X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e1f448eeefd90163fedd9134f35203afe51200c6..29281095c4959cbadfcc66efccf679c6c25c7dc7:/src/gtk/stattext.cpp diff --git a/src/gtk/stattext.cpp b/src/gtk/stattext.cpp index 53fe9f98e5..6e0916a79a 100644 --- a/src/gtk/stattext.cpp +++ b/src/gtk/stattext.cpp @@ -7,12 +7,12 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// - -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "stattext.h" #endif -#include "wx/defs.h" +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" #if wxUSE_STATTEXT @@ -111,7 +111,8 @@ bool wxStaticText::Create(wxWindow *parent, ApplyWidgetStyle(); - wxControl::SetFont( parent->GetFont() ); + InheritAttributes(); +// wxControl::SetFont( parent->GetFont() ); wxSize size_best( DoGetBestSize() ); wxSize new_size( size ); @@ -122,8 +123,11 @@ bool wxStaticText::Create(wxWindow *parent, if ((new_size.x != size.x) || (new_size.y != size.y)) SetSize( new_size.x, new_size.y ); - SetBackgroundColour( parent->GetBackgroundColour() ); - SetForegroundColour( parent->GetForegroundColour() ); +// if (ShouldInheritColours()) +// { +// SetBackgroundColour( parent->GetBackgroundColour() ); +// SetForegroundColour( parent->GetForegroundColour() ); +// } Show( TRUE ); return TRUE; @@ -144,9 +148,23 @@ wxString wxStaticText::GetLabel() const void wxStaticText::SetLabel( const wxString &label ) { + // Build the colorized version of the label + wxString colorlabel = label; + // If the color has been set, create a markup string to pass to the label setter + if (m_foregroundColour.Ok()) + { + colorlabel.Printf(_T("%s"), m_foregroundColour.Red(), + m_foregroundColour.Green(), m_foregroundColour.Blue(), label.c_str()); + } + wxControl::SetLabel(label); + // markup only allowed under GTK2 +#ifdef __WXGTK20__ + gtk_label_set_markup( GTK_LABEL(m_widget), wxGTK_CONV( colorlabel ) ); +#else gtk_label_set( GTK_LABEL(m_widget), wxGTK_CONV( m_label ) ); +#endif // adjust the label size to the new label unless disabled if (!HasFlag(wxST_NO_AUTORESIZE)) @@ -188,4 +206,13 @@ wxSize wxStaticText::DoGetBestSize() const return wxSize(req.width, req.height); } +bool wxStaticText::SetForegroundColour(const wxColour& colour) +{ + // First, we call the base class member + wxControl::SetForegroundColour(colour); + // Then, to force the color change, we set the label with the current label + SetLabel(GetLabel()); + return true; +} + #endif // wxUSE_STATTEXT