Implementation of wxSysColourChangedEvent on wxGTK

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@49492 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Julian Smart
2007-10-27 17:38:39 +00:00
parent a45f904dea
commit 013151c744
3 changed files with 85 additions and 0 deletions

View File

@@ -16,6 +16,7 @@
class WXDLLIMPEXP_CORE wxTopLevelWindowGTK : public wxTopLevelWindowBase class WXDLLIMPEXP_CORE wxTopLevelWindowGTK : public wxTopLevelWindowBase
{ {
DECLARE_EVENT_TABLE()
public: public:
// construction // construction
wxTopLevelWindowGTK() { Init(); } wxTopLevelWindowGTK() { Init(); }
@@ -85,6 +86,9 @@ public:
// GTK callbacks // GTK callbacks
virtual void OnInternalIdle(); virtual void OnInternalIdle();
// Respond to system colour change
void OnSysColourChanged(wxSysColourChangedEvent& event);
// do *not* call this to iconize the frame, this is a private function! // do *not* call this to iconize the frame, this is a private function!
void SetIconizeState(bool iconic); void SetIconizeState(bool iconic);

View File

@@ -452,6 +452,11 @@ static gboolean property_notify_event(
} }
} }
BEGIN_EVENT_TABLE(wxTopLevelWindowGTK, wxTopLevelWindowBase)
EVT_SYS_COLOUR_CHANGED(wxTopLevelWindowGTK::OnSysColourChanged)
END_EVENT_TABLE()
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// wxTopLevelWindowGTK creation // wxTopLevelWindowGTK creation
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -1282,3 +1287,16 @@ bool wxTopLevelWindowGTK::CanSetTransparent()
"Composite", &opcode, &event, &error); "Composite", &opcode, &event, &error);
#endif #endif
} }
void wxTopLevelWindowGTK::OnSysColourChanged(wxSysColourChangedEvent& event)
{
// We don't know the order in which top-level windows will
// be notified, so we need to clear the system objects
// for each top-level window.
extern void wxClearGtkSystemObjects();
wxClearGtkSystemObjects();
// wxWindowBase::OnSysColourChanged will propagate event
// to children
event.Skip();
}

View File

@@ -2116,8 +2116,65 @@ gtk_window_grab_broken( GtkWidget*,
} }
#endif #endif
//-----------------------------------------------------------------------------
// "style_set"
//-----------------------------------------------------------------------------
static
void gtk_window_style_set_callback( GtkWidget *WXUNUSED(widget),
GtkStyle *previous_style,
wxWindow* win )
{
//wxLogDebug(wxT("gtk_window_style_set_callback"));
if (win && previous_style)
{
wxString name(win->GetName());
//wxLogDebug(wxT("gtk_window_style_set_callback %s"), name.c_str());
wxSysColourChangedEvent event;
event.SetEventObject(win);
win->GTKProcessEvent( event );
}
}
} // extern "C" } // extern "C"
// Connect/disconnect style-set
void wxConnectStyleSet(wxWindow* win)
{
if (win->m_wxwindow)
g_signal_connect (win->m_wxwindow, "style_set",
G_CALLBACK (gtk_window_style_set_callback), win);
}
void wxDisconnectStyleSet(wxWindow* win)
{
if (win->m_wxwindow)
g_signal_handlers_disconnect_by_func (win->m_wxwindow,
(gpointer) gtk_window_style_set_callback,
win);
}
// Helper to suspend colour change event event processing while we change a widget's style
class wxSuspendStyleEvents
{
public:
wxSuspendStyleEvents(wxWindow* win)
{
m_win = win;
if (win->IsTopLevel())
wxDisconnectStyleSet(win);
}
~wxSuspendStyleEvents()
{
if (m_win->IsTopLevel())
wxConnectStyleSet(m_win);
}
wxWindow* m_win;
};
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// this wxWindowBase function is implemented here (in platform-specific file) // this wxWindowBase function is implemented here (in platform-specific file)
// because it is static and so couldn't be made virtual // because it is static and so couldn't be made virtual
@@ -2614,6 +2671,10 @@ void wxWindowGTK::ConnectWidget( GtkWidget *widget )
G_CALLBACK (gtk_window_enter_callback), this); G_CALLBACK (gtk_window_enter_callback), this);
g_signal_connect (widget, "leave_notify_event", g_signal_connect (widget, "leave_notify_event",
G_CALLBACK (gtk_window_leave_callback), this); G_CALLBACK (gtk_window_leave_callback), this);
if (IsTopLevel() && m_wxwindow)
g_signal_connect (m_wxwindow, "style_set",
G_CALLBACK (gtk_window_style_set_callback), this);
} }
bool wxWindowGTK::Destroy() bool wxWindowGTK::Destroy()
@@ -3918,6 +3979,8 @@ void wxWindowGTK::ApplyWidgetStyle(bool forceStyle)
void wxWindowGTK::DoApplyWidgetStyle(GtkRcStyle *style) void wxWindowGTK::DoApplyWidgetStyle(GtkRcStyle *style)
{ {
wxSuspendStyleEvents s(this);
if (m_wxwindow) if (m_wxwindow)
gtk_widget_modify_style(m_wxwindow, style); gtk_widget_modify_style(m_wxwindow, style);
else else