IMPLEMENT_ABSTRACT_CLASS(wxPickerBase, wxControl)
-BEGIN_EVENT_TABLE(wxPickerBase, wxControl)
- EVT_SIZE(wxPickerBase::OnSize)
- WX_EVENT_TABLE_CONTROL_CONTAINER(wxPickerBase)
-END_EVENT_TABLE()
-WX_DELEGATE_TO_CONTROL_CONTAINER(wxPickerBase, wxControl)
-
-
// ----------------------------------------------------------------------------
// wxPickerBase
// ----------------------------------------------------------------------------
return false;
}
- // set the maximum lenght allowed for this textctrl.
+ // set the maximum length allowed for this textctrl.
// This is very important since any change to it will trigger an update in
// the m_picker; for very long strings, this real-time synchronization could
// become a CPU-blocker and thus should be avoided.
// set the initial contents of the textctrl
m_text->SetValue(text);
- m_text->Connect(m_text->GetId(), wxEVT_COMMAND_TEXT_UPDATED,
+ m_text->Connect(m_text->GetId(), wxEVT_TEXT,
wxCommandEventHandler(wxPickerBase::OnTextCtrlUpdate),
NULL, this);
m_text->Connect(m_text->GetId(), wxEVT_KILL_FOCUS,
m_sizer->Add(m_picker, HasTextCtrl() ? 0 : 1, GetDefaultPickerCtrlFlag(), 5);
// For aesthetic reasons, make sure the picker is at least as high as the
- // associated text control and is always at least square.
- const wxSize pickerBestSize(m_picker->GetBestSize());
- const wxSize textBestSize( HasTextCtrl() ? m_text->GetBestSize() : wxSize());
- wxSize pickerMinSize;
- pickerMinSize.y = wxMax(pickerBestSize.y, textBestSize.y);
- pickerMinSize.x = wxMax(pickerBestSize.x, pickerMinSize.y);
- if ( pickerMinSize != pickerBestSize )
- m_picker->SetMinSize(pickerMinSize);
+ // associated text control and is always at least square, unless we are
+ // explicitly using wxPB_SMALL style to force it to take as little space as
+ // possible.
+ if ( !HasFlag(wxPB_SMALL) )
+ {
+ const wxSize pickerBestSize(m_picker->GetBestSize());
+ const wxSize textBestSize( HasTextCtrl() ? m_text->GetBestSize() : wxSize());
+ wxSize pickerMinSize;
+ pickerMinSize.y = wxMax(pickerBestSize.y, textBestSize.y);
+ pickerMinSize.x = wxMax(pickerBestSize.x, pickerMinSize.y);
+ if ( pickerMinSize != pickerBestSize )
+ m_picker->SetMinSize(pickerMinSize);
+ }
SetSizer(m_sizer);
UpdatePickerFromTextCtrl();
}
-void wxPickerBase::OnSize(wxSizeEvent &event)
-{
- if (GetAutoLayout())
- Layout();
- event.Skip();
-}
-
#endif // Any picker in use