]> git.saurik.com Git - wxWidgets.git/blob - include/wx/generic/notebook.h
1. MSW message handling simplifications
[wxWidgets.git] / include / wx / generic / notebook.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: notebook.h
3 // Purpose: wxNotebook class (a.k.a. property sheet, tabbed dialog)
4 // Author: Julian Smart
5 // Modified by:
6 // RCS-ID: $Id$
7 // Copyright: (c) Julian Smart
8 // Licence: wxWindows licence
9 /////////////////////////////////////////////////////////////////////////////
10
11 #ifndef _WX_NOTEBOOK_H_
12 #define _WX_NOTEBOOK_H_
13
14 #ifdef __GNUG__
15 #pragma interface "notebook.h"
16 #endif
17
18 // ----------------------------------------------------------------------------
19 // headers
20 // ----------------------------------------------------------------------------
21 #include "wx/dynarray.h"
22 #include "wx/event.h"
23 #include "wx/control.h"
24 #include "wx/generic/tabg.h"
25
26 // ----------------------------------------------------------------------------
27 // types
28 // ----------------------------------------------------------------------------
29
30 // fwd declarations
31 class WXDLLEXPORT wxImageList;
32 class WXDLLEXPORT wxWindow;
33
34 // array of notebook pages
35 typedef wxWindow wxNotebookPage; // so far, any window can be a page
36 WX_DEFINE_ARRAY(wxNotebookPage *, wxArrayPages);
37
38 // ----------------------------------------------------------------------------
39 // notebook events
40 // ----------------------------------------------------------------------------
41 class WXDLLEXPORT wxNotebookEvent : public wxCommandEvent
42 {
43 public:
44 wxNotebookEvent(wxEventType commandType = wxEVT_NULL, int id = 0,
45 int nSel = -1, int nOldSel = -1)
46 : wxCommandEvent(commandType, id) { m_nSel = nSel; m_nOldSel = nOldSel; }
47
48 // accessors
49 int GetSelection() const { return m_nSel; }
50 int GetOldSelection() const { return m_nOldSel; }
51
52 void SetSelection(int sel) { m_nSel = sel; }
53 void SetOldSelection(int oldSel) { m_nOldSel = oldSel; }
54
55 private:
56 int m_nSel, // currently selected page
57 m_nOldSel; // previously selected page
58
59 DECLARE_DYNAMIC_CLASS(wxNotebookEvent)
60 };
61
62 // ----------------------------------------------------------------------------
63 // wxNotebook
64 // ----------------------------------------------------------------------------
65
66 class WXDLLEXPORT wxNotebook;
67
68 // This reuses wxTabView to draw the tabs.
69 class WXDLLEXPORT wxNotebookTabView: public wxTabView
70 {
71 DECLARE_DYNAMIC_CLASS(wxNotebookTabView)
72 public:
73 wxNotebookTabView(wxNotebook* notebook, long style = wxTAB_STYLE_DRAW_BOX | wxTAB_STYLE_COLOUR_INTERIOR);
74 ~wxNotebookTabView(void);
75
76 // Called when a tab is activated
77 virtual void OnTabActivate(int activateId, int deactivateId);
78
79 protected:
80 wxNotebook* m_notebook;
81 };
82
83 class wxNotebook : public wxControl
84 {
85 public:
86 // ctors
87 // -----
88 // default for dynamic class
89 wxNotebook();
90 // the same arguments as for wxControl (@@@ any special styles?)
91 wxNotebook(wxWindow *parent,
92 wxWindowID id,
93 const wxPoint& pos = wxDefaultPosition,
94 const wxSize& size = wxDefaultSize,
95 long style = 0,
96 const wxString& name = "notebook");
97 // Create() function
98 bool Create(wxWindow *parent,
99 wxWindowID id,
100 const wxPoint& pos = wxDefaultPosition,
101 const wxSize& size = wxDefaultSize,
102 long style = 0,
103 const wxString& name = "notebook");
104 // dtor
105 ~wxNotebook();
106
107 // accessors
108 // ---------
109 // get number of pages in the dialog
110 int GetPageCount() const;
111
112 // Find the position of the wxNotebookPage, -1 if not found.
113 int FindPagePosition(wxNotebookPage* page) const;
114
115 // set the currently selected page, return the index of the previously
116 // selected one (or -1 on error)
117 // NB: this function will _not_ generate wxEVT_NOTEBOOK_PAGE_xxx events
118 int SetSelection(int nPage);
119 // cycle thru the tabs
120 void AdvanceSelection(bool bForward = TRUE);
121 // get the currently selected page
122 int GetSelection() const { return m_nSelection; }
123
124 // set/get the title of a page
125 bool SetPageText(int nPage, const wxString& strText);
126 wxString GetPageText(int nPage) const;
127
128 // image list stuff: each page may have an image associated with it. All
129 // the images belong to an image list, so you have to
130 // 1) create an image list
131 // 2) associate it with the notebook
132 // 3) set for each page it's image
133 // associate image list with a control
134 void SetImageList(wxImageList* imageList);
135 // get pointer (may be NULL) to the associated image list
136 wxImageList* GetImageList() const { return m_pImageList; }
137
138 // sets/returns item's image index in the current image list
139 int GetPageImage(int nPage) const;
140 bool SetPageImage(int nPage, int nImage);
141
142 // currently it's always 1 because wxGTK doesn't support multi-row
143 // tab controls
144 int GetRowCount() const;
145
146 // control the appearance of the notebook pages
147 // set the size (the same for all pages)
148 void SetPageSize(const wxSize& size);
149 // set the padding between tabs (in pixels)
150 void SetPadding(const wxSize& padding);
151
152 // Sets the size of the tabs (assumes all tabs are the same size)
153 void SetTabSize(const wxSize& sz);
154
155 // operations
156 // ----------
157 // remove one page from the notebook, and delete the page.
158 bool DeletePage(int nPage);
159 bool DeletePage(wxNotebookPage* page);
160 // remove one page from the notebook, without deleting the page.
161 bool RemovePage(int nPage);
162 bool RemovePage(wxNotebookPage* page);
163 // remove all pages
164 bool DeleteAllPages();
165 // adds a new page to the notebook (it will be deleted ny the notebook,
166 // don't delete it yourself). If bSelect, this page becomes active.
167 bool AddPage(wxNotebookPage *pPage,
168 const wxString& strText,
169 bool bSelect = FALSE,
170 int imageId = -1);
171 // the same as AddPage(), but adds it at the specified position
172 bool InsertPage(int nPage,
173 wxNotebookPage *pPage,
174 const wxString& strText,
175 bool bSelect = FALSE,
176 int imageId = -1);
177 // get the panel which represents the given page
178 wxNotebookPage *GetPage(int nPage) { return m_aPages[nPage]; }
179
180 // callbacks
181 // ---------
182 void OnSize(wxSizeEvent& event);
183 void OnIdle(wxIdleEvent& event);
184 void OnSelChange(wxNotebookEvent& event);
185 void OnSetFocus(wxFocusEvent& event);
186 void OnNavigationKey(wxNavigationKeyEvent& event);
187
188 // base class virtuals
189 // -------------------
190 virtual void Command(wxCommandEvent& event);
191 virtual void SetConstraintSizes(bool recurse = TRUE);
192 virtual bool DoPhase(int nPhase);
193
194 // Implementation
195
196 // wxNotebook on Motif uses a generic wxTabView to implement itself.
197 inline wxTabView *GetTabView() const { return m_tabView; }
198 inline void SetTabView(wxTabView *v) { m_tabView = v; }
199
200 void OnMouseEvent(wxMouseEvent& event);
201 void OnPaint(wxPaintEvent& event);
202
203 virtual wxRect GetAvailableClientSize();
204
205 // Implementation: calculate the layout of the view rect
206 // and resize the children if required
207 bool RefreshLayout(bool force = TRUE);
208
209 protected:
210 // common part of all ctors
211 void Init();
212
213 // helper functions
214 void ChangePage(int nOldSel, int nSel); // change pages
215
216 wxImageList *m_pImageList; // we can have an associated image list
217 wxArrayPages m_aPages; // array of pages
218
219 int m_nSelection; // the current selection (-1 if none)
220
221 wxTabView* m_tabView;
222
223 DECLARE_DYNAMIC_CLASS(wxNotebook)
224 DECLARE_EVENT_TABLE()
225 };
226
227 // ----------------------------------------------------------------------------
228 // event macros
229 // ----------------------------------------------------------------------------
230 typedef void (wxEvtHandler::*wxNotebookEventFunction)(wxNotebookEvent&);
231
232 // Because of name truncation!
233 #if defined(__BORLANDC__) && defined(__WIN16__)
234
235 #define EVT_NOTEBOOK_PAGE_CHANGED(id, fn) \
236 { \
237 wxEVT_COMMAND_NB_PAGE_CHANGED, \
238 id, \
239 -1, \
240 (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \
241 NULL \
242 },
243
244 #define EVT_NOTEBOOK_PAGE_CHANGING(id, fn) \
245 { \
246 wxEVT_COMMAND_NB_PAGE_CHANGING, \ \
247 id, \
248 -1, \
249 (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \
250 NULL \
251 },
252
253 #else
254
255 #define EVT_NOTEBOOK_PAGE_CHANGED(id, fn) \
256 { \
257 wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED, \
258 id, \
259 -1, \
260 (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \
261 NULL \
262 },
263
264 #define EVT_NOTEBOOK_PAGE_CHANGING(id, fn) \
265 { \
266 wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING, \ \
267 id, \
268 -1, \
269 (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \
270 NULL \
271 },
272
273 #endif
274
275 #endif // _WX_NOTEBOOK_H_