]>
Commit | Line | Data |
---|---|---|
b5f2afe5 VZ |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: msw/notebook.h | |
3 | // Purpose: MSW/GTK compatible notebook (a.k.a. property sheet) | |
4 | // Author: Robert Roebling | |
5 | // Modified by: Vadim Zeitlin for Windows version | |
6 | // RCS-ID: $Id$ | |
371a5b4e | 7 | // Copyright: (c) Julian Smart |
65571936 | 8 | // Licence: wxWindows licence |
b5f2afe5 VZ |
9 | ///////////////////////////////////////////////////////////////////////////// |
10 | ||
11 | #ifndef _NOTEBOOK_H | |
12 | #define _NOTEBOOK_H | |
13 | ||
12028905 | 14 | #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) |
b5f2afe5 VZ |
15 | #pragma interface "notebook.h" |
16 | #endif | |
17 | ||
1e6feb95 VZ |
18 | #if wxUSE_NOTEBOOK |
19 | ||
b5f2afe5 VZ |
20 | // ---------------------------------------------------------------------------- |
21 | // headers | |
22 | // ---------------------------------------------------------------------------- | |
74b31181 | 23 | |
7c0ea335 | 24 | #include "wx/control.h" |
b5f2afe5 | 25 | |
b5f2afe5 VZ |
26 | // ---------------------------------------------------------------------------- |
27 | // wxNotebook | |
28 | // ---------------------------------------------------------------------------- | |
29 | ||
8acd402f SC |
30 | class WXDLLEXPORT wxNotebookPageInfo : public wxObject |
31 | { | |
32 | public : | |
3839f37e | 33 | wxNotebookPageInfo() { m_page = NULL; m_imageId = -1; m_selected = false; } |
8acd402f SC |
34 | virtual ~wxNotebookPageInfo() { } |
35 | ||
3839f37e VZ |
36 | void Create(wxNotebookPage *page, |
37 | const wxString& text, | |
38 | bool selected, | |
39 | int imageId) | |
40 | { | |
41 | m_page = page; | |
42 | m_text = text; | |
43 | m_selected = selected; | |
44 | m_imageId = imageId; | |
45 | } | |
46 | ||
47 | wxNotebookPage* GetPage() const { return m_page; } | |
48 | wxString GetText() const { return m_text; } | |
49 | bool GetSelected() const { return m_selected; } | |
8acd402f | 50 | int GetImageId() const { return m_imageId; } |
8acd402f | 51 | |
3839f37e VZ |
52 | private: |
53 | wxNotebookPage *m_page; | |
54 | wxString m_text; | |
55 | bool m_selected; | |
56 | int m_imageId; | |
57 | ||
58 | DECLARE_DYNAMIC_CLASS(wxNotebookPageInfo) | |
59 | }; | |
8acd402f SC |
60 | |
61 | ||
91c9dbdc | 62 | WX_DECLARE_EXPORTED_LIST(wxNotebookPageInfo, wxNotebookPageInfoList ); |
8acd402f | 63 | |
1e6feb95 | 64 | class WXDLLEXPORT wxNotebook : public wxNotebookBase |
b5f2afe5 VZ |
65 | { |
66 | public: | |
67 | // ctors | |
68 | // ----- | |
69 | // default for dynamic class | |
70 | wxNotebook(); | |
71 | // the same arguments as for wxControl (@@@ any special styles?) | |
72 | wxNotebook(wxWindow *parent, | |
35eca07c | 73 | wxWindowID id, |
b5f2afe5 VZ |
74 | const wxPoint& pos = wxDefaultPosition, |
75 | const wxSize& size = wxDefaultSize, | |
debe6624 | 76 | long style = 0, |
630ad6c6 | 77 | const wxString& name = wxNotebookNameStr); |
b5f2afe5 VZ |
78 | // Create() function |
79 | bool Create(wxWindow *parent, | |
35eca07c | 80 | wxWindowID id, |
b5f2afe5 VZ |
81 | const wxPoint& pos = wxDefaultPosition, |
82 | const wxSize& size = wxDefaultSize, | |
debe6624 | 83 | long style = 0, |
630ad6c6 | 84 | const wxString& name = wxNotebookNameStr); |
caf95d2a | 85 | virtual ~wxNotebook(); |
b5f2afe5 VZ |
86 | |
87 | // accessors | |
88 | // --------- | |
89 | // get number of pages in the dialog | |
8d34bf5c | 90 | virtual size_t GetPageCount() const; |
b5f2afe5 VZ |
91 | |
92 | // set the currently selected page, return the index of the previously | |
93 | // selected one (or -1 on error) | |
94 | // NB: this function will _not_ generate wxEVT_NOTEBOOK_PAGE_xxx events | |
15aad3b9 | 95 | int SetSelection(size_t nPage); |
b5f2afe5 VZ |
96 | // get the currently selected page |
97 | int GetSelection() const { return m_nSelection; } | |
98 | ||
99 | // set/get the title of a page | |
15aad3b9 VZ |
100 | bool SetPageText(size_t nPage, const wxString& strText); |
101 | wxString GetPageText(size_t nPage) const; | |
b5f2afe5 VZ |
102 | |
103 | // image list stuff: each page may have an image associated with it. All | |
104 | // the images belong to an image list, so you have to | |
105 | // 1) create an image list | |
106 | // 2) associate it with the notebook | |
107 | // 3) set for each page it's image | |
108 | // associate image list with a control | |
109 | void SetImageList(wxImageList* imageList); | |
b5f2afe5 VZ |
110 | |
111 | // sets/returns item's image index in the current image list | |
15aad3b9 VZ |
112 | int GetPageImage(size_t nPage) const; |
113 | bool SetPageImage(size_t nPage, int nImage); | |
b5f2afe5 | 114 | |
b5f2afe5 VZ |
115 | // currently it's always 1 because wxGTK doesn't support multi-row |
116 | // tab controls | |
117 | int GetRowCount() const; | |
118 | ||
119 | // control the appearance of the notebook pages | |
120 | // set the size (the same for all pages) | |
121 | void SetPageSize(const wxSize& size); | |
122 | // set the padding between tabs (in pixels) | |
123 | void SetPadding(const wxSize& padding); | |
124 | ||
125 | // operations | |
126 | // ---------- | |
b5f2afe5 VZ |
127 | // remove all pages |
128 | bool DeleteAllPages(); | |
e450aa69 | 129 | |
efa14cf2 | 130 | // inserts a new page to the notebook (it will be deleted ny the notebook, |
b5f2afe5 | 131 | // don't delete it yourself). If bSelect, this page becomes active. |
15aad3b9 | 132 | bool InsertPage(size_t nPage, |
b5f2afe5 VZ |
133 | wxNotebookPage *pPage, |
134 | const wxString& strText, | |
078cf5cb | 135 | bool bSelect = false, |
8a33ea62 | 136 | int imageId = -1); |
b5f2afe5 | 137 | |
3839f37e VZ |
138 | void AddPageInfo( wxNotebookPageInfo* info ) { AddPage( info->GetPage() , info->GetText() , info->GetSelected() , info->GetImageId() ); } |
139 | const wxNotebookPageInfoList& GetPageInfos() const; | |
8acd402f | 140 | |
58a8ab88 JS |
141 | // Windows-only at present. Also, you must use the wxNB_FIXEDWIDTH |
142 | // style. | |
143 | void SetTabSize(const wxSize& sz); | |
144 | ||
e450aa69 VZ |
145 | // hit test |
146 | virtual int HitTest(const wxPoint& pt, long *flags = NULL) const; | |
147 | ||
148 | // calculate the size of the notebook from the size of its page | |
2ce7af35 JS |
149 | virtual wxSize CalcSizeFromPage(const wxSize& sizePage) const; |
150 | ||
b5f2afe5 VZ |
151 | // callbacks |
152 | // --------- | |
9026ad85 | 153 | void OnSize(wxSizeEvent& event); |
b5f2afe5 | 154 | void OnSelChange(wxNotebookEvent& event); |
8a33ea62 | 155 | void OnNavigationKey(wxNavigationKeyEvent& event); |
35eca07c | 156 | |
b5f2afe5 VZ |
157 | // base class virtuals |
158 | // ------------------- | |
0b481c72 | 159 | |
a23fd0e1 | 160 | virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result); |
0df3fbd7 VZ |
161 | virtual bool MSWOnScroll(int orientation, WXWORD nSBCode, |
162 | WXWORD pos, WXHWND control); | |
b8bdaa7c | 163 | virtual bool MSWTranslateMessage(WXMSG *wxmsg); |
0b481c72 VZ |
164 | |
165 | #if wxUSE_CONSTRAINTS | |
078cf5cb | 166 | virtual void SetConstraintSizes(bool recurse = true); |
5475b960 | 167 | virtual bool DoPhase(int nPhase); |
0b481c72 | 168 | #endif // wxUSE_CONSTRAINTS |
b5f2afe5 | 169 | |
25057aba JS |
170 | // Attempts to get colour for UX theme page background |
171 | wxColour GetThemeBackgroundColour() const; | |
caf95d2a VZ |
172 | |
173 | // implementation only | |
174 | // ------------------- | |
175 | ||
176 | #if wxUSE_UXTHEME | |
c4a95f6f VZ |
177 | virtual bool SetBackgroundColour(const wxColour& colour) |
178 | { | |
179 | if ( !wxNotebookBase::SetBackgroundColour(colour) ) | |
180 | return false; | |
caf95d2a | 181 | |
c4a95f6f | 182 | UpdateBgBrush(); |
9b7d2b81 | 183 | |
c4a95f6f VZ |
184 | return true; |
185 | } | |
186 | ||
187 | virtual WXHBRUSH MSWGetBgBrushForChild(WXHDC hDC, wxWindow *win); | |
188 | virtual wxColour MSWGetBgColourForChild(wxWindow *win); | |
caf95d2a VZ |
189 | #endif // wxUSE_UXTHEME |
190 | ||
b5f2afe5 VZ |
191 | protected: |
192 | // common part of all ctors | |
193 | void Init(); | |
194 | ||
0df3fbd7 VZ |
195 | // translate wxWin styles to the Windows ones |
196 | virtual WXDWORD MSWGetStyle(long flags, WXDWORD *exstyle = NULL) const; | |
197 | ||
1e6feb95 | 198 | // remove one page from the notebook, without deleting |
15aad3b9 | 199 | virtual wxNotebookPage *DoRemovePage(size_t nPage); |
1e6feb95 | 200 | |
2015f2b3 VZ |
201 | // set the size of the given page to fit in the notebook |
202 | void AdjustPageSize(wxNotebookPage *page); | |
203 | ||
ffafd8a5 | 204 | #if wxUSE_UXTHEME |
c4a95f6f VZ |
205 | // this is a slightly ugly function which gets the bitmap of notebook |
206 | // background and either returns the colour under the specified window in it | |
207 | // or creates a brush from it | |
208 | // | |
209 | // so if win == NULL, a brush is created and returned | |
210 | // win != NULL, returns COLORREF of the pixel under its top left corner | |
211 | WXHANDLE QueryBgBitmap(wxWindow *win = NULL); | |
212 | ||
caf95d2a VZ |
213 | // creates the brush to be used for drawing the tab control background |
214 | void UpdateBgBrush(); | |
07c19327 VZ |
215 | |
216 | // paint themed children background here | |
217 | virtual bool MSWPrintChild(wxWindow *win, WXWPARAM wParam, WXLPARAM lParam); | |
caf95d2a | 218 | #endif // wxUSE_UXTHEME |
2015f2b3 | 219 | |
2b5f62a0 VZ |
220 | // the current selection (-1 if none) |
221 | int m_nSelection; | |
b5f2afe5 | 222 | |
caf95d2a VZ |
223 | wxNotebookPageInfoList m_pageInfos; |
224 | ||
225 | #if wxUSE_UXTHEME | |
226 | // background brush used to paint the tab control | |
227 | WXHBRUSH m_hbrBackground; | |
228 | #endif // wxUSE_UXTHEME | |
8acd402f | 229 | |
2015f2b3 | 230 | |
fc7a2a60 | 231 | DECLARE_DYNAMIC_CLASS_NO_COPY(wxNotebook) |
b5f2afe5 VZ |
232 | DECLARE_EVENT_TABLE() |
233 | }; | |
234 | ||
1e6feb95 VZ |
235 | #endif // wxUSE_NOTEBOOK |
236 | ||
b5f2afe5 | 237 | #endif // _NOTEBOOK_H |