X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e8e24dfa9322702d56a125586a7d4a37f4a5dfd7..08989e30ede130f0ec29ddf0d4f36a71211bdcee:/src/gtk/stattext.cpp diff --git a/src/gtk/stattext.cpp b/src/gtk/stattext.cpp index 228cac559f..6e0916a79a 100644 --- a/src/gtk/stattext.cpp +++ b/src/gtk/stattext.cpp @@ -148,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)) @@ -192,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