X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1621c234d152d16afe6f016ad8a6f49ef780c02b..b5cf8234c683f80d207fc8e96cd364eff122a025:/include/wx/sizer.h diff --git a/include/wx/sizer.h b/include/wx/sizer.h index 7f7481fed3..ade5aea748 100644 --- a/include/wx/sizer.h +++ b/include/wx/sizer.h @@ -26,9 +26,9 @@ // classes //--------------------------------------------------------------------------- -class wxSizerItem; -class wxSizer; -class wxBoxSizer; +class WXDLLEXPORT wxSizerItem; +class WXDLLEXPORT wxSizer; +class WXDLLEXPORT wxBoxSizer; //--------------------------------------------------------------------------- // wxSizerItem @@ -74,8 +74,17 @@ public: wxSize GetMinSize() const { return m_minSize; } + wxSize GetMinSizeWithBorder() const; + + void SetMinSize(const wxSize& size) + { + if (IsWindow()) m_window->SetMinSize(size); + m_minSize = size; + } + void SetMinSize( int x, int y ) + { SetMinSize(wxSize(x, y)); } void SetInitSize( int x, int y ) - { m_minSize.x = x; m_minSize.y = y; } + { SetMinSize(wxSize(x, y)); } void SetRatio( int width, int height ) // if either of dimensions is zero, ratio is assumed to be 1 @@ -189,6 +198,9 @@ public: wxObject* userData = NULL ); virtual void Add( wxSizerItem *item ); + virtual void AddSpacer(int size); + virtual void AddStretchSpacer(int prop = 1); + virtual void Insert( size_t index, wxWindow *window, int proportion = 0, @@ -211,6 +223,9 @@ public: virtual void Insert( size_t index, wxSizerItem *item ); + virtual void InsertSpacer(size_t index, int size); + virtual void InsertStretchSpacer(size_t index, int prop = 1); + virtual void Prepend( wxWindow *window, int proportion = 0, int flag = 0, @@ -229,6 +244,9 @@ public: wxObject* userData = NULL ); virtual void Prepend( wxSizerItem *item ); + virtual void PrependSpacer(int size); + virtual void PrependStretchSpacer(int prop = 1); + // Deprecated in 2.6 since historically it does not delete the window, // use Detach instead. wxDEPRECATED( virtual bool Remove( wxWindow *window ) ); @@ -305,7 +323,7 @@ public: bool IsShown( size_t index ) const; // Recursively call wxWindow::Show () on all sizer items. - void ShowItems (bool show); + virtual void ShowItems (bool show); protected: wxSize m_size; @@ -413,7 +431,10 @@ public: void SetNonFlexibleGrowMode(wxFlexSizerGrowMode mode) { m_growMode = mode; } wxFlexSizerGrowMode GetNonFlexibleGrowMode() const { return m_growMode; } - + // Read-only access to the row heights and col widths arrays + const wxArrayInt& GetRowHeights() const { return m_rowHeights; } + const wxArrayInt& GetColWidths() const { return m_colWidths; } + // implementation virtual void RecalcSizes(); virtual wxSize CalcMin(); @@ -440,6 +461,9 @@ protected: int m_flexDirection; wxFlexSizerGrowMode m_growMode; + // saves CalcMin result to optimize RecalcSizes + wxSize m_calculatedMinSize; + private: DECLARE_CLASS(wxFlexGridSizer) DECLARE_NO_COPY_CLASS(wxFlexGridSizer) @@ -494,6 +518,9 @@ public: wxStaticBox *GetStaticBox() const { return m_staticBox; } + // override to hide/show the static box as well + virtual void ShowItems (bool show); + protected: wxStaticBox *m_staticBox; @@ -504,6 +531,11 @@ private: #endif // wxUSE_STATBOX + +#if WXWIN_COMPATIBILITY_2_4 +// NB: wxBookCtrlSizer and wxNotebookSizer are deprecated, they +// don't do anything. wxBookCtrl::DoGetBestSize does the job now. + // ---------------------------------------------------------------------------- // wxBookCtrlSizer // ---------------------------------------------------------------------------- @@ -517,14 +549,18 @@ class WXDLLEXPORT wxBookCtrl; class WXDLLEXPORT wxBookCtrlSizer : public wxSizer { public: - wxBookCtrlSizer(wxBookCtrl *bookctrl); + wxDEPRECATED( wxBookCtrlSizer(wxBookCtrl *bookctrl) ); + wxBookCtrl *GetControl() const { return m_bookctrl; } + virtual void RecalcSizes(); virtual wxSize CalcMin(); - wxBookCtrl *GetControl() const { return m_bookctrl; } - protected: + // this protected ctor lets us mark the real one above as deprecated + // and still have warning-free build of the library itself: + wxBookCtrlSizer() {} + wxBookCtrl *m_bookctrl; private: @@ -542,7 +578,7 @@ class WXDLLEXPORT wxNotebook; class WXDLLEXPORT wxNotebookSizer : public wxBookCtrlSizer { public: - wxNotebookSizer(wxNotebook *nb); + wxDEPRECATED( wxNotebookSizer(wxNotebook *nb) ); wxNotebook *GetNotebook() const { return (wxNotebook *)m_bookctrl; } @@ -555,5 +591,8 @@ private: #endif // wxUSE_BOOKCTRL +#endif // WXWIN_COMPATIBILITY_2_4 + + #endif // __WXSIZER_H__