X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/33720b2de5ada9513c163a9694e7e267234bf791..f51a6f6a0c11f2d5ce58bcb858f5dfa1c27299a5:/src/gtk/stattext.cpp diff --git a/src/gtk/stattext.cpp b/src/gtk/stattext.cpp index 8136ac250c..6e00a77898 100644 --- a/src/gtk/stattext.cpp +++ b/src/gtk/stattext.cpp @@ -62,8 +62,6 @@ bool wxStaticText::Create(wxWindow *parent, wxControl::SetLabel(label); m_widget = gtk_label_new( m_label.mbc_str() ); - wxControl::SetFont( parent->GetFont() ); - GtkJustification justify; if ( style & wxALIGN_CENTER ) justify = GTK_JUSTIFY_CENTER; @@ -80,11 +78,22 @@ bool wxStaticText::Create(wxWindow *parent, // do not move this call elsewhere gtk_label_set_line_wrap( GTK_LABEL(m_widget), FALSE ); - SetSizeOrDefault( size ); - m_parent->DoAddChild( this ); PostCreation(); + + ApplyWidgetStyle(); + + wxControl::SetFont( parent->GetFont() ); + + wxSize size_best( DoGetBestSize() ); + wxSize new_size( size ); + if (new_size.x == -1) + new_size.x = size_best.x; + if (new_size.y == -1) + new_size.y = size_best.y; + if ((new_size.x != size.x) || (new_size.y != size.y)) + SetSize( new_size.x, new_size.y ); SetBackgroundColour( parent->GetBackgroundColour() ); SetForegroundColour( parent->GetForegroundColour() ); @@ -141,7 +150,7 @@ wxSize wxStaticText::DoGetBestSize() const GtkRequisition req; req.width = 2; req.height = 2; - (* GTK_WIDGET_CLASS( GTK_OBJECT(m_widget)->klass )->size_request ) + (* GTK_WIDGET_CLASS( GTK_OBJECT_GET_CLASS(m_widget) )->size_request ) (m_widget, &req ); return wxSize(req.width, req.height);