X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/33720b2de5ada9513c163a9694e7e267234bf791..2b004197c8cea40b41632e86cf27857463f985b8:/src/gtk1/stattext.cpp diff --git a/src/gtk1/stattext.cpp b/src/gtk1/stattext.cpp index 8136ac250c..f10c32753c 100644 --- a/src/gtk1/stattext.cpp +++ b/src/gtk1/stattext.cpp @@ -12,6 +12,10 @@ #pragma implementation "stattext.h" #endif +#include "wx/defs.h" + +#if wxUSE_STATTEXT + #include "wx/stattext.h" #include "gdk/gdk.h" @@ -62,8 +66,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 +82,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,9 +154,10 @@ 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); } +#endif // wxUSE_STATTEXT