}
// An easy way to capture screenshots:
-static void wxCaptureScreenshot()
+static void wxCaptureScreenshot(bool activeWindowOnly)
{
#ifdef __DOS__
#define SCREENSHOT_FILENAME _T("sshot%03i.png")
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));
}
if ( win->AcceptsFocus() && wxWindow::FindFocus() != win )
win->SetFocus();
- 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;
-
if ( e->message & EVT_DBLCLICK )
{
- // MGL doesn't generate two subsequent single clicks prior
- // to a double click, but rather only fires one single click
- // followed by one double click. wxWindows expects two single
- // clicks, so we have to emulate the second one.
- event.SetEventType(type);
- win->GetEventHandler()->ProcessEvent(event);
-
- // And change event type for the real double click event
- // that will be generated later in this function:
if ( e->message & EVT_LEFTBMASK )
type = wxEVT_LEFT_DCLICK;
else if ( e->message & EVT_MIDDLEBMASK )
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;
)
#endif
{
- wxCaptureScreenshot();
+ wxCaptureScreenshot(event.m_altDown/*only active wnd?*/);
return TRUE;
}
// 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;
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