Applied patch [ 670782 ] Combobox uses popup window width
(wxUniv) git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@19070 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -83,6 +83,8 @@ public:
|
||||
// called immediately after the control is shown
|
||||
virtual void OnShow() = 0;
|
||||
|
||||
virtual wxCoord GetBestWidth() const {return 0; }
|
||||
|
||||
protected:
|
||||
wxComboControl *m_combo;
|
||||
};
|
||||
|
@@ -125,6 +125,7 @@ public:
|
||||
virtual bool SetSelection(const wxString& value);
|
||||
virtual wxControl *GetControl() { return this; }
|
||||
virtual void OnShow();
|
||||
virtual wxCoord wxComboListBox::GetBestWidth() const;
|
||||
|
||||
protected:
|
||||
// we shouldn't return height too big from here
|
||||
@@ -300,8 +301,15 @@ wxSize wxComboControl::DoGetBestClientSize() const
|
||||
{
|
||||
wxSize sizeBtn = m_btn->GetBestSize(),
|
||||
sizeText = m_text->GetBestSize();
|
||||
wxCoord widthPopup = 0;
|
||||
|
||||
return wxSize(sizeText.x + g_comboMargin + sizeBtn.x, wxMax(sizeBtn.y, sizeText.y));
|
||||
if (m_popup)
|
||||
{
|
||||
widthPopup = m_popup->GetBestWidth();
|
||||
}
|
||||
|
||||
return wxSize(wxMax(sizeText.x + g_comboMargin + sizeBtn.x, widthPopup),
|
||||
wxMax(sizeBtn.y, sizeText.y));
|
||||
}
|
||||
|
||||
void wxComboControl::DoMoveWindow(int x, int y, int width, int height)
|
||||
@@ -615,6 +623,12 @@ void wxComboListBox::OnMouseMove(wxMouseEvent& event)
|
||||
}
|
||||
}
|
||||
|
||||
wxCoord wxComboListBox::GetBestWidth() const
|
||||
{
|
||||
wxSize size = wxListBox::GetBestSize();
|
||||
return size.x;
|
||||
}
|
||||
|
||||
wxSize wxComboListBox::DoGetBestClientSize() const
|
||||
{
|
||||
// don't return size too big or we risk to not fit on the screen
|
||||
|
Reference in New Issue
Block a user