1 /////////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxBookCtrlBase: common base class for wxList/Tree/Notebook 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org> 
   9 // Licence:     wxWindows licence 
  10 /////////////////////////////////////////////////////////////////////////////// 
  12 #ifndef _WX_BOOKCTRL_H_ 
  13 #define _WX_BOOKCTRL_H_ 
  15 // ---------------------------------------------------------------------------- 
  17 // ---------------------------------------------------------------------------- 
  23 #include "wx/control.h" 
  24 #include "wx/dynarray.h" 
  26 WX_DEFINE_EXPORTED_ARRAY_PTR(wxWindow 
*, wxArrayPages
); 
  28 class WXDLLIMPEXP_FWD_CORE wxImageList
; 
  29 class WXDLLIMPEXP_FWD_CORE wxBookCtrlBaseEvent
; 
  31 // ---------------------------------------------------------------------------- 
  33 // ---------------------------------------------------------------------------- 
  35 // wxBookCtrl hit results 
  38     wxBK_HITTEST_NOWHERE 
= 1,   // not on tab 
  39     wxBK_HITTEST_ONICON  
= 2,   // on icon 
  40     wxBK_HITTEST_ONLABEL 
= 4,   // on label 
  41     wxBK_HITTEST_ONITEM  
= wxBK_HITTEST_ONICON 
| wxBK_HITTEST_ONLABEL
, 
  42     wxBK_HITTEST_ONPAGE  
= 8    // not on tab control, but over the selected page 
  45 // wxBookCtrl flags (common for wxNotebook, wxListbook, wxChoicebook, wxTreebook) 
  46 #define wxBK_DEFAULT          0x0000 
  47 #define wxBK_TOP              0x0010 
  48 #define wxBK_BOTTOM           0x0020 
  49 #define wxBK_LEFT             0x0040 
  50 #define wxBK_RIGHT            0x0080 
  51 #define wxBK_ALIGN_MASK       (wxBK_TOP | wxBK_BOTTOM | wxBK_LEFT | wxBK_RIGHT) 
  53 // ---------------------------------------------------------------------------- 
  55 // ---------------------------------------------------------------------------- 
  57 class WXDLLIMPEXP_CORE wxBookCtrlBase 
: public wxControl
 
  68     wxBookCtrlBase(wxWindow 
*parent
, 
  70                    const wxPoint
& pos 
= wxDefaultPosition
, 
  71                    const wxSize
& size 
= wxDefaultSize
, 
  73                    const wxString
& name 
= wxEmptyString
) 
  77         (void)Create(parent
, winid
, pos
, size
, style
, name
); 
  81     bool Create(wxWindow 
*parent
, 
  83                 const wxPoint
& pos 
= wxDefaultPosition
, 
  84                 const wxSize
& size 
= wxDefaultSize
, 
  86                 const wxString
& name 
= wxEmptyString
); 
  89     virtual ~wxBookCtrlBase(); 
  95     // get number of pages in the dialog 
  96     virtual size_t GetPageCount() const { return m_pages
.size(); } 
  98     // get the panel which represents the given page 
  99     wxWindow 
*GetPage(size_t n
) const { return m_pages
[n
]; } 
 101     // get the current page or NULL if none 
 102     wxWindow 
*GetCurrentPage() const 
 104         const int n 
= GetSelection(); 
 105         return n 
== wxNOT_FOUND 
? NULL 
: GetPage(n
); 
 108     // get the currently selected page or wxNOT_FOUND if none 
 109     virtual int GetSelection() const = 0; 
 111     // set/get the title of a page 
 112     virtual bool SetPageText(size_t n
, const wxString
& strText
) = 0; 
 113     virtual wxString 
GetPageText(size_t n
) const = 0; 
 116     // image list stuff: each page may have an image associated with it (all 
 117     // images belong to the same image list) 
 118     // --------------------------------------------------------------------- 
 120     // sets the image list to use, it is *not* deleted by the control 
 121     virtual void SetImageList(wxImageList 
*imageList
); 
 123     // as SetImageList() but we will delete the image list ourselves 
 124     void AssignImageList(wxImageList 
*imageList
); 
 126     // get pointer (may be NULL) to the associated image list 
 127     wxImageList
* GetImageList() const { return m_imageList
; } 
 129     // sets/returns item's image index in the current image list 
 130     virtual int GetPageImage(size_t n
) const = 0; 
 131     virtual bool SetPageImage(size_t n
, int imageId
) = 0; 
 137     // resize the notebook so that all pages will have the specified size 
 138     virtual void SetPageSize(const wxSize
& size
); 
 140     // calculate the size of the control from the size of its page 
 141     virtual wxSize 
CalcSizeFromPage(const wxSize
& sizePage
) const = 0; 
 143     // get/set size of area between book control area and page area 
 144     unsigned int GetInternalBorder() const { return m_internalBorder
; } 
 145     void SetInternalBorder(unsigned int border
) { m_internalBorder 
= border
; } 
 147     // Sets/gets the margin around the controller 
 148     void SetControlMargin(int margin
) { m_controlMargin 
= margin
; } 
 149     int GetControlMargin() const { return m_controlMargin
; } 
 151     // returns true if we have wxBK_TOP or wxBK_BOTTOM style 
 152     bool IsVertical() const { return HasFlag(wxBK_BOTTOM 
| wxBK_TOP
); } 
 154     // set/get option to shrink to fit current page 
 155     void SetFitToCurrentPage(bool fit
) { m_fitToCurrentPage 
= fit
; } 
 156     bool GetFitToCurrentPage() const { return m_fitToCurrentPage
; } 
 158     // returns the sizer containing the control, if any 
 159     wxSizer
* GetControlSizer() const { return m_controlSizer
; } 
 165     // remove one page from the control and delete it 
 166     virtual bool DeletePage(size_t n
); 
 168     // remove one page from the notebook, without deleting it 
 169     virtual bool RemovePage(size_t n
) 
 171         DoInvalidateBestSize(); 
 172         return DoRemovePage(n
) != NULL
; 
 175     // remove all pages and delete them 
 176     virtual bool DeleteAllPages() 
 178         DoInvalidateBestSize(); 
 179         WX_CLEAR_ARRAY(m_pages
); 
 183     // adds a new page to the control 
 184     virtual bool AddPage(wxWindow 
*page
, 
 185                          const wxString
& text
, 
 186                          bool bSelect 
= false, 
 189         DoInvalidateBestSize(); 
 190         return InsertPage(GetPageCount(), page
, text
, bSelect
, imageId
); 
 193     // the same as AddPage(), but adds the page at the specified position 
 194     virtual bool InsertPage(size_t n
, 
 196                             const wxString
& text
, 
 197                             bool bSelect 
= false, 
 198                             int imageId 
= -1) = 0; 
 200     // set the currently selected page, return the index of the previously 
 201     // selected one (or -1 on error) 
 203     // NB: this function will generate PAGE_CHANGING/ED events 
 204     virtual int SetSelection(size_t n
) = 0; 
 206     // acts as SetSelection but does not generate events 
 207     virtual int ChangeSelection(size_t n
) = 0; 
 210     // cycle thru the pages 
 211     void AdvanceSelection(bool forward 
= true) 
 213         int nPage 
= GetNextPage(forward
); 
 216             // cast is safe because of the check above 
 217             SetSelection((size_t)nPage
); 
 221     // hit test: returns which page is hit and, optionally, where (icon, label) 
 222     virtual int HitTest(const wxPoint
& WXUNUSED(pt
), 
 223                         long * WXUNUSED(flags
) = NULL
) const 
 229     // we do have multiple pages 
 230     virtual bool HasMultiplePages() const { return true; } 
 232     // we don't want focus for ourselves 
 233     virtual bool AcceptsFocus() const { return false; } 
 235     // returns true if the platform should explicitly apply a theme border 
 236     virtual bool CanApplyThemeBorder() const { return false; } 
 239     // flags for DoSetSelection() 
 242         SetSelection_SendEvent 
= 1 
 245     // choose the default border for this window 
 246     virtual wxBorder 
GetDefaultBorder() const { return wxBORDER_NONE
; } 
 248     // set the selection to the given page, sending the events (which can 
 249     // possibly prevent the page change from taking place) if SendEvent flag is 
 251     virtual int DoSetSelection(size_t nPage
, int flags 
= 0); 
 253     // if the derived class uses DoSetSelection() for implementing 
 254     // [Set|Change]Selection, it must override UpdateSelectedPage(), 
 255     // CreatePageChangingEvent() and MakeChangedEvent(), but as it might not 
 256     // use it, these functions are not pure virtual 
 258     // called to notify the control about a new current page 
 259     virtual void UpdateSelectedPage(size_t WXUNUSED(newsel
)) 
 260         { wxFAIL_MSG(wxT("Override this function!")); } 
 262     // create a new "page changing" event 
 263     virtual wxBookCtrlBaseEvent
* CreatePageChangingEvent() const 
 264         { wxFAIL_MSG(wxT("Override this function!")); return NULL
; } 
 266     // modify the event created by CreatePageChangingEvent() to "page changed" 
 267     // event, usually by just calling SetEventType() on it 
 268     virtual void MakeChangedEvent(wxBookCtrlBaseEvent
& WXUNUSED(event
)) 
 269         { wxFAIL_MSG(wxT("Override this function!")); } 
 272     // Should we accept NULL page pointers in Add/InsertPage()? 
 274     // Default is no but derived classes may override it if they can treat NULL 
 275     // pages in some sensible way (e.g. wxTreebook overrides this to allow 
 276     // having nodes without any associated page) 
 277     virtual bool AllowNullPage() const { return false; } 
 279     // remove the page and return a pointer to it 
 280     virtual wxWindow 
*DoRemovePage(size_t page
) = 0; 
 282     // our best size is the size which fits all our pages 
 283     virtual wxSize 
DoGetBestSize() const; 
 285     // helper: get the next page wrapping if we reached the end 
 286     int GetNextPage(bool forward
) const; 
 291     // This method also invalidates the size of the controller and should be 
 292     // called instead of just InvalidateBestSize() whenever pages are added or 
 293     // removed as this also affects the controller 
 294     void DoInvalidateBestSize(); 
 297     // Show the help for the corresponding page 
 298     void OnHelp(wxHelpEvent
& event
); 
 302     // the array of all pages of this control 
 303     wxArrayPages m_pages
; 
 305     // the associated image list or NULL 
 306     wxImageList 
*m_imageList
; 
 308     // true if we must delete m_imageList 
 309     bool m_ownsImageList
; 
 312     wxRect 
GetPageRect() const; 
 315     virtual wxSize 
GetControllerSize() const; 
 316     void OnSize(wxSizeEvent
& event
); 
 318     // controller buddy if available, NULL otherwise (usually for native book controls like wxNotebook) 
 319     wxControl 
*m_bookctrl
; 
 321     // Whether to shrink to fit current page 
 322     bool m_fitToCurrentPage
; 
 324     // the sizer containing the choice control 
 325     wxSizer 
*m_controlSizer
; 
 327     // the margin around the choice control 
 332     // common part of all ctors 
 336     unsigned int m_internalBorder
; 
 338     DECLARE_ABSTRACT_CLASS(wxBookCtrlBase
) 
 339     DECLARE_NO_COPY_CLASS(wxBookCtrlBase
) 
 340     DECLARE_EVENT_TABLE() 
 343 // ---------------------------------------------------------------------------- 
 344 // wxBookCtrlBaseEvent: page changing events generated by derived classes 
 345 // ---------------------------------------------------------------------------- 
 347 class WXDLLIMPEXP_CORE wxBookCtrlBaseEvent 
: public wxNotifyEvent
 
 350     wxBookCtrlBaseEvent(wxEventType commandType 
= wxEVT_NULL
, int winid 
= 0, 
 351                         int nSel 
= -1, int nOldSel 
= -1) 
 352         : wxNotifyEvent(commandType
, winid
) 
 358     wxBookCtrlBaseEvent(const wxBookCtrlBaseEvent
& event
) 
 359         : wxNotifyEvent(event
) 
 361         m_nSel 
= event
.m_nSel
; 
 362         m_nOldSel 
= event
.m_nOldSel
; 
 366         // the currently selected page (-1 if none) 
 367     int GetSelection() const { return m_nSel
; } 
 368     void SetSelection(int nSel
) { m_nSel 
= nSel
; } 
 369         // the page that was selected before the change (-1 if none) 
 370     int GetOldSelection() const { return m_nOldSel
; } 
 371     void SetOldSelection(int nOldSel
) { m_nOldSel 
= nOldSel
; } 
 374     int m_nSel
,     // currently selected page 
 375         m_nOldSel
;  // previously selected page 
 378 // make a default book control for given platform 
 380     // dedicated to majority of desktops 
 381     #include "wx/notebook.h" 
 382     #define wxBookCtrl                             wxNotebook 
 383     #define wxBookCtrlEvent                        wxNotebookEvent 
 384     #define wxEVT_COMMAND_BOOKCTRL_PAGE_CHANGED    wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED 
 385     #define wxEVT_COMMAND_BOOKCTRL_PAGE_CHANGING   wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING 
 386     #define EVT_BOOKCTRL_PAGE_CHANGED(id, fn)      EVT_NOTEBOOK_PAGE_CHANGED(id, fn) 
 387     #define EVT_BOOKCTRL_PAGE_CHANGING(id, fn)     EVT_NOTEBOOK_PAGE_CHANGING(id, fn) 
 388     #define wxBookctrlEventHandler(func)           wxNotebookEventHandler(func) 
 390     // dedicated to Smartphones 
 391     #include "wx/choicebk.h" 
 392     #define wxBookCtrl                             wxChoicebook 
 393     #define wxBookCtrlEvent                        wxChoicebookEvent 
 394     #define wxEVT_COMMAND_BOOKCTRL_PAGE_CHANGED    wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED 
 395     #define wxEVT_COMMAND_BOOKCTRL_PAGE_CHANGING   wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING 
 396     #define EVT_BOOKCTRL_PAGE_CHANGED(id, fn)      EVT_CHOICEBOOK_PAGE_CHANGED(id, fn) 
 397     #define EVT_BOOKCTRL_PAGE_CHANGING(id, fn)     EVT_CHOICEBOOK_PAGE_CHANGING(id, fn) 
 398     #define wxBookctrlEventHandler(func)           wxChoicebookEventHandler(func) 
 401 #if WXWIN_COMPATIBILITY_2_6 
 402     #define wxBC_TOP                               wxBK_TOP 
 403     #define wxBC_BOTTOM                            wxBK_BOTTOM 
 404     #define wxBC_LEFT                              wxBK_LEFT 
 405     #define wxBC_RIGHT                             wxBK_RIGHT 
 406     #define wxBC_DEFAULT                           wxBK_DEFAULT 
 409 #endif // wxUSE_BOOKCTRL 
 411 #endif // _WX_BOOKCTRL_H_