]> git.saurik.com Git - wxWidgets.git/blame - include/wx/treebook.h
fix aui crash related to SF bug 1531361
[wxWidgets.git] / include / wx / treebook.h
CommitLineData
eca15c0d
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/treebook.h
3// Purpose: wxTreebook: wxNotebook-like control presenting pages in a tree
4// Author: Evgeniy Tarassov, Vadim Zeitlin
5// Modified by:
6// Created: 2005-09-15
7// RCS-ID: $Id$
8// Copyright: (c) 2005 Vadim Zeitlin <vadim@wxwidgets.org>
9// Licence: wxWindows licence
10///////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_TREEBOOK_H_
13#define _WX_TREEBOOK_H_
14
15#include "wx/defs.h"
16
17#if wxUSE_TREEBOOK
18
19#include "wx/bookctrl.h"
20#include "wx/treectrl.h" // for wxArrayTreeItemIds
5e4a7f91 21#include "wx/containr.h"
eca15c0d
VZ
22
23typedef wxWindow wxTreebookPage;
24
25class WXDLLEXPORT wxTreeEvent;
26
eca15c0d
VZ
27// ----------------------------------------------------------------------------
28// wxTreebook
29// ----------------------------------------------------------------------------
30
31class WXDLLEXPORT wxTreebook : public wxBookCtrlBase
32{
33public:
34 // Constructors and such
35 // ---------------------
36
37 // Default ctor doesn't create the control, use Create() afterwards
38 wxTreebook()
39 {
40 Init();
41 }
42
43 // This ctor creates the tree book control
44 wxTreebook(wxWindow *parent,
45 wxWindowID id,
46 const wxPoint& pos = wxDefaultPosition,
47 const wxSize& size = wxDefaultSize,
d8fd7acb 48 long style = wxBK_DEFAULT,
eca15c0d
VZ
49 const wxString& name = wxEmptyString)
50 {
51 Init();
52
53 (void)Create(parent, id, pos, size, style, name);
54 }
55
56 // Really creates the control
57 bool Create(wxWindow *parent,
58 wxWindowID id,
59 const wxPoint& pos = wxDefaultPosition,
60 const wxSize& size = wxDefaultSize,
d8fd7acb 61 long style = wxBK_DEFAULT,
eca15c0d
VZ
62 const wxString& name = wxEmptyString);
63
64
65 // Page insertion operations
66 // -------------------------
67
68 // Notice that page pointer may be NULL in which case the next non NULL
69 // page (usually the first child page of a node) is shown when this page is
70 // selected
71
72 // Inserts a new page just before the page indicated by page.
73 // The new page is placed on the same level as page.
74 virtual bool InsertPage(size_t pos,
75 wxWindow *page,
76 const wxString& text,
77 bool bSelect = false,
78 int imageId = wxNOT_FOUND);
79
80 // Inserts a new sub-page to the end of children of the page at given pos.
9d5371c6
VZ
81 virtual bool InsertSubPage(size_t pos,
82 wxWindow *page,
83 const wxString& text,
84 bool bSelect = false,
85 int imageId = wxNOT_FOUND);
eca15c0d
VZ
86
87 // Adds a new page at top level after all other pages.
88 virtual bool AddPage(wxWindow *page,
89 const wxString& text,
90 bool bSelect = false,
91 int imageId = wxNOT_FOUND);
92
93 // Adds a new child-page to the last top-level page inserted.
94 // Useful when constructing 1 level tree structure.
95 virtual bool AddSubPage(wxWindow *page,
96 const wxString& text,
97 bool bSelect = false,
98 int imageId = wxNOT_FOUND);
99
100 // Deletes the page and ALL its children. Could trigger page selection
101 // change in a case when selected page is removed. In that case its parent
102 // is selected (or the next page if no parent).
103 virtual bool DeletePage(size_t pos);
104
105
106 // Tree operations
107 // ---------------
108
109 // Gets the page node state -- node is expanded or collapsed
110 virtual bool IsNodeExpanded(size_t pos) const;
111
112 // Expands or collapses the page node. Returns the previous state.
113 // May generate page changing events (if selected page
114 // is under the collapsed branch, then parent is autoselected).
115 virtual bool ExpandNode(size_t pos, bool expand = true);
116
117 // shortcut for ExpandNode(pos, false)
118 bool CollapseNode(size_t pos) { return ExpandNode(pos, false); }
119
120 // get the parent page or wxNOT_FOUND if this is a top level page
121 int GetPageParent(size_t pos) const;
122
d8fd7acb
WS
123 // the tree control we use for showing the pages index tree
124 wxTreeCtrl* GetTreeCtrl() const { return (wxTreeCtrl*)m_bookctrl; }
125
eca15c0d
VZ
126
127 // Standard operations inherited from wxBookCtrlBase
128 // -------------------------------------------------
129
130 virtual int GetSelection() const;
131 virtual bool SetPageText(size_t n, const wxString& strText);
132 virtual wxString GetPageText(size_t n) const;
133 virtual int GetPageImage(size_t n) const;
134 virtual bool SetPageImage(size_t n, int imageId);
135 virtual wxSize CalcSizeFromPage(const wxSize& sizePage) const;
1d6fcbcc
VZ
136 virtual int SetSelection(size_t n) { return DoSetSelection(n, SetSelection_SendEvent); }
137 virtual int ChangeSelection(size_t n) { return DoSetSelection(n); }
eca15c0d
VZ
138 virtual void SetImageList(wxImageList *imageList);
139 virtual void AssignImageList(wxImageList *imageList);
140 virtual bool DeleteAllPages();
141
142protected:
6f02a879
VZ
143 // Implementation of a page removal. See DeletPage for comments.
144 wxTreebookPage *DoRemovePage(size_t pos);
145
eca15c0d
VZ
146 // This subclass of wxBookCtrlBase accepts NULL page pointers (empty pages)
147 virtual bool AllowNullPage() const { return true; }
148
851b88c3
VZ
149 // return the page corresponding to the tab at the specified position
150 virtual int HitTest(const wxPoint& pt, long *flags = NULL) const;
151
eca15c0d 152 // event handlers
eca15c0d
VZ
153 void OnTreeSelectionChange(wxTreeEvent& event);
154 void OnTreeNodeExpandedCollapsed(wxTreeEvent& event);
155
eca15c0d
VZ
156 // array of page ids and page windows
157 wxArrayTreeItemIds m_treeIds;
158
159 // the currently selected page or wxNOT_FOUND if none
160 int m_selection;
161
162 // in the situation when m_selection page is not wxNOT_FOUND but page is
163 // NULL this is the first (sub)child that has a non-NULL page
164 int m_actualSelection;
165
166private:
167 // common part of all constructors
168 void Init();
169
170 // The real implementations of page insertion functions
171 // ------------------------------------------------------
172 // All DoInsert/Add(Sub)Page functions add the page into :
173 // - the base class
174 // - the tree control
175 // - update the index/TreeItemId corespondance array
176 bool DoInsertPage(size_t pos,
177 wxWindow *page,
178 const wxString& text,
179 bool bSelect = false,
180 int imageId = wxNOT_FOUND);
181 bool DoInsertSubPage(size_t pos,
182 wxWindow *page,
183 const wxString& text,
184 bool bSelect = false,
185 int imageId = wxNOT_FOUND);
186 bool DoAddSubPage(wxWindow *page,
187 const wxString& text,
188 bool bSelect = false,
189 int imageId = wxNOT_FOUND);
190
eca15c0d 191 // Sets selection in the tree control and updates the page being shown.
1d6fcbcc 192 int DoSetSelection(size_t pos, int flags = 0);
eca15c0d
VZ
193
194 // Returns currently shown page. In a case when selected the node
195 // has empty (NULL) page finds first (sub)child with not-empty page.
196 wxTreebookPage *DoGetCurrentPage() const;
197
198 // Does the selection update. Called from page insertion functions
199 // to update selection if the selected page was pushed by the newly inserted
200 void DoUpdateSelection(bool bSelect, int page);
201
202
203 // Operations on the internal private members of the class
204 // -------------------------------------------------------
205 // Returns the page TreeItemId for the page.
206 // Or, if the page index is incorrect, a fake one (fakePage.IsOk() == false)
207 wxTreeItemId DoInternalGetPage(size_t pos) const;
208
209 // Linear search for a page with the id specified. If no page
210 // found wxNOT_FOUND is returned. The function is used when we catch an event
211 // from m_tree (wxTreeCtrl) component.
212 int DoInternalFindPageById(wxTreeItemId page) const;
213
214 // Updates page and wxTreeItemId correspondance.
215 void DoInternalAddPage(size_t newPos, wxWindow *page, wxTreeItemId pageId);
216
217 // Removes the page from internal structure.
218 void DoInternalRemovePage(size_t pos)
219 { DoInternalRemovePageRange(pos, 0); }
220
221 // Removes the page and all its children designated by subCount
222 // from internal structures of the control.
223 void DoInternalRemovePageRange(size_t pos, size_t subCount);
224
225 // Returns internal number of pages which can be different from
226 // GetPageCount() while performing a page insertion or removal.
227 size_t DoInternalGetPageCount() const { return m_treeIds.Count(); }
228
229
230 DECLARE_EVENT_TABLE()
231 DECLARE_DYNAMIC_CLASS_NO_COPY(wxTreebook)
5e4a7f91 232 WX_DECLARE_CONTROL_CONTAINER();
eca15c0d
VZ
233};
234
235
236// ----------------------------------------------------------------------------
237// treebook event class and related stuff
238// ----------------------------------------------------------------------------
239
240class WXDLLEXPORT wxTreebookEvent : public wxBookCtrlBaseEvent
241{
242public:
243 wxTreebookEvent(wxEventType commandType = wxEVT_NULL, int id = 0,
244 int nSel = wxNOT_FOUND, int nOldSel = wxNOT_FOUND)
245 : wxBookCtrlBaseEvent(commandType, id, nSel, nOldSel)
246 {
247 }
248
b2f8e75a
VZ
249 wxTreebookEvent(const wxTreebookEvent& event)
250 : wxBookCtrlBaseEvent(event)
251 {
252 }
253
254 virtual wxEvent *Clone() const { return new wxTreebookEvent(*this); }
255
eca15c0d 256private:
b2f8e75a 257 DECLARE_DYNAMIC_CLASS_NO_ASSIGN(wxTreebookEvent)
eca15c0d
VZ
258};
259
260extern WXDLLIMPEXP_CORE const wxEventType wxEVT_COMMAND_TREEBOOK_PAGE_CHANGED;
261extern WXDLLIMPEXP_CORE const wxEventType wxEVT_COMMAND_TREEBOOK_PAGE_CHANGING;
262extern WXDLLIMPEXP_CORE const wxEventType wxEVT_COMMAND_TREEBOOK_NODE_COLLAPSED;
263extern WXDLLIMPEXP_CORE const wxEventType wxEVT_COMMAND_TREEBOOK_NODE_EXPANDED;
264
265typedef void (wxEvtHandler::*wxTreebookEventFunction)(wxTreebookEvent&);
266
267#define wxTreebookEventHandler(func) \
268 (wxObjectEventFunction)(wxEventFunction)wxStaticCastEvent(wxTreebookEventFunction, &func)
269
270#define EVT_TREEBOOK_PAGE_CHANGED(winid, fn) \
271 wx__DECLARE_EVT1(wxEVT_COMMAND_TREEBOOK_PAGE_CHANGED, winid, wxTreebookEventHandler(fn))
272
273#define EVT_TREEBOOK_PAGE_CHANGING(winid, fn) \
274 wx__DECLARE_EVT1(wxEVT_COMMAND_TREEBOOK_PAGE_CHANGING, winid, wxTreebookEventHandler(fn))
275
276#define EVT_TREEBOOK_NODE_COLLAPSED(winid, fn) \
277 wx__DECLARE_EVT1(wxEVT_COMMAND_TREEBOOK_NODE_COLLAPSED, winid, wxTreebookEventHandler(fn))
278
279#define EVT_TREEBOOK_NODE_EXPANDED(winid, fn) \
280 wx__DECLARE_EVT1(wxEVT_COMMAND_TREEBOOK_NODE_EXPANDED, winid, wxTreebookEventHandler(fn))
281
282
283#endif // wxUSE_TREEBOOK
284
285#endif // _WX_TREEBOOK_H_