minor fixes
cursor fix for splitter window git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2352 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
051b55ad8b
commit
58d1c1ae86
@ -164,6 +164,9 @@ public:
|
|||||||
bool DoPhase(int phase);
|
bool DoPhase(int phase);
|
||||||
void ApplyWidgetStyle();
|
void ApplyWidgetStyle();
|
||||||
|
|
||||||
|
// report if window belongs to notebook
|
||||||
|
bool IsOwnGtkWindow( GdkWindow *window );
|
||||||
|
|
||||||
// common part of all ctors
|
// common part of all ctors
|
||||||
void Init();
|
void Init();
|
||||||
|
|
||||||
|
@ -164,6 +164,9 @@ public:
|
|||||||
bool DoPhase(int phase);
|
bool DoPhase(int phase);
|
||||||
void ApplyWidgetStyle();
|
void ApplyWidgetStyle();
|
||||||
|
|
||||||
|
// report if window belongs to notebook
|
||||||
|
bool IsOwnGtkWindow( GdkWindow *window );
|
||||||
|
|
||||||
// common part of all ctors
|
// common part of all ctors
|
||||||
void Init();
|
void Init();
|
||||||
|
|
||||||
|
@ -67,14 +67,7 @@
|
|||||||
{ (const wxEventTable *)NULL, &wxEvtHandler::sm_eventTableEntries[0] };
|
{ (const wxEventTable *)NULL, &wxEvtHandler::sm_eventTableEntries[0] };
|
||||||
|
|
||||||
const wxEventTableEntry wxEvtHandler::sm_eventTableEntries[] =
|
const wxEventTableEntry wxEvtHandler::sm_eventTableEntries[] =
|
||||||
{ { 0, 0, 0,
|
{ { 0, 0, 0, (wxObjectEventFunction) NULL, (wxObject*) NULL } };
|
||||||
#ifdef __SGI_CC__
|
|
||||||
// stupid SGI compiler --- offer aug 98
|
|
||||||
0L }
|
|
||||||
#else // !SGI CC
|
|
||||||
NULL }
|
|
||||||
#endif // SGI/!SGI
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // !USE_SHARED_LIBRARY
|
#endif // !USE_SHARED_LIBRARY
|
||||||
|
|
||||||
|
@ -153,6 +153,16 @@ void wxSplitterWindow::OnMouseEvent(wxMouseEvent& event)
|
|||||||
SetCursor(wxCursor());
|
SetCursor(wxCursor());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// under wxGTK the method above causes the mouse
|
||||||
|
// to flicker so we set the standard cursor only
|
||||||
|
// when leaving the window and when moving over
|
||||||
|
// non-sash parts of the window. this should work
|
||||||
|
// on the other platforms as well, but who knows.
|
||||||
|
#ifdef __WXGTK__
|
||||||
|
if (event.Leaving())
|
||||||
|
SetCursor(* wxSTANDARD_CURSOR);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (event.LeftDown())
|
if (event.LeftDown())
|
||||||
{
|
{
|
||||||
if ( SashHitTest(x, y) )
|
if ( SashHitTest(x, y) )
|
||||||
@ -173,9 +183,6 @@ void wxSplitterWindow::OnMouseEvent(wxMouseEvent& event)
|
|||||||
m_dragMode = wxSPLIT_DRAG_NONE;
|
m_dragMode = wxSPLIT_DRAG_NONE;
|
||||||
ReleaseMouse();
|
ReleaseMouse();
|
||||||
|
|
||||||
#ifdef __WXGTK__
|
|
||||||
SetCursor(* wxSTANDARD_CURSOR);
|
|
||||||
#endif
|
|
||||||
// Erase old tracker
|
// Erase old tracker
|
||||||
DrawSashTracker(m_oldX, m_oldY);
|
DrawSashTracker(m_oldX, m_oldY);
|
||||||
|
|
||||||
@ -253,6 +260,13 @@ void wxSplitterWindow::OnMouseEvent(wxMouseEvent& event)
|
|||||||
SetCursor(*m_sashCursorNS);
|
SetCursor(*m_sashCursorNS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#ifdef __WXGTK__
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// where else do we unset the cursor?
|
||||||
|
SetCursor(* wxSTANDARD_CURSOR);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else if (event.Dragging() && (m_dragMode == wxSPLIT_DRAG_DRAGGING))
|
else if (event.Dragging() && (m_dragMode == wxSPLIT_DRAG_DRAGGING))
|
||||||
{
|
{
|
||||||
|
@ -707,6 +707,12 @@ void wxNotebook::ApplyWidgetStyle()
|
|||||||
gtk_widget_set_style( m_widget, m_widgetStyle );
|
gtk_widget_set_style( m_widget, m_widgetStyle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool wxNotebook::IsOwnGtkWindow( GdkWindow *window )
|
||||||
|
{
|
||||||
|
return ((m_widget->window == window) ||
|
||||||
|
(GTK_NOTEBOOK(m_widget)->panel == window));
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxNotebookEvent
|
// wxNotebookEvent
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -464,8 +464,10 @@ gtk_myfixed_size_request (GtkWidget *widget,
|
|||||||
|
|
||||||
myfixed = GTK_MYFIXED (widget);
|
myfixed = GTK_MYFIXED (widget);
|
||||||
|
|
||||||
requisition->width = widget->requisition.width;
|
/* request very little, I'm not sure if requesting nothing
|
||||||
requisition->height = widget->requisition.height;
|
will always have positive effects on stability... */
|
||||||
|
requisition->width = 2;
|
||||||
|
requisition->height = 2;
|
||||||
|
|
||||||
children = myfixed->children;
|
children = myfixed->children;
|
||||||
while (children)
|
while (children)
|
||||||
|
@ -1092,7 +1092,7 @@ static gint gtk_window_enter_callback( GtkWidget *widget, GdkEventCrossing *gdk_
|
|||||||
if (!win->HasVMT()) return FALSE;
|
if (!win->HasVMT()) return FALSE;
|
||||||
if (g_blockEventsOnDrag) return FALSE;
|
if (g_blockEventsOnDrag) return FALSE;
|
||||||
|
|
||||||
if (widget->window != gdk_event->window) return FALSE;
|
if (!win->IsOwnGtkWindow( gdk_event->window )) return FALSE;
|
||||||
|
|
||||||
if ((widget->window) && (win->m_cursor.Ok()))
|
if ((widget->window) && (win->m_cursor.Ok()))
|
||||||
gdk_window_set_cursor( widget->window, win->m_cursor.GetCursor() );
|
gdk_window_set_cursor( widget->window, win->m_cursor.GetCursor() );
|
||||||
@ -1144,16 +1144,16 @@ static gint gtk_window_leave_callback( GtkWidget *widget, GdkEventCrossing *gdk_
|
|||||||
if (!win->HasVMT()) return FALSE;
|
if (!win->HasVMT()) return FALSE;
|
||||||
if (g_blockEventsOnDrag) return FALSE;
|
if (g_blockEventsOnDrag) return FALSE;
|
||||||
|
|
||||||
if (widget->window != gdk_event->window) return FALSE;
|
if (!win->IsOwnGtkWindow( gdk_event->window )) return FALSE;
|
||||||
|
|
||||||
if (widget->window)
|
if (widget->window)
|
||||||
gdk_window_set_cursor( widget->window, wxSTANDARD_CURSOR->GetCursor() );
|
gdk_window_set_cursor( widget->window, wxSTANDARD_CURSOR->GetCursor() );
|
||||||
|
|
||||||
/*
|
/*
|
||||||
printf( "OnLeave from " );
|
wxPrintf( _T("OnLeave from ") );
|
||||||
if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
|
if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
|
||||||
printf( win->GetClassInfo()->GetClassName() );
|
wxPrintf( win->GetClassInfo()->GetClassName() );
|
||||||
printf( ".\n" );
|
wxPrintf( _T(".\n") );
|
||||||
*/
|
*/
|
||||||
|
|
||||||
wxMouseEvent event( wxEVT_LEAVE_WINDOW );
|
wxMouseEvent event( wxEVT_LEAVE_WINDOW );
|
||||||
|
@ -707,6 +707,12 @@ void wxNotebook::ApplyWidgetStyle()
|
|||||||
gtk_widget_set_style( m_widget, m_widgetStyle );
|
gtk_widget_set_style( m_widget, m_widgetStyle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool wxNotebook::IsOwnGtkWindow( GdkWindow *window )
|
||||||
|
{
|
||||||
|
return ((m_widget->window == window) ||
|
||||||
|
(GTK_NOTEBOOK(m_widget)->panel == window));
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxNotebookEvent
|
// wxNotebookEvent
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -464,8 +464,10 @@ gtk_myfixed_size_request (GtkWidget *widget,
|
|||||||
|
|
||||||
myfixed = GTK_MYFIXED (widget);
|
myfixed = GTK_MYFIXED (widget);
|
||||||
|
|
||||||
requisition->width = widget->requisition.width;
|
/* request very little, I'm not sure if requesting nothing
|
||||||
requisition->height = widget->requisition.height;
|
will always have positive effects on stability... */
|
||||||
|
requisition->width = 2;
|
||||||
|
requisition->height = 2;
|
||||||
|
|
||||||
children = myfixed->children;
|
children = myfixed->children;
|
||||||
while (children)
|
while (children)
|
||||||
|
@ -1092,7 +1092,7 @@ static gint gtk_window_enter_callback( GtkWidget *widget, GdkEventCrossing *gdk_
|
|||||||
if (!win->HasVMT()) return FALSE;
|
if (!win->HasVMT()) return FALSE;
|
||||||
if (g_blockEventsOnDrag) return FALSE;
|
if (g_blockEventsOnDrag) return FALSE;
|
||||||
|
|
||||||
if (widget->window != gdk_event->window) return FALSE;
|
if (!win->IsOwnGtkWindow( gdk_event->window )) return FALSE;
|
||||||
|
|
||||||
if ((widget->window) && (win->m_cursor.Ok()))
|
if ((widget->window) && (win->m_cursor.Ok()))
|
||||||
gdk_window_set_cursor( widget->window, win->m_cursor.GetCursor() );
|
gdk_window_set_cursor( widget->window, win->m_cursor.GetCursor() );
|
||||||
@ -1144,16 +1144,16 @@ static gint gtk_window_leave_callback( GtkWidget *widget, GdkEventCrossing *gdk_
|
|||||||
if (!win->HasVMT()) return FALSE;
|
if (!win->HasVMT()) return FALSE;
|
||||||
if (g_blockEventsOnDrag) return FALSE;
|
if (g_blockEventsOnDrag) return FALSE;
|
||||||
|
|
||||||
if (widget->window != gdk_event->window) return FALSE;
|
if (!win->IsOwnGtkWindow( gdk_event->window )) return FALSE;
|
||||||
|
|
||||||
if (widget->window)
|
if (widget->window)
|
||||||
gdk_window_set_cursor( widget->window, wxSTANDARD_CURSOR->GetCursor() );
|
gdk_window_set_cursor( widget->window, wxSTANDARD_CURSOR->GetCursor() );
|
||||||
|
|
||||||
/*
|
/*
|
||||||
printf( "OnLeave from " );
|
wxPrintf( _T("OnLeave from ") );
|
||||||
if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
|
if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
|
||||||
printf( win->GetClassInfo()->GetClassName() );
|
wxPrintf( win->GetClassInfo()->GetClassName() );
|
||||||
printf( ".\n" );
|
wxPrintf( _T(".\n") );
|
||||||
*/
|
*/
|
||||||
|
|
||||||
wxMouseEvent event( wxEVT_LEAVE_WINDOW );
|
wxMouseEvent event( wxEVT_LEAVE_WINDOW );
|
||||||
|
Loading…
Reference in New Issue
Block a user