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:
Vadim Zeitlin 2004-05-03 12:48:08 +00:00
parent 17c48da8ee
commit 3dfb79a67d

View File

@ -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;
}