X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9f13661f8bce6d5b3dd402d8688de7592957d11e..23a59c2cbe8489445b9c26dee4a77e2d20a999c2:/include/wx/sizer.h diff --git a/include/wx/sizer.h b/include/wx/sizer.h index 374b1559dc..e13f202903 100644 --- a/include/wx/sizer.h +++ b/include/wx/sizer.h @@ -182,6 +182,8 @@ public: float GetRatio() const { return m_ratio; } + virtual wxRect GetRect() { return m_zoneRect; } + bool IsWindow() const; bool IsSizer() const; bool IsSpacer() const; @@ -241,6 +243,7 @@ protected: int m_proportion; int m_border; int m_flag; + wxRect m_zoneRect; // Rectangle for window or item (not including borders) // If true, then this item is considered in the layout // calculation. Otherwise, it is skipped over. @@ -273,81 +276,81 @@ public: // methods for adding elements to the sizer: there are Add/Insert/Prepend // overloads for each of window/sizer/spacer/wxSizerItem - inline void Add( wxWindow *window, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Add( wxSizer *sizer, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Add( int width, - int height, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Add( wxWindow *window, const wxSizerFlags& flags ); - inline void Add( wxSizer *sizer, const wxSizerFlags& flags ); - inline void Add( wxSizerItem *item ); - - inline void AddSpacer(int size); - inline void AddStretchSpacer(int prop = 1); - - inline void Insert( size_t index, - wxWindow *window, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Insert( size_t index, - wxSizer *sizer, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Insert( size_t index, - int width, - int height, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Insert( size_t index, - wxWindow *window, - const wxSizerFlags& flags ); - inline void Insert( size_t index, - wxSizer *sizer, - const wxSizerFlags& flags ); - virtual void Insert( size_t index, wxSizerItem *item ); - - inline void InsertSpacer(size_t index, int size); - inline void InsertStretchSpacer(size_t index, int prop = 1); - - inline void Prepend( wxWindow *window, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Prepend( wxSizer *sizer, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Prepend( int width, - int height, - int proportion = 0, - int flag = 0, - int border = 0, - wxObject* userData = NULL ); - inline void Prepend( wxWindow *window, const wxSizerFlags& flags ); - inline void Prepend( wxSizer *sizer, const wxSizerFlags& flags ); - inline void Prepend( wxSizerItem *item ); - - inline void PrependSpacer(int size); - inline void PrependStretchSpacer(int prop = 1); + inline wxSizerItem* Add( wxWindow *window, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Add( wxSizer *sizer, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Add( int width, + int height, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Add( wxWindow *window, const wxSizerFlags& flags ); + inline wxSizerItem* Add( wxSizer *sizer, const wxSizerFlags& flags ); + inline wxSizerItem* Add( wxSizerItem *item ); + + inline wxSizerItem* AddSpacer(int size); + inline wxSizerItem* AddStretchSpacer(int prop = 1); + + inline wxSizerItem* Insert( size_t index, + wxWindow *window, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Insert( size_t index, + wxSizer *sizer, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Insert( size_t index, + int width, + int height, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Insert( size_t index, + wxWindow *window, + const wxSizerFlags& flags ); + inline wxSizerItem* Insert( size_t index, + wxSizer *sizer, + const wxSizerFlags& flags ); + virtual wxSizerItem* Insert( size_t index, wxSizerItem *item ); + + inline wxSizerItem* InsertSpacer(size_t index, int size); + inline wxSizerItem* InsertStretchSpacer(size_t index, int prop = 1); + + inline wxSizerItem* Prepend( wxWindow *window, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Prepend( wxSizer *sizer, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Prepend( int width, + int height, + int proportion = 0, + int flag = 0, + int border = 0, + wxObject* userData = NULL ); + inline wxSizerItem* Prepend( wxWindow *window, const wxSizerFlags& flags ); + inline wxSizerItem* Prepend( wxSizer *sizer, const wxSizerFlags& flags ); + inline wxSizerItem* Prepend( wxSizerItem *item ); + + inline wxSizerItem* PrependSpacer(int size); + inline wxSizerItem* PrependStretchSpacer(int prop = 1); // Deprecated in 2.6 since historically it does not delete the window, @@ -641,7 +644,7 @@ private: #if WXWIN_COMPATIBILITY_2_4 // NB: wxBookCtrlSizer and wxNotebookSizer are deprecated, they -// don't do anything. wxBookCtrl::DoGetBestSize does the job now. +// don't do anything. wxBookCtrlBase::DoGetBestSize does the job now. // ---------------------------------------------------------------------------- // wxBookCtrlSizer @@ -651,14 +654,14 @@ private: // this sizer works with wxNotebook/wxListbook/... and sizes the control to // fit its pages -class WXDLLEXPORT wxBookCtrl; +class WXDLLEXPORT wxBookCtrlBase; class WXDLLEXPORT wxBookCtrlSizer : public wxSizer { public: - wxDEPRECATED( wxBookCtrlSizer(wxBookCtrl *bookctrl) ); + wxDEPRECATED( wxBookCtrlSizer(wxBookCtrlBase *bookctrl) ); - wxBookCtrl *GetControl() const { return m_bookctrl; } + wxBookCtrlBase *GetControl() const { return m_bookctrl; } virtual void RecalcSizes(); virtual wxSize CalcMin(); @@ -668,7 +671,7 @@ protected: // and still have warning-free build of the library itself: wxBookCtrlSizer() {} - wxBookCtrl *m_bookctrl; + wxBookCtrlBase *m_bookctrl; private: DECLARE_CLASS(wxBookCtrlSizer) @@ -678,7 +681,7 @@ private: #if wxUSE_NOTEBOOK -// before wxBookCtrl we only had wxNotebookSizer, keep it for backwards +// before wxBookCtrlBase we only had wxNotebookSizer, keep it for backwards // compatibility class WXDLLEXPORT wxNotebook; @@ -704,103 +707,103 @@ private: // inline functions implementation // ---------------------------------------------------------------------------- -inline void +inline wxSizerItem* wxSizer::Add( wxWindow *window, int proportion, int flag, int border, wxObject* userData ) { - Add( new wxSizerItem( window, proportion, flag, border, userData ) ); + return Add( new wxSizerItem( window, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Add( wxSizer *sizer, int proportion, int flag, int border, wxObject* userData ) { - Add( new wxSizerItem( sizer, proportion, flag, border, userData ) ); + return Add( new wxSizerItem( sizer, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Add( int width, int height, int proportion, int flag, int border, wxObject* userData ) { - Add( new wxSizerItem( width, height, proportion, flag, border, userData ) ); + return Add( new wxSizerItem( width, height, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Add( wxWindow *window, const wxSizerFlags& flags ) { - Add( new wxSizerItem(window, flags) ); + return Add( new wxSizerItem(window, flags) ); } -inline void +inline wxSizerItem* wxSizer::Add( wxSizer *sizer, const wxSizerFlags& flags ) { - Add( new wxSizerItem(sizer, flags) ); + return Add( new wxSizerItem(sizer, flags) ); } -inline void +inline wxSizerItem* wxSizer::Add( wxSizerItem *item ) { - Insert( m_children.GetCount(), item ); + return Insert( m_children.GetCount(), item ); } -inline void +inline wxSizerItem* wxSizer::AddSpacer(int size) { - Add(size, size); + return Add(size, size); } -inline void +inline wxSizerItem* wxSizer::AddStretchSpacer(int prop) { - Add(0, 0, prop); + return Add(0, 0, prop); } -inline void +inline wxSizerItem* wxSizer::Prepend( wxWindow *window, int proportion, int flag, int border, wxObject* userData ) { - Prepend( new wxSizerItem( window, proportion, flag, border, userData ) ); + return Prepend( new wxSizerItem( window, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Prepend( wxSizer *sizer, int proportion, int flag, int border, wxObject* userData ) { - Prepend( new wxSizerItem( sizer, proportion, flag, border, userData ) ); + return Prepend( new wxSizerItem( sizer, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Prepend( int width, int height, int proportion, int flag, int border, wxObject* userData ) { - Prepend( new wxSizerItem( width, height, proportion, flag, border, userData ) ); + return Prepend( new wxSizerItem( width, height, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Prepend( wxSizerItem *item ) { - Insert( 0, item ); + return Insert( 0, item ); } -inline void +inline wxSizerItem* wxSizer::PrependSpacer(int size) { - Prepend(size, size); + return Prepend(size, size); } -inline void +inline wxSizerItem* wxSizer::PrependStretchSpacer(int prop) { - Prepend(0, 0, prop); + return Prepend(0, 0, prop); } -inline void +inline wxSizerItem* wxSizer::Prepend( wxWindow *window, const wxSizerFlags& flags ) { - Prepend( new wxSizerItem(window, flags) ); + return Prepend( new wxSizerItem(window, flags) ); } -inline void +inline wxSizerItem* wxSizer::Prepend( wxSizer *sizer, const wxSizerFlags& flags ) { - Prepend( new wxSizerItem(sizer, flags) ); + return Prepend( new wxSizerItem(sizer, flags) ); } -inline void +inline wxSizerItem* wxSizer::Insert( size_t index, wxWindow *window, int proportion, @@ -808,10 +811,10 @@ wxSizer::Insert( size_t index, int border, wxObject* userData ) { - Insert( index, new wxSizerItem( window, proportion, flag, border, userData ) ); + return Insert( index, new wxSizerItem( window, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Insert( size_t index, wxSizer *sizer, int proportion, @@ -819,10 +822,10 @@ wxSizer::Insert( size_t index, int border, wxObject* userData ) { - Insert( index, new wxSizerItem( sizer, proportion, flag, border, userData ) ); + return Insert( index, new wxSizerItem( sizer, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Insert( size_t index, int width, int height, @@ -831,31 +834,31 @@ wxSizer::Insert( size_t index, int border, wxObject* userData ) { - Insert( index, new wxSizerItem( width, height, proportion, flag, border, userData ) ); + return Insert( index, new wxSizerItem( width, height, proportion, flag, border, userData ) ); } -inline void +inline wxSizerItem* wxSizer::Insert( size_t index, wxWindow *window, const wxSizerFlags& flags ) { - Insert( index, new wxSizerItem(window, flags) ); + return Insert( index, new wxSizerItem(window, flags) ); } -inline void +inline wxSizerItem* wxSizer::Insert( size_t index, wxSizer *sizer, const wxSizerFlags& flags ) { - Insert( index, new wxSizerItem(sizer, flags) ); + return Insert( index, new wxSizerItem(sizer, flags) ); } -inline void +inline wxSizerItem* wxSizer::InsertSpacer(size_t index, int size) { - Insert(index, size, size); + return Insert(index, size, size); } -inline void +inline wxSizerItem* wxSizer::InsertStretchSpacer(size_t index, int prop) { - Insert(index, 0, 0, prop); + return Insert(index, 0, 0, prop); }