moved SetBestSize() to .cpp file; set min size from it
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@27072 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
2aaa050c33
commit
400a9e419b
@ -1111,9 +1111,6 @@ protected:
|
||||
wxAccessible* m_accessible;
|
||||
#endif
|
||||
|
||||
// Initial window size, used as minimal size in Sizers
|
||||
wxSize m_initialSize;
|
||||
|
||||
// Virtual size (scrolling)
|
||||
wxSize m_virtualSize;
|
||||
|
||||
@ -1141,22 +1138,7 @@ protected:
|
||||
// smarter SetSize / convenience function for expanding wxDefaultSize.
|
||||
// Note that it does not influence the value returned by GetBestSize
|
||||
// at all.
|
||||
void SetBestSize(const wxSize& size)
|
||||
{
|
||||
// the size only needs to be changed if the current size is incomplete,
|
||||
// i.e. one of the components was specified as default -- so if both
|
||||
// were given, simply don't do anything
|
||||
if ( size.x == -1 || size.y == -1 )
|
||||
{
|
||||
wxSize sizeBest = DoGetBestSize();
|
||||
if ( size.x != -1 )
|
||||
sizeBest.x = size.x;
|
||||
if ( size.y != -1 )
|
||||
sizeBest.y = size.y;
|
||||
|
||||
SetSize(sizeBest);
|
||||
}
|
||||
}
|
||||
void SetBestSize(const wxSize& size);
|
||||
|
||||
// more pure virtual functions
|
||||
// ---------------------------
|
||||
|
@ -115,8 +115,6 @@ wxWindowBase::wxWindowBase()
|
||||
m_parent = (wxWindow *)NULL;
|
||||
m_windowId = wxID_ANY;
|
||||
|
||||
m_initialSize = wxDefaultSize;
|
||||
|
||||
// no constraints on the minimal window size
|
||||
m_minWidth =
|
||||
m_minHeight =
|
||||
@ -195,7 +193,7 @@ wxWindowBase::wxWindowBase()
|
||||
bool wxWindowBase::CreateBase(wxWindowBase *parent,
|
||||
wxWindowID id,
|
||||
const wxPoint& WXUNUSED(pos),
|
||||
const wxSize& size,
|
||||
const wxSize& WXUNUSED(size),
|
||||
long style,
|
||||
const wxValidator& wxVALIDATOR_PARAM(validator),
|
||||
const wxString& name)
|
||||
@ -224,10 +222,6 @@ bool wxWindowBase::CreateBase(wxWindowBase *parent,
|
||||
SetWindowStyleFlag(style);
|
||||
SetParent(parent);
|
||||
|
||||
// Save the size passed to the ctor (if any.) This will be used later as
|
||||
// the minimal size if the window is added to a sizer.
|
||||
m_initialSize = size;
|
||||
|
||||
#if wxUSE_VALIDATORS
|
||||
SetValidator(validator);
|
||||
#endif // wxUSE_VALIDATORS
|
||||
@ -600,6 +594,27 @@ wxSize wxWindowBase::DoGetBestSize() const
|
||||
}
|
||||
}
|
||||
|
||||
void wxWindowBase::SetBestSize(const wxSize& size)
|
||||
{
|
||||
// the size only needs to be changed if the current size is incomplete,
|
||||
// i.e. one of the components was specified as default -- so if both
|
||||
// were given, simply don't do anything
|
||||
if ( size.x == -1 || size.y == -1 )
|
||||
{
|
||||
wxSize sizeBest = DoGetBestSize();
|
||||
if ( size.x != -1 )
|
||||
sizeBest.x = size.x;
|
||||
if ( size.y != -1 )
|
||||
sizeBest.y = size.y;
|
||||
|
||||
SetSize(sizeBest);
|
||||
|
||||
// don't shrink the control below its best size
|
||||
m_minWidth = sizeBest.x;
|
||||
m_minHeight = sizeBest.y;
|
||||
}
|
||||
}
|
||||
|
||||
// by default the origin is not shifted
|
||||
wxPoint wxWindowBase::GetClientAreaOrigin() const
|
||||
{
|
||||
@ -1639,13 +1654,6 @@ void wxWindowBase::SetContainingSizer(wxSizer* sizer)
|
||||
_T("Adding a window to the same sizer twice?") );
|
||||
|
||||
m_containingSizer = sizer;
|
||||
|
||||
// If there was an initial size for this window, and if a minsize has not
|
||||
// been set, then set the initial size as the minsize. This helps with
|
||||
// sizer layout when a larger than GetBestSize size is needed for
|
||||
// controls.
|
||||
if (m_initialSize != wxDefaultSize && GetMinSize() == wxDefaultSize)
|
||||
SetSizeHints(m_initialSize);
|
||||
}
|
||||
|
||||
#if wxUSE_CONSTRAINTS
|
||||
|
Loading…
Reference in New Issue
Block a user