removed the old hack needed to size the control properly initially, now it is done by simply calling SetBestSize()
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@27076 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
17c48da8ee
commit
3dfb79a67d
@ -130,36 +130,12 @@ bool wxChoice::Create(wxWindow *parent,
|
||||
bool wxChoice::CreateAndInit(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxPoint& pos,
|
||||
const wxSize& sizeOrig,
|
||||
const wxSize& size,
|
||||
int n, const wxString choices[],
|
||||
long style,
|
||||
const wxValidator& validator,
|
||||
const wxString& name)
|
||||
{
|
||||
// this is a bit hackish but we want to prevent MSWCreateControl() from
|
||||
// calling SetBestSize() (which it would do if any of the size components
|
||||
// is not given) because it wouldn't calculate it correctly if we have any
|
||||
// strings as they're not yet added to the control when it is called
|
||||
//
|
||||
// so: if we have any strings, we fudge the size parameter so that
|
||||
// SetBestSize() is not called by MSWCreateControl() but then we do call it
|
||||
// manually below
|
||||
bool autoSize = false;
|
||||
wxSize size = sizeOrig;
|
||||
if ( n )
|
||||
{
|
||||
if ( size.x < 0 )
|
||||
{
|
||||
size.x = 1;
|
||||
autoSize = true;
|
||||
}
|
||||
if ( size.y < 0 )
|
||||
{
|
||||
size.y = 1;
|
||||
autoSize = true;
|
||||
}
|
||||
}
|
||||
|
||||
// initialize wxControl
|
||||
if ( !CreateControl(parent, id, pos, size, style, validator, name) )
|
||||
return FALSE;
|
||||
@ -180,22 +156,7 @@ bool wxChoice::CreateAndInit(wxWindow *parent,
|
||||
}
|
||||
|
||||
// and now we may finally size the control properly (if needed)
|
||||
if ( autoSize )
|
||||
{
|
||||
// we do the same thing as SetBestSize() but we need sizeBest here
|
||||
wxSize sizeBest = DoGetBestSize();
|
||||
if ( size.x != -1 )
|
||||
sizeBest.x = sizeOrig.x;
|
||||
if ( size.y != -1 )
|
||||
sizeBest.y = sizeOrig.y;
|
||||
|
||||
SetSize(sizeBest);
|
||||
|
||||
// this is our true initial size, not the (1, 1) we had during
|
||||
// CreateControl() call above: this is especially important if we're
|
||||
// added to a sizer as we don't want to be shrunk to nothing by it
|
||||
m_initialSize = sizeBest;
|
||||
}
|
||||
SetBestSize(size);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user