Some Resize/GetBestSize() changes.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5169 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -108,8 +108,8 @@ bool wxComboBox::Create( wxWindow *parent, wxWindowID id, const wxString& value,
|
|||||||
newSize.x = bestSize.x;
|
newSize.x = bestSize.x;
|
||||||
if (newSize.y == -1)
|
if (newSize.y == -1)
|
||||||
newSize.y = bestSize.y;
|
newSize.y = bestSize.y;
|
||||||
if (newSize.y > 30)
|
if (newSize.y > 22)
|
||||||
newSize.y = 30;
|
newSize.y = 22;
|
||||||
|
|
||||||
if (!PreCreation( parent, pos, newSize ) ||
|
if (!PreCreation( parent, pos, newSize ) ||
|
||||||
!CreateBase( parent, id, pos, size, style, validator, name ))
|
!CreateBase( parent, id, pos, size, style, validator, name ))
|
||||||
@@ -666,7 +666,7 @@ bool wxComboBox::IsOwnGtkWindow( GdkWindow *window )
|
|||||||
wxSize wxComboBox::DoGetBestSize() const
|
wxSize wxComboBox::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
// totally bogus - should measure the strings in the combo!
|
// totally bogus - should measure the strings in the combo!
|
||||||
return wxSize(100, 26);
|
return wxSize(100, 22);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -74,6 +74,9 @@ wxString wxControl::GetLabel() const
|
|||||||
|
|
||||||
wxSize wxControl::DoGetBestSize() const
|
wxSize wxControl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
|
// Do not return any arbitrary default value...
|
||||||
|
wxASSERT_MSG( m_widget, wxT("DoGetBestSize called before creation") );
|
||||||
|
|
||||||
GtkRequisition req;
|
GtkRequisition req;
|
||||||
(* GTK_WIDGET_CLASS( GTK_OBJECT(m_widget)->klass )->size_request )
|
(* GTK_WIDGET_CLASS( GTK_OBJECT(m_widget)->klass )->size_request )
|
||||||
(m_widget, &req );
|
(m_widget, &req );
|
||||||
|
@@ -75,15 +75,8 @@ bool wxSpinCtrl::Create(wxWindow *parent, wxWindowID id,
|
|||||||
m_needParent = TRUE;
|
m_needParent = TRUE;
|
||||||
m_acceptsFocus = TRUE;
|
m_acceptsFocus = TRUE;
|
||||||
|
|
||||||
wxSize new_size = size,
|
if (!PreCreation( parent, pos, size ) ||
|
||||||
sizeBest = DoGetBestSize();
|
!CreateBase( parent, id, pos, size, style, wxDefaultValidator, name ))
|
||||||
if (new_size.x == -1)
|
|
||||||
new_size.x = sizeBest.x;
|
|
||||||
if (new_size.y == -1)
|
|
||||||
new_size.y = sizeBest.y;
|
|
||||||
|
|
||||||
if (!PreCreation( parent, pos, new_size ) ||
|
|
||||||
!CreateBase( parent, id, pos, new_size, style, wxDefaultValidator, name ))
|
|
||||||
{
|
{
|
||||||
wxFAIL_MSG( wxT("wxSpinCtrl creation failed") );
|
wxFAIL_MSG( wxT("wxSpinCtrl creation failed") );
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@@ -95,6 +88,16 @@ bool wxSpinCtrl::Create(wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
m_widget = gtk_spin_button_new( m_adjust, 1, 0 );
|
m_widget = gtk_spin_button_new( m_adjust, 1, 0 );
|
||||||
|
|
||||||
|
wxSize new_size = size,
|
||||||
|
sizeBest = DoGetBestSize();
|
||||||
|
if (new_size.x == -1)
|
||||||
|
new_size.x = sizeBest.x;
|
||||||
|
if (new_size.y == -1)
|
||||||
|
new_size.y = sizeBest.y;
|
||||||
|
|
||||||
|
if ((new_size.x != size.x) || (new_size.y != size.y))
|
||||||
|
SetSize( new_size.x, new_size.y );
|
||||||
|
|
||||||
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON(m_widget),
|
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON(m_widget),
|
||||||
(int)(m_windowStyle & wxSP_WRAP) );
|
(int)(m_windowStyle & wxSP_WRAP) );
|
||||||
|
|
||||||
@@ -224,7 +227,8 @@ void wxSpinCtrl::ApplyWidgetStyle()
|
|||||||
|
|
||||||
wxSize wxSpinCtrl::DoGetBestSize() const
|
wxSize wxSpinCtrl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
return wxSize(95, 26);
|
wxSize ret( wxControl::DoGetBestSize() );
|
||||||
|
return wxSize(95, ret.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -192,7 +192,15 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
m_text = gtk_entry_new();
|
m_text = gtk_entry_new();
|
||||||
}
|
}
|
||||||
|
|
||||||
SetSizeOrDefault( size );
|
wxSize new_size = size,
|
||||||
|
sizeBest = DoGetBestSize();
|
||||||
|
if (new_size.x == -1)
|
||||||
|
new_size.x = sizeBest.x;
|
||||||
|
if (new_size.y == -1)
|
||||||
|
new_size.y = sizeBest.y;
|
||||||
|
|
||||||
|
if ((new_size.x != size.x) || (new_size.y != size.y))
|
||||||
|
SetSize( new_size.x, new_size.y );
|
||||||
|
|
||||||
m_parent->DoAddChild( this );
|
m_parent->DoAddChild( this );
|
||||||
|
|
||||||
@@ -977,5 +985,6 @@ void wxTextCtrl::OnInternalIdle()
|
|||||||
wxSize wxTextCtrl::DoGetBestSize() const
|
wxSize wxTextCtrl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
// FIXME should be different for multi-line controls...
|
// FIXME should be different for multi-line controls...
|
||||||
return wxSize(80, 26);
|
wxSize ret( wxControl::DoGetBestSize() );
|
||||||
|
return wxSize(80, ret.y);
|
||||||
}
|
}
|
||||||
|
@@ -108,8 +108,8 @@ bool wxComboBox::Create( wxWindow *parent, wxWindowID id, const wxString& value,
|
|||||||
newSize.x = bestSize.x;
|
newSize.x = bestSize.x;
|
||||||
if (newSize.y == -1)
|
if (newSize.y == -1)
|
||||||
newSize.y = bestSize.y;
|
newSize.y = bestSize.y;
|
||||||
if (newSize.y > 30)
|
if (newSize.y > 22)
|
||||||
newSize.y = 30;
|
newSize.y = 22;
|
||||||
|
|
||||||
if (!PreCreation( parent, pos, newSize ) ||
|
if (!PreCreation( parent, pos, newSize ) ||
|
||||||
!CreateBase( parent, id, pos, size, style, validator, name ))
|
!CreateBase( parent, id, pos, size, style, validator, name ))
|
||||||
@@ -666,7 +666,7 @@ bool wxComboBox::IsOwnGtkWindow( GdkWindow *window )
|
|||||||
wxSize wxComboBox::DoGetBestSize() const
|
wxSize wxComboBox::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
// totally bogus - should measure the strings in the combo!
|
// totally bogus - should measure the strings in the combo!
|
||||||
return wxSize(100, 26);
|
return wxSize(100, 22);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -74,6 +74,9 @@ wxString wxControl::GetLabel() const
|
|||||||
|
|
||||||
wxSize wxControl::DoGetBestSize() const
|
wxSize wxControl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
|
// Do not return any arbitrary default value...
|
||||||
|
wxASSERT_MSG( m_widget, wxT("DoGetBestSize called before creation") );
|
||||||
|
|
||||||
GtkRequisition req;
|
GtkRequisition req;
|
||||||
(* GTK_WIDGET_CLASS( GTK_OBJECT(m_widget)->klass )->size_request )
|
(* GTK_WIDGET_CLASS( GTK_OBJECT(m_widget)->klass )->size_request )
|
||||||
(m_widget, &req );
|
(m_widget, &req );
|
||||||
|
@@ -75,15 +75,8 @@ bool wxSpinCtrl::Create(wxWindow *parent, wxWindowID id,
|
|||||||
m_needParent = TRUE;
|
m_needParent = TRUE;
|
||||||
m_acceptsFocus = TRUE;
|
m_acceptsFocus = TRUE;
|
||||||
|
|
||||||
wxSize new_size = size,
|
if (!PreCreation( parent, pos, size ) ||
|
||||||
sizeBest = DoGetBestSize();
|
!CreateBase( parent, id, pos, size, style, wxDefaultValidator, name ))
|
||||||
if (new_size.x == -1)
|
|
||||||
new_size.x = sizeBest.x;
|
|
||||||
if (new_size.y == -1)
|
|
||||||
new_size.y = sizeBest.y;
|
|
||||||
|
|
||||||
if (!PreCreation( parent, pos, new_size ) ||
|
|
||||||
!CreateBase( parent, id, pos, new_size, style, wxDefaultValidator, name ))
|
|
||||||
{
|
{
|
||||||
wxFAIL_MSG( wxT("wxSpinCtrl creation failed") );
|
wxFAIL_MSG( wxT("wxSpinCtrl creation failed") );
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@@ -95,6 +88,16 @@ bool wxSpinCtrl::Create(wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
m_widget = gtk_spin_button_new( m_adjust, 1, 0 );
|
m_widget = gtk_spin_button_new( m_adjust, 1, 0 );
|
||||||
|
|
||||||
|
wxSize new_size = size,
|
||||||
|
sizeBest = DoGetBestSize();
|
||||||
|
if (new_size.x == -1)
|
||||||
|
new_size.x = sizeBest.x;
|
||||||
|
if (new_size.y == -1)
|
||||||
|
new_size.y = sizeBest.y;
|
||||||
|
|
||||||
|
if ((new_size.x != size.x) || (new_size.y != size.y))
|
||||||
|
SetSize( new_size.x, new_size.y );
|
||||||
|
|
||||||
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON(m_widget),
|
gtk_spin_button_set_wrap( GTK_SPIN_BUTTON(m_widget),
|
||||||
(int)(m_windowStyle & wxSP_WRAP) );
|
(int)(m_windowStyle & wxSP_WRAP) );
|
||||||
|
|
||||||
@@ -224,7 +227,8 @@ void wxSpinCtrl::ApplyWidgetStyle()
|
|||||||
|
|
||||||
wxSize wxSpinCtrl::DoGetBestSize() const
|
wxSize wxSpinCtrl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
return wxSize(95, 26);
|
wxSize ret( wxControl::DoGetBestSize() );
|
||||||
|
return wxSize(95, ret.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -192,7 +192,15 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
m_text = gtk_entry_new();
|
m_text = gtk_entry_new();
|
||||||
}
|
}
|
||||||
|
|
||||||
SetSizeOrDefault( size );
|
wxSize new_size = size,
|
||||||
|
sizeBest = DoGetBestSize();
|
||||||
|
if (new_size.x == -1)
|
||||||
|
new_size.x = sizeBest.x;
|
||||||
|
if (new_size.y == -1)
|
||||||
|
new_size.y = sizeBest.y;
|
||||||
|
|
||||||
|
if ((new_size.x != size.x) || (new_size.y != size.y))
|
||||||
|
SetSize( new_size.x, new_size.y );
|
||||||
|
|
||||||
m_parent->DoAddChild( this );
|
m_parent->DoAddChild( this );
|
||||||
|
|
||||||
@@ -977,5 +985,6 @@ void wxTextCtrl::OnInternalIdle()
|
|||||||
wxSize wxTextCtrl::DoGetBestSize() const
|
wxSize wxTextCtrl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
// FIXME should be different for multi-line controls...
|
// FIXME should be different for multi-line controls...
|
||||||
return wxSize(80, 26);
|
wxSize ret( wxControl::DoGetBestSize() );
|
||||||
|
return wxSize(80, ret.y);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user