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

@ -76,11 +76,11 @@ wxEND_FLAGS( wxChoiceStyle )
IMPLEMENT_DYNAMIC_CLASS_XTI(wxChoice, wxControl,"wx/choice.h")
wxBEGIN_PROPERTIES_TABLE(wxChoice)
wxEVENT_PROPERTY( Select , wxEVT_COMMAND_CHOICE_SELECTED , wxCommandEvent )
wxEVENT_PROPERTY( Select , wxEVT_COMMAND_CHOICE_SELECTED , wxCommandEvent )
wxPROPERTY( Font , wxFont , SetFont , GetFont , EMPTY_MACROVALUE , 0 /*flags*/ , wxT("Helpstring") , wxT("group"))
wxPROPERTY_COLLECTION( Choices , wxArrayString , wxString , AppendString , GetStrings , 0 /*flags*/ , wxT("Helpstring") , wxT("group"))
wxPROPERTY( Selection ,int, SetSelection, GetSelection, EMPTY_MACROVALUE , 0 /*flags*/ , wxT("Helpstring") , wxT("group"))
wxPROPERTY( Selection ,int, SetSelection, GetSelection, EMPTY_MACROVALUE , 0 /*flags*/ , wxT("Helpstring") , wxT("group"))
wxPROPERTY_FLAGS( WindowStyle , wxChoiceStyle , long , SetWindowStyleFlag , GetWindowStyleFlag , EMPTY_MACROVALUE , 0 /*flags*/ , wxT("Helpstring") , wxT("group")) // style
wxEND_PROPERTIES_TABLE()
@ -92,10 +92,10 @@ wxCONSTRUCTOR_4( wxChoice , wxWindow* , Parent , wxWindowID , Id , wxPoint , Pos
IMPLEMENT_DYNAMIC_CLASS(wxChoice, wxControl)
#endif
/*
TODO PROPERTIES
selection (long)
content (list)
item
TODO PROPERTIES
selection (long)
content (list)
item
*/
// ============================================================================
@ -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;
}