add back wxChoice::DoGetBestSize() removed by the previous refactoring, it's still needed (#9150)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@53698 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
154014d681
commit
0662f99096
@ -85,6 +85,7 @@ protected:
|
|||||||
// contains the client data for the items
|
// contains the client data for the items
|
||||||
wxArrayPtrVoid m_clientData;
|
wxArrayPtrVoid m_clientData;
|
||||||
|
|
||||||
|
virtual wxSize DoGetBestSize() const;
|
||||||
virtual int DoInsertItems(const wxArrayStringsAdapter& items,
|
virtual int DoInsertItems(const wxArrayStringsAdapter& items,
|
||||||
unsigned int pos,
|
unsigned int pos,
|
||||||
void **clientData, wxClientDataType type);
|
void **clientData, wxClientDataType type);
|
||||||
|
@ -314,6 +314,37 @@ GdkWindow *wxChoice::GTKGetWindow(wxArrayGdkWindows& WXUNUSED(windows)) const
|
|||||||
return m_widget->window;
|
return m_widget->window;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Notice that this method shouldn't be necessary, because GTK calculates
|
||||||
|
// properly size of the combobox but for unknown reasons it doesn't work
|
||||||
|
// correctly in wx without this.
|
||||||
|
wxSize wxChoice::DoGetBestSize() const
|
||||||
|
{
|
||||||
|
// strangely, this returns a width of 188 pixels from GTK+ (?)
|
||||||
|
wxSize ret( wxControl::DoGetBestSize() );
|
||||||
|
|
||||||
|
// we know better our horizontal extent: it depends on the longest string
|
||||||
|
// in the combobox
|
||||||
|
if ( m_widget )
|
||||||
|
{
|
||||||
|
ret.x = 60; // start with something "sensible"
|
||||||
|
int width;
|
||||||
|
unsigned int count = GetCount();
|
||||||
|
for ( unsigned int n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
GetTextExtent(GetString(n), &width, NULL, NULL, NULL );
|
||||||
|
if ( width + 40 > ret.x ) // 40 for drop down arrow and space around text
|
||||||
|
ret.x = width + 40;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// empty combobox should have some reasonable default size too
|
||||||
|
if ((GetCount() == 0) && (ret.x < 80))
|
||||||
|
ret.x = 80;
|
||||||
|
|
||||||
|
CacheBestSize(ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
wxVisualAttributes
|
wxVisualAttributes
|
||||||
wxChoice::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
wxChoice::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
Loading…
Reference in New Issue
Block a user