X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/eea932674bd95e7f785560fbedd785fcb2bdaa1b..4b2424bcadbc87babd3367d243b957e49333eeae:/src/mgl/window.cpp diff --git a/src/mgl/window.cpp b/src/mgl/window.cpp index dd5bfd6c40..28e827dcc4 100644 --- a/src/mgl/window.cpp +++ b/src/mgl/window.cpp @@ -104,7 +104,7 @@ static wxWindowMGL* wxGetTopLevelParent(wxWindowMGL *win) } // An easy way to capture screenshots: -static void wxCaptureScreenshot() +static void wxCaptureScreenshot(bool activeWindowOnly) { #ifdef __DOS__ #define SCREENSHOT_FILENAME _T("sshot%03i.png") @@ -119,9 +119,15 @@ static void wxCaptureScreenshot() screenshot.Printf(SCREENSHOT_FILENAME, screenshot_num++); } while ( wxFileExists(screenshot) && screenshot_num < 1000 ); - g_displayDC->savePNGFromDC(screenshot.mb_str(), 0, 0, - g_displayDC->sizex(), - g_displayDC->sizey()); + wxRect r(0, 0, g_displayDC->sizex(), g_displayDC->sizey()); + + if ( activeWindowOnly && gs_activeFrame ) + { + r.Intersect(gs_activeFrame->GetRect()); + } + + g_displayDC->savePNGFromDC(screenshot.mb_str(), + r.x, r. y, r.x+r.width, r.y+r.height); wxMessageBox(_("Screenshot captured: ") + wxString(screenshot)); } @@ -171,23 +177,33 @@ static ibool MGLAPI wxWindowMouseHandler(window_t *wnd, event_t *e) event.m_leftDown = e->modifiers & EVT_LEFTBUT; event.m_middleDown = e->modifiers & EVT_MIDDLEBUT; event.m_rightDown = e->modifiers & EVT_RIGHTBUT; - + switch (e->what) { case EVT_MOUSEDOWN: - if ( e->message & EVT_LEFTBMASK ) - type = (e->message & EVT_DBLCLICK) ? - wxEVT_LEFT_DCLICK : wxEVT_LEFT_DOWN; - else if ( e->message & EVT_MIDDLEBMASK ) - type = (e->message & EVT_DBLCLICK) ? - wxEVT_MIDDLE_DCLICK : wxEVT_MIDDLE_DOWN; - else if ( e->message & EVT_RIGHTBMASK ) - type = (e->message & EVT_DBLCLICK) ? - wxEVT_RIGHT_DCLICK : wxEVT_RIGHT_DOWN; - + // Change focus if the user clicks outside focused window: if ( win->AcceptsFocus() && wxWindow::FindFocus() != win ) win->SetFocus(); + if ( e->message & EVT_DBLCLICK ) + { + if ( e->message & EVT_LEFTBMASK ) + type = wxEVT_LEFT_DCLICK; + else if ( e->message & EVT_MIDDLEBMASK ) + type = wxEVT_MIDDLE_DCLICK; + else if ( e->message & EVT_RIGHTBMASK ) + type = wxEVT_RIGHT_DCLICK; + } + else + { + if ( e->message & EVT_LEFTBMASK ) + type = wxEVT_LEFT_DOWN; + else if ( e->message & EVT_MIDDLEBMASK ) + type = wxEVT_MIDDLE_DOWN; + else if ( e->message & EVT_RIGHTBMASK ) + type = wxEVT_RIGHT_DOWN; + } + break; case EVT_MOUSEUP: @@ -421,7 +437,7 @@ static bool wxHandleSpecialKeys(wxKeyEvent& event) ) #endif { - wxCaptureScreenshot(); + wxCaptureScreenshot(event.m_altDown/*only active wnd?*/); return TRUE; } @@ -899,7 +915,7 @@ void wxWindowMGL::DragAcceptFiles(bool accept) // Get total size void wxWindowMGL::DoGetSize(int *x, int *y) const { - wxASSERT_MSG( m_wnd, wxT("invalid window") ) + wxASSERT_MSG( m_wnd, wxT("invalid window") ); if (x) *x = m_wnd->width; if (y) *y = m_wnd->height; @@ -907,10 +923,13 @@ void wxWindowMGL::DoGetSize(int *x, int *y) const void wxWindowMGL::DoGetPosition(int *x, int *y) const { - wxASSERT_MSG( m_wnd, wxT("invalid window") ) + wxASSERT_MSG( m_wnd, wxT("invalid window") ); + + int pX = 0, pY = 0; + AdjustForParentClientOrigin(pX, pY, 0); - if (x) *x = m_wnd->x; - if (y) *y = m_wnd->y; + if (x) *x = m_wnd->x - pX; + if (y) *y = m_wnd->y - pY; } void wxWindowMGL::DoScreenToClient(int *x, int *y) const