X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/fe161a2685012cf90bb5bfe95f2260aee71d8ad7..d40a56d0db2e5249a65087b6af7d1ff7bfb378a6:/src/gtk1/stattext.cpp?ds=sidebyside diff --git a/src/gtk1/stattext.cpp b/src/gtk1/stattext.cpp index f3c40c1226..9b5aa5cb2f 100644 --- a/src/gtk1/stattext.cpp +++ b/src/gtk1/stattext.cpp @@ -132,24 +132,41 @@ void wxStaticText::SetLabel( const wxString &label ) #ifdef __WXGTK20__ // Build the colorized version of the label (markup only allowed // under GTK2): - wxString colorlabel = label; - // If the color has been set, create a markup string to pass to - // the label setter if (m_foregroundColour.Ok()) { + // If the color has been set, create a markup string to pass to + // the label setter + wxString colorlabel; colorlabel.Printf(_T("%s"), m_foregroundColour.Red(), m_foregroundColour.Green(), - m_foregroundColour.Blue(), label.c_str()); + m_foregroundColour.Blue(), + wxEscapeStringForPangoMarkup(label).c_str()); + gtk_label_set_markup( GTK_LABEL(m_widget), wxGTK_CONV( colorlabel ) ); } - - gtk_label_set_markup( GTK_LABEL(m_widget), wxGTK_CONV( colorlabel ) ); -#else - gtk_label_set( GTK_LABEL(m_widget), wxGTK_CONV( m_label ) ); + else #endif - - PostSetLabel(); + gtk_label_set( GTK_LABEL(m_widget), wxGTK_CONV( m_label ) ); + + // adjust the label size to the new label unless disabled + if (!HasFlag(wxST_NO_AUTORESIZE)) + { + InvalidateBestSize(); + SetSize( GetBestSize() ); + } } +bool wxStaticText::SetFont( const wxFont &font ) +{ + bool ret = wxControl::SetFont(font); + + // adjust the label size to the new label unless disabled + if (!HasFlag(wxST_NO_AUTORESIZE)) + { + InvalidateBestSize(); + SetSize( GetBestSize() ); + } + return ret; +} wxSize wxStaticText::DoGetBestSize() const { @@ -166,7 +183,9 @@ wxSize wxStaticText::DoGetBestSize() const (* GTK_WIDGET_CLASS( GTK_OBJECT_GET_CLASS(m_widget) )->size_request ) (m_widget, &req ); - return wxSize(req.width, req.height); + wxSize best(req.width, req.height); + CacheBestSize(best); + return best; } bool wxStaticText::SetForegroundColour(const wxColour& colour)