// Author: Vaclav Slavik
// (based on GTK & MSW implementations)
// RCS-ID: $Id$
-// Copyright: (c) 2001 SciTech Software, Inc. (www.scitechsoft.com)
+// Copyright: (c) 2001-2002 SciTech Software, Inc. (www.scitechsoft.com)
// Licence: wxWindows license
/////////////////////////////////////////////////////////////////////////////
// the window that has keyboard focus:
static wxWindowMGL *gs_focusedWindow = NULL;
+// the window that is about to be focused after currently focused
+// one looses focus:
+static wxWindow *gs_toBeFocusedWindow = NULL;
// the window that is currently under mouse cursor:
static wxWindowMGL *gs_windowUnderMouse = NULL;
// the window that has mouse capture
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:
+ // Change focus if the user clicks outside focused window:
+ if ( win->AcceptsFocus() && wxWindow::FindFocus() != win )
+ win->SetFocus();
+
if ( e->message & EVT_LEFTBMASK )
- type = (e->message & EVT_DBLCLICK) ?
- wxEVT_LEFT_DCLICK : wxEVT_LEFT_DOWN;
+ type = wxEVT_LEFT_DOWN;
else if ( e->message & EVT_MIDDLEBMASK )
- type = (e->message & EVT_DBLCLICK) ?
- wxEVT_MIDDLE_DCLICK : wxEVT_MIDDLE_DOWN;
+ type = wxEVT_MIDDLE_DOWN;
else if ( e->message & EVT_RIGHTBMASK )
- type = (e->message & EVT_DBLCLICK) ?
- wxEVT_RIGHT_DCLICK : wxEVT_RIGHT_DOWN;
+ type = wxEVT_RIGHT_DOWN;
- if ( win->AcceptsFocus() && wxWindow::FindFocus() != win )
- win->SetFocus();
+ 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 )
+ type = wxEVT_MIDDLE_DCLICK;
+ else if ( e->message & EVT_RIGHTBMASK )
+ type = wxEVT_RIGHT_DCLICK;
+ }
break;
{
if ( gs_focusedWindow == this ) return;
+ wxWindowMGL *oldFocusedWindow = gs_focusedWindow;
+
if ( gs_focusedWindow )
+ {
+ gs_toBeFocusedWindow = (wxWindow*)this;
gs_focusedWindow->KillFocus();
+ gs_toBeFocusedWindow = NULL;
+ }
gs_focusedWindow = this;
wxFocusEvent event(wxEVT_SET_FOCUS, GetId());
event.SetEventObject(this);
+ event.SetWindow((wxWindow*)oldFocusedWindow);
GetEventHandler()->ProcessEvent(event);
#if wxUSE_CARET
wxFocusEvent event(wxEVT_KILL_FOCUS, GetId());
event.SetEventObject(this);
+ event.SetWindow(gs_toBeFocusedWindow);
GetEventHandler()->ProcessEvent(event);
}