1 ///////////////////////////////////////////////////////////////////////////////
2 // Name: wx/univ/notebook.h
3 // Purpose: universal version of wxNotebook
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 2001 SciTech Software, Inc. (www.scitechsoft.com)
9 // Licence: wxWindows licence
10 ///////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_UNIV_NOTEBOOK_H_
13 #define _WX_UNIV_NOTEBOOK_H_
15 #include "wx/arrstr.h"
17 class WXDLLIMPEXP_FWD_CORE wxSpinButton
;
19 // ----------------------------------------------------------------------------
20 // the actions supported by this control
21 // ----------------------------------------------------------------------------
23 // change the page: to the next/previous/given one
24 #define wxACTION_NOTEBOOK_NEXT wxT("nexttab")
25 #define wxACTION_NOTEBOOK_PREV wxT("prevtab")
26 #define wxACTION_NOTEBOOK_GOTO wxT("gototab")
28 // ----------------------------------------------------------------------------
30 // ----------------------------------------------------------------------------
32 class WXDLLIMPEXP_CORE wxNotebook
: public wxNotebookBase
38 wxNotebook() { Init(); }
40 wxNotebook(wxWindow
*parent
,
42 const wxPoint
& pos
= wxDefaultPosition
,
43 const wxSize
& size
= wxDefaultSize
,
45 const wxString
& name
= wxNotebookNameStr
)
49 (void)Create(parent
, id
, pos
, size
, style
, name
);
53 bool Create(wxWindow
*parent
,
55 const wxPoint
& pos
= wxDefaultPosition
,
56 const wxSize
& size
= wxDefaultSize
,
58 const wxString
& name
= wxNotebookNameStr
);
61 virtual ~wxNotebook();
63 // implement wxNotebookBase pure virtuals
64 // --------------------------------------
66 virtual int SetSelection(size_t nPage
) { return DoSetSelection(nPage
, SetSelection_SendEvent
); }
67 virtual int GetSelection() const { return (int) m_sel
; }
69 // changes selected page without sending events
70 int ChangeSelection(size_t nPage
) { return DoSetSelection(nPage
); }
72 virtual bool SetPageText(size_t nPage
, const wxString
& strText
);
73 virtual wxString
GetPageText(size_t nPage
) const;
75 virtual int GetPageImage(size_t nPage
) const;
76 virtual bool SetPageImage(size_t nPage
, int nImage
);
78 virtual void SetPageSize(const wxSize
& size
);
79 virtual void SetPadding(const wxSize
& padding
);
80 virtual void SetTabSize(const wxSize
& sz
);
82 virtual wxSize
CalcSizeFromPage(const wxSize
& sizePage
) const;
84 virtual bool DeleteAllPages();
86 virtual bool InsertPage(size_t nPage
,
87 wxNotebookPage
*pPage
,
88 const wxString
& strText
,
95 // return true if all tabs have the same width
96 bool FixedSizeTabs() const { return HasFlag(wxNB_FIXEDWIDTH
); }
98 // return wxTOP/wxBOTTOM/wxRIGHT/wxLEFT
99 wxDirection
GetTabOrientation() const;
101 // return true if the notebook has tabs at the sidesand not at the top (or
103 bool IsVertical() const;
108 virtual int HitTest(const wxPoint
& pt
, long *flags
= NULL
) const;
113 virtual bool PerformAction(const wxControlAction
& action
,
115 const wxString
& strArg
= wxEmptyString
);
117 static wxInputHandler
*GetStdInputHandler(wxInputHandler
*handlerDef
);
118 virtual wxInputHandler
*DoGetStdInputHandler(wxInputHandler
*handlerDef
)
120 return GetStdInputHandler(handlerDef
);
123 // refresh the currently selected tab
124 void RefreshCurrent();
127 virtual wxNotebookPage
*DoRemovePage(size_t nPage
);
130 virtual void DoDraw(wxControlRenderer
*renderer
);
131 void DoDrawTab(wxDC
& dc
, const wxRect
& rect
, size_t n
);
134 virtual wxSize
DoGetBestClientSize() const;
135 virtual void DoMoveWindow(int x
, int y
, int width
, int height
);
136 virtual void DoSetSize(int x
, int y
,
137 int width
, int height
,
138 int sizeFlags
= wxSIZE_AUTO
);
140 int DoSetSelection(size_t nPage
, int flags
= 0);
142 // common part of all ctors
145 // resize the tab to fit its title (and icon if any)
146 void ResizeTab(int page
);
148 // recalculate the geometry of the notebook completely
151 // is the spin button currently shown?
152 bool HasSpinBtn() const;
154 // calculate last (fully) visible tab: updates m_lastVisible
155 void CalcLastVisibleTab();
157 // show or hide the spin control for tabs scrolling depending on whether it
159 void UpdateSpinBtn();
161 // position the spin button
162 void PositionSpinBtn();
164 // refresh the given tab only
165 void RefreshTab(int page
, bool forceSelected
= false);
168 void RefreshAllTabs();
170 // get the tab rect (inefficient, don't use this in a loop)
171 wxRect
GetTabRect(int page
) const;
173 // get the rectangle containing all tabs
174 wxRect
GetAllTabsRect() const;
176 // get the part occupied by the tabs - slightly smaller than
177 // GetAllTabsRect() because the tabs may be indented from it
178 wxRect
GetTabsPart() const;
180 // calculate the tab size (without padding)
181 wxSize
CalcTabSize(int page
) const;
183 // get the (cached) size of a tab
184 void GetTabSize(int page
, wxCoord
*w
, wxCoord
*h
) const;
186 // get the (cached) width of the tab
187 wxCoord
GetTabWidth(int page
) const
188 { return FixedSizeTabs() ? m_widthMax
: m_widths
[page
]; }
190 // return true if the tab has an associated image
191 bool HasImage(int page
) const
192 { return m_imageList
&& m_images
[page
] != -1; }
194 // get the part of the notebook reserved for the pages (slightly larger
195 // than GetPageRect() as we draw a border and leave marginin between)
196 wxRect
GetPagePart() const;
198 // get the page rect in our client coords
199 wxRect
GetPageRect() const;
201 // get our client size from the page size
202 wxSize
GetSizeForPage(const wxSize
& size
) const;
204 // scroll the tabs so that the first page shown becomes the given one
205 void ScrollTo(int page
);
207 // scroll the tabs so that the first page shown becomes the given one
208 void ScrollLastTo(int page
);
211 wxArrayString m_titles
;
213 // the current selection
216 // the spin button to change the pages
217 wxSpinButton
*m_spinbtn
;
219 // the offset of the first page shown (may be changed with m_spinbtn)
222 // the first and last currently visible tabs: the name is not completely
223 // accurate as m_lastVisible is, in fact, the first tab which is *not*
224 // visible: so the visible tabs are those with indexes such that
225 // m_firstVisible <= n < m_lastVisible
226 size_t m_firstVisible
,
229 // the last fully visible item, usually just m_lastVisible - 1 but may be
231 size_t m_lastFullyVisible
;
233 // the height of tabs in a normal notebook or the width of tabs in a
234 // notebook with tabs on a side
237 // the biggest height (or width) of a notebook tab (used only if
238 // FixedSizeTabs()) or -1 if not calculated yet
241 // the cached widths (or heights) of tabs
247 // the accel indexes for labels
253 DECLARE_DYNAMIC_CLASS(wxNotebook
)
256 #endif // _WX_UNIV_NOTEBOOK_H_