X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/655719367ac5e131d9642e5783f3ecf64d1a3385..33ebfc3b9b542e2cefcab456e47a101311b74697:/include/wx/sizer.h diff --git a/include/wx/sizer.h b/include/wx/sizer.h index ce907346bb..5c0db82aee 100644 --- a/include/wx/sizer.h +++ b/include/wx/sizer.h @@ -21,14 +21,15 @@ #include "wx/window.h" #include "wx/frame.h" #include "wx/dialog.h" +#include "wx/bookctrl.h" //--------------------------------------------------------------------------- // classes //--------------------------------------------------------------------------- -class wxSizerItem; -class wxSizer; -class wxBoxSizer; +class WXDLLEXPORT wxSizerItem; +class WXDLLEXPORT wxSizer; +class WXDLLEXPORT wxBoxSizer; //--------------------------------------------------------------------------- // wxSizerItem @@ -74,14 +75,15 @@ public: wxSize GetMinSize() const { return m_minSize; } + wxSize GetMinSizeWithBorder() const; + void SetMinSize(const wxSize& size) { - if (IsWindow() && !(m_flag & wxFIXED_MINSIZE)) - m_window->SetSizeHints(size); - m_minSize = size; + if (IsWindow()) m_window->SetMinSize(size); + m_minSize = size; } void SetMinSize( int x, int y ) - { SetMinSize(wxSize(x, y)); } + { SetMinSize(wxSize(x, y)); } void SetInitSize( int x, int y ) { SetMinSize(wxSize(x, y)); } @@ -197,6 +199,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, @@ -219,6 +224,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, @@ -237,6 +245,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 ) ); @@ -297,16 +308,16 @@ public: // Manage whether individual scene items are considered // in the layout calculations or not. - void Show( wxWindow *window, bool show = true ); - void Show( wxSizer *sizer, bool show = true ); - void Show( size_t index, bool show = true ); + bool Show( wxWindow *window, bool show = true, bool recursive = false ); + bool Show( wxSizer *sizer, bool show = true, bool recursive = false ); + bool Show( size_t index, bool show = true ); - void Hide( wxSizer *sizer ) - { Show( sizer, false ); } - void Hide( wxWindow *window ) - { Show( window, false ); } - void Hide( size_t index ) - { Show( index, false ); } + bool Hide( wxSizer *sizer, bool recursive = false ) + { return Show( sizer, false, recursive ); } + bool Hide( wxWindow *window, bool recursive = false ) + { return Show( window, false, recursive ); } + bool Hide( size_t index ) + { return Show( index, false ); } bool IsShown( wxWindow *window ) const; bool IsShown( wxSizer *sizer ) const; @@ -424,7 +435,7 @@ public: // 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(); @@ -433,7 +444,7 @@ protected: void AdjustForFlexDirection(); void AdjustForGrowables(const wxSize& sz, const wxSize& minsz, int nrows, int ncols); - + // the heights/widths of all rows/columns wxArrayInt m_rowHeights, m_colWidths; @@ -451,6 +462,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) @@ -518,27 +532,36 @@ 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 // ---------------------------------------------------------------------------- #if wxUSE_BOOKCTRL -// this sizer works with wxNotebook/wxListbook/... and sizes the control to +// this sizer works with wxNotebook/wxListbook/wxChoicebook... and sizes the control to // fit its pages 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: @@ -556,7 +579,7 @@ class WXDLLEXPORT wxNotebook; class WXDLLEXPORT wxNotebookSizer : public wxBookCtrlSizer { public: - wxNotebookSizer(wxNotebook *nb); + wxDEPRECATED( wxNotebookSizer(wxNotebook *nb) ); wxNotebook *GetNotebook() const { return (wxNotebook *)m_bookctrl; } @@ -569,5 +592,8 @@ private: #endif // wxUSE_BOOKCTRL +#endif // WXWIN_COMPATIBILITY_2_4 + + #endif // __WXSIZER_H__