]>
Commit | Line | Data |
---|---|---|
23324ae1 FM |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: mdi.h | |
e54c96f1 | 3 | // Purpose: interface of wxMDIClientWindow |
23324ae1 FM |
4 | // Author: wxWidgets team |
5 | // RCS-ID: $Id$ | |
6 | // Licence: wxWindows license | |
7 | ///////////////////////////////////////////////////////////////////////////// | |
8 | ||
9 | /** | |
10 | @class wxMDIClientWindow | |
7c913512 | 11 | |
23324ae1 FM |
12 | An MDI client window is a child of wxMDIParentFrame, and manages zero or |
13 | more wxMDIChildFrame objects. | |
7c913512 | 14 | |
5c3a762d FM |
15 | @remarks |
16 | ||
17 | The client window is the area where MDI child windows exist. It doesn't have to | |
18 | cover the whole parent frame; other windows such as toolbars and a help window | |
19 | might coexist with it. There can be scrollbars on a client window, which are | |
20 | controlled by the parent window style. | |
21 | ||
22 | The wxMDIClientWindow class is usually adequate without further derivation, and | |
23 | it is created automatically when the MDI parent frame is created. If the application | |
24 | needs to derive a new class, the function wxMDIParentFrame::OnCreateClient() must | |
25 | be overridden in order to give an opportunity to use a different class of client | |
26 | window. | |
27 | ||
bb69632a | 28 | Under wxMSW, the client window will automatically have a sunken border style |
5c3a762d | 29 | when the active child is not maximized, and no border style when a child is maximized. |
7c913512 | 30 | |
ba1d7a6c FM |
31 | @library{wxcore} |
32 | @category{managedwnd} | |
33 | ||
e54c96f1 | 34 | @see wxMDIChildFrame, wxMDIParentFrame, wxFrame |
23324ae1 FM |
35 | */ |
36 | class wxMDIClientWindow : public wxWindow | |
37 | { | |
38 | public: | |
5c3a762d FM |
39 | /** |
40 | Default constructor. | |
d2824cdb VZ |
41 | |
42 | Objects of this class are only created by wxMDIParentFrame which uses | |
43 | the default constructor and calls CreateClient() immediately | |
44 | afterwards. | |
45 | */ | |
5c3a762d FM |
46 | wxMDIClientWindow(); |
47 | ||
23324ae1 | 48 | /** |
d2824cdb VZ |
49 | Called by wxMDIParentFrame immediately after creating the client |
50 | window. | |
51 | ||
52 | This function may be overridden in the derived class but the base class | |
53 | version must usually be called first to really create the window. | |
3c4f71cc | 54 | |
7c913512 | 55 | @param parent |
4cc4bfaf | 56 | The window parent. |
7c913512 | 57 | @param style |
d2824cdb VZ |
58 | The window style. Only wxHSCROLL and wxVSCROLL bits are meaningful |
59 | here. | |
3c4f71cc | 60 | |
23324ae1 | 61 | */ |
adaaa686 | 62 | virtual bool CreateClient(wxMDIParentFrame* parent, long style = 0); |
23324ae1 FM |
63 | }; |
64 | ||
65 | ||
e54c96f1 | 66 | |
23324ae1 FM |
67 | /** |
68 | @class wxMDIParentFrame | |
7c913512 | 69 | |
d2824cdb VZ |
70 | An MDI (Multiple Document Interface) parent frame is a window which can |
71 | contain MDI child frames in its client area which emulates the full | |
72 | desktop. | |
73 | ||
74 | MDI is a user-interface model in which all the window reside inside the | |
75 | single parent window as opposed to being separate from each other. It | |
76 | remains popular despite dire warnings from Microsoft itself (which | |
77 | popularized this model in the first model) that MDI is obsolete. | |
78 | ||
79 | An MDI parent frame always has a wxMDIClientWindow associated with it, | |
80 | which is the parent for MDI child frames. In the simplest case, the client | |
81 | window takes up the entire parent frame area but it is also possible to | |
82 | resize it to be smaller in order to have other windows in the frame, a | |
83 | typical example is using a sidebar along one of the window edges. | |
84 | ||
85 | The appearance of MDI applications differs between different ports. The | |
86 | classic MDI model, with child windows which can be independently moved, | |
87 | resized etc, is only available under MSW, which provides native support for | |
88 | it. In Mac ports, multiple top level windows are used for the MDI children | |
89 | too and the MDI parent frame itself is invisible, to accommodate the native | |
90 | look and feel requirements. In all the other ports, a tab-based MDI | |
91 | implementation (sometimes called TDI) is used and so at most one MDI child | |
92 | is visible at any moment (child frames are always maximized). | |
5c3a762d FM |
93 | |
94 | @remarks | |
95 | ||
d2824cdb VZ |
96 | Although it is possible to have multiple MDI parent frames, a typical MDI |
97 | application has a single MDI parent frame window inside which multiple MDI | |
98 | child frames, i.e. objects of class wxMDIChildFrame, can be created. | |
5c3a762d | 99 | |
5c3a762d | 100 | |
d2824cdb | 101 | @beginStyleTable |
5c3a762d | 102 | |
d2824cdb VZ |
103 | There are no special styles for this class, all wxFrame styles apply to it |
104 | in the usual way. The only exception is that wxHSCROLL and wxVSCROLL styles | |
105 | apply not to the frame itself but to the client window, so that using them | |
106 | enables horizontal and vertical scrollbars for this window and not the | |
107 | frame. | |
7c913512 | 108 | |
23324ae1 | 109 | @endStyleTable |
7c913512 | 110 | |
23324ae1 FM |
111 | @library{wxcore} |
112 | @category{managedwnd} | |
7c913512 | 113 | |
e54c96f1 | 114 | @see wxMDIChildFrame, wxMDIClientWindow, wxFrame, wxDialog |
23324ae1 FM |
115 | */ |
116 | class wxMDIParentFrame : public wxFrame | |
117 | { | |
118 | public: | |
5c3a762d FM |
119 | |
120 | /** | |
121 | Default constructor. | |
d2824cdb VZ |
122 | |
123 | Use Create() for the objects created using this constructor. | |
5c3a762d FM |
124 | */ |
125 | wxMDIParentFrame(); | |
126 | ||
23324ae1 FM |
127 | /** |
128 | Constructor, creating the window. | |
3c4f71cc | 129 | |
d2824cdb VZ |
130 | Notice that if you override virtual OnCreateClient() method you |
131 | shouldn't be using this constructor but the default constructor and | |
132 | Create() as otherwise your overridden method is never going to be | |
133 | called because of the usual C++ virtual call resolution rules. | |
134 | ||
7c913512 | 135 | @param parent |
d2824cdb | 136 | The window parent. Usually is @NULL. |
7c913512 | 137 | @param id |
d2824cdb VZ |
138 | The window identifier. It may take a value of @c wxID_ANY to |
139 | indicate a default value. | |
7c913512 | 140 | @param title |
4cc4bfaf | 141 | The caption to be displayed on the frame's title bar. |
7c913512 | 142 | @param pos |
76e2b570 | 143 | The window position. The value ::wxDefaultPosition indicates a |
d2824cdb VZ |
144 | default position, chosen by either the windowing system or |
145 | wxWidgets, depending on platform. | |
7c913512 | 146 | @param size |
76e2b570 | 147 | The window size. The value ::wxDefaultSize indicates a default |
d2824cdb VZ |
148 | size, chosen by either the windowing system or wxWidgets, depending |
149 | on platform. | |
7c913512 | 150 | @param style |
d2824cdb VZ |
151 | The window style. Default value includes wxHSCROLL and wxVSCROLL |
152 | styles. | |
7c913512 | 153 | @param name |
5c3a762d | 154 | The name of the window. This parameter is used to associate a name |
d2824cdb VZ |
155 | with the item, allowing the application user to set Motif resource |
156 | values for individual windows. | |
157 | ||
158 | @remarks | |
3c4f71cc | 159 | |
bb69632a | 160 | Under wxMSW, the client window will automatically have a sunken |
d2824cdb VZ |
161 | border style when the active child is not maximized, and no border |
162 | style when a child is maximized. | |
3c4f71cc | 163 | |
4cc4bfaf | 164 | @see Create(), OnCreateClient() |
23324ae1 | 165 | */ |
7c913512 FM |
166 | wxMDIParentFrame(wxWindow* parent, wxWindowID id, |
167 | const wxString& title, | |
168 | const wxPoint& pos = wxDefaultPosition, | |
169 | const wxSize& size = wxDefaultSize, | |
4cc4bfaf | 170 | long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL, |
408776d0 | 171 | const wxString& name = wxFrameNameStr); |
23324ae1 FM |
172 | |
173 | /** | |
d2824cdb VZ |
174 | Destructor. |
175 | ||
176 | Destroys all child windows and menu bar if present. | |
23324ae1 | 177 | */ |
adaaa686 | 178 | virtual ~wxMDIParentFrame(); |
23324ae1 FM |
179 | |
180 | /** | |
181 | Activates the MDI child following the currently active one. | |
3c4f71cc | 182 | |
d2824cdb VZ |
183 | The MDI children are maintained in an ordered list and this function |
184 | switches to the next element in this list, wrapping around the end of | |
185 | it if the currently active child is the last one. | |
186 | ||
4cc4bfaf | 187 | @see ActivatePrevious() |
23324ae1 | 188 | */ |
adaaa686 | 189 | virtual void ActivateNext(); |
23324ae1 FM |
190 | |
191 | /** | |
192 | Activates the MDI child preceding the currently active one. | |
3c4f71cc | 193 | |
4cc4bfaf | 194 | @see ActivateNext() |
23324ae1 | 195 | */ |
adaaa686 | 196 | virtual void ActivatePrevious(); |
23324ae1 FM |
197 | |
198 | /** | |
199 | Arranges any iconized (minimized) MDI child windows. | |
3c4f71cc | 200 | |
d2824cdb VZ |
201 | This method is only implemented in MSW MDI implementation and does |
202 | nothing under the other platforms. | |
203 | ||
4cc4bfaf | 204 | @see Cascade(), Tile() |
23324ae1 | 205 | */ |
adaaa686 | 206 | virtual void ArrangeIcons(); |
23324ae1 FM |
207 | |
208 | /** | |
209 | Arranges the MDI child windows in a cascade. | |
3c4f71cc | 210 | |
d2824cdb VZ |
211 | This method is only implemented in MSW MDI implementation and does |
212 | nothing under the other platforms. | |
213 | ||
4cc4bfaf | 214 | @see Tile(), ArrangeIcons() |
23324ae1 | 215 | */ |
adaaa686 | 216 | virtual void Cascade(); |
23324ae1 FM |
217 | |
218 | /** | |
ba1d7a6c | 219 | Used in two-step frame construction. |
d2824cdb | 220 | |
ba1d7a6c | 221 | See wxMDIParentFrame() for further details. |
23324ae1 | 222 | */ |
d2824cdb VZ |
223 | bool Create(wxWindow* parent, |
224 | wxWindowID id, | |
225 | const wxString& title, | |
23324ae1 | 226 | const wxPoint& pos = wxDefaultPosition, |
d2824cdb VZ |
227 | const wxSize& size = wxDefaultSize, |
228 | long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL, | |
5267aefd | 229 | const wxString& name = wxFrameNameStr); |
23324ae1 FM |
230 | |
231 | /** | |
232 | Returns a pointer to the active MDI child, if there is one. | |
d2824cdb VZ |
233 | |
234 | If there are any children at all this function returns a non-@NULL | |
235 | pointer. | |
23324ae1 | 236 | */ |
26818748 | 237 | virtual wxMDIChildFrame* GetActiveChild() const; |
23324ae1 FM |
238 | |
239 | /** | |
d2824cdb | 240 | Returns a pointer to the client window. |
5c3a762d | 241 | |
d2824cdb VZ |
242 | @see OnCreateClient() |
243 | */ | |
26818748 | 244 | wxMDIClientWindowBase* GetClientWindow() const; |
5c3a762d | 245 | |
d2824cdb VZ |
246 | /** |
247 | Returns the current MDI Window menu. | |
5c3a762d | 248 | |
d2824cdb VZ |
249 | Unless wxFRAME_NO_WINDOW_MENU style was used, a default menu listing |
250 | all the currently active children and providing the usual operations | |
251 | (tile, cascade, ...) on them is created automatically by the library | |
252 | and this function can be used to retrieve it. Notice that the default | |
253 | menu can be replaced by calling SetWindowMenu(). | |
5c3a762d | 254 | |
d2824cdb | 255 | This function is currently not available under OS X. |
5c3a762d | 256 | |
d2824cdb | 257 | @return The current Window menu or @NULL. |
23324ae1 | 258 | */ |
d2824cdb | 259 | wxMenu *GetWindowMenu() const; |
23324ae1 FM |
260 | |
261 | /** | |
d2824cdb | 262 | Returns whether the MDI implementation is tab-based. |
3c4f71cc | 263 | |
d2824cdb VZ |
264 | Currently only the MSW port uses the real MDI. In Mac ports the usual |
265 | SDI is used, as common under this platforms, and all the other ports | |
266 | use TDI implementation. | |
23324ae1 | 267 | |
d2824cdb VZ |
268 | TDI-based MDI applications have different appearance and functionality |
269 | (e.g. child frames can't be minimized and only one of them is visible | |
270 | at any given time) so the application may need to adapt its interface | |
271 | somewhat depending on the return value of this function. | |
272 | */ | |
273 | static bool IsTDI(); | |
23324ae1 FM |
274 | |
275 | /** | |
d2824cdb | 276 | Override this to return a different kind of client window. |
23324ae1 | 277 | |
d2824cdb VZ |
278 | If you override this function, you must create your parent frame in two |
279 | stages, or your function will never be called, due to the way C++ | |
280 | treats virtual functions called from constructors. For example: | |
5c3a762d FM |
281 | |
282 | @code | |
283 | frame = new MyParentFrame; | |
f8ebb70d | 284 | frame->Create(parent, myParentFrameId, "My Parent Frame"); |
5c3a762d | 285 | @endcode |
3c4f71cc | 286 | |
5c3a762d FM |
287 | @remarks |
288 | ||
d2824cdb VZ |
289 | You might wish to derive from wxMDIClientWindow in order to implement |
290 | different erase behaviour, for example, such as painting a bitmap on | |
291 | the background. | |
5c3a762d FM |
292 | |
293 | Note that it is probably impossible to have a client window that scrolls | |
294 | as well as painting a bitmap or pattern, since in @b OnScroll, the scrollbar | |
ba1d7a6c | 295 | positions always return zero. |
3c4f71cc | 296 | |
4cc4bfaf | 297 | @see GetClientWindow(), wxMDIClientWindow |
23324ae1 FM |
298 | */ |
299 | virtual wxMDIClientWindow* OnCreateClient(); | |
300 | ||
301 | /** | |
d2824cdb | 302 | Replace the current MDI Window menu. |
5c3a762d | 303 | |
d2824cdb VZ |
304 | Ownership of the menu object passes to the frame when you call this |
305 | function, i.e. the menu will be deleted by it when it's no longer | |
306 | needed (usually when the frame itself is deleted or when | |
307 | SetWindowMenu() is called again). | |
5c3a762d | 308 | |
d2824cdb VZ |
309 | To remove the window completely, you can use the wxFRAME_NO_WINDOW_MENU |
310 | window style but this function also allows to do it by passing @NULL | |
311 | pointer as @a menu. | |
5c3a762d | 312 | |
1483e5db VZ |
313 | The menu may include the items with the following standard identifiers |
314 | (but may use arbitrary text and help strings and bitmaps for them): | |
315 | - @c wxID_MDI_WINDOW_CASCADE | |
316 | - @c wxID_MDI_WINDOW_TILE_HORZ | |
317 | - @c wxID_MDI_WINDOW_TILE_VERT | |
318 | - @c wxID_MDI_WINDOW_ARRANGE_ICONS | |
319 | - @c wxID_MDI_WINDOW_PREV | |
320 | - @c wxID_MDI_WINDOW_NEXT | |
321 | All of which are handled by wxMDIParentFrame itself. If any other | |
322 | commands are used in the menu, the derived frame should handle them. | |
323 | ||
d2824cdb | 324 | This function is currently not available under OS X. |
3c4f71cc | 325 | |
d2824cdb VZ |
326 | @param menu |
327 | The menu to be used instead of the standard MDI Window menu or @NULL. | |
23324ae1 | 328 | */ |
26818748 | 329 | virtual void SetWindowMenu(wxMenu* menu); |
23324ae1 FM |
330 | |
331 | /** | |
d2824cdb VZ |
332 | Tiles the MDI child windows either horizontally or vertically depending |
333 | on whether @a orient is @c wxHORIZONTAL or @c wxVERTICAL. | |
5c3a762d | 334 | |
d2824cdb VZ |
335 | This method is only implemented in MSW MDI implementation and does |
336 | nothing under the other platforms. | |
5c3a762d | 337 | |
23324ae1 | 338 | */ |
adaaa686 | 339 | virtual void Tile(wxOrientation orient = wxHORIZONTAL); |
23324ae1 FM |
340 | }; |
341 | ||
342 | ||
e54c96f1 | 343 | |
23324ae1 FM |
344 | /** |
345 | @class wxMDIChildFrame | |
7c913512 | 346 | |
d2824cdb VZ |
347 | An MDI child frame is a frame that can only exist inside a |
348 | wxMDIClientWindow, which is itself a child of wxMDIParentFrame. | |
7c913512 | 349 | |
23324ae1 | 350 | @beginStyleTable |
d2824cdb VZ |
351 | All of the standard wxFrame styles can be used but most of them are ignored |
352 | by TDI-based MDI implementations. | |
23324ae1 | 353 | @endStyleTable |
7c913512 | 354 | |
ba1d7a6c FM |
355 | @remarks |
356 | Although internally an MDI child frame is a child of the MDI client window, | |
d2824cdb VZ |
357 | in wxWidgets you create it as a child of wxMDIParentFrame. In fact, you can |
358 | usually forget that the client window exists. MDI child frames are clipped | |
359 | to the area of the MDI client window, and may be iconized on the client | |
360 | window. You can associate a menubar with a child frame as usual, although | |
361 | an MDI child doesn't display its menubar under its own title bar. The MDI | |
362 | parent frame's menubar will be changed to reflect the currently active | |
363 | child frame. If there are currently no children, the parent frame's own | |
364 | menubar will be displayed. | |
ba1d7a6c | 365 | |
23324ae1 FM |
366 | @library{wxcore} |
367 | @category{managedwnd} | |
7c913512 | 368 | |
e54c96f1 | 369 | @see wxMDIClientWindow, wxMDIParentFrame, wxFrame |
23324ae1 FM |
370 | */ |
371 | class wxMDIChildFrame : public wxFrame | |
372 | { | |
373 | public: | |
5c3a762d FM |
374 | /** |
375 | Default constructor. | |
376 | */ | |
377 | wxMDIChildFrame(); | |
378 | ||
23324ae1 FM |
379 | /** |
380 | Constructor, creating the window. | |
3c4f71cc | 381 | |
7c913512 | 382 | @param parent |
4cc4bfaf | 383 | The window parent. This should not be @NULL. |
7c913512 | 384 | @param id |
4cc4bfaf | 385 | The window identifier. It may take a value of -1 to indicate a default |
5c3a762d | 386 | value. |
7c913512 | 387 | @param title |
4cc4bfaf | 388 | The caption to be displayed on the frame's title bar. |
7c913512 | 389 | @param pos |
76e2b570 | 390 | The window position. The value ::wxDefaultPosition indicates a default position, |
5c3a762d | 391 | chosen by either the windowing system or wxWidgets, depending on platform. |
7c913512 | 392 | @param size |
76e2b570 | 393 | The window size. The value ::wxDefaultSize indicates a default size, chosen by |
4cc4bfaf | 394 | either the windowing system or wxWidgets, depending on platform. |
7c913512 | 395 | @param style |
4cc4bfaf | 396 | The window style. See wxMDIChildFrame. |
7c913512 | 397 | @param name |
4cc4bfaf | 398 | The name of the window. This parameter is used to associate a name with the |
5c3a762d FM |
399 | item, allowing the application user to set Motif resource values for individual |
400 | windows. | |
3c4f71cc | 401 | |
4cc4bfaf | 402 | @see Create() |
23324ae1 | 403 | */ |
7c913512 FM |
404 | wxMDIChildFrame(wxMDIParentFrame* parent, wxWindowID id, |
405 | const wxString& title, | |
406 | const wxPoint& pos = wxDefaultPosition, | |
407 | const wxSize& size = wxDefaultSize, | |
408 | long style = wxDEFAULT_FRAME_STYLE, | |
408776d0 | 409 | const wxString& name = wxFrameNameStr); |
23324ae1 FM |
410 | |
411 | /** | |
412 | Destructor. Destroys all child windows and menu bar if present. | |
413 | */ | |
adaaa686 | 414 | virtual ~wxMDIChildFrame(); |
23324ae1 FM |
415 | |
416 | /** | |
417 | Activates this MDI child frame. | |
3c4f71cc | 418 | |
4cc4bfaf | 419 | @see Maximize(), Restore() |
23324ae1 | 420 | */ |
adaaa686 | 421 | virtual void Activate(); |
23324ae1 FM |
422 | |
423 | /** | |
ba1d7a6c FM |
424 | Used in two-step frame construction. |
425 | See wxMDIChildFrame() for further details. | |
23324ae1 | 426 | */ |
5267aefd | 427 | bool Create(wxMDIParentFrame* parent, wxWindowID id, const wxString& title, |
23324ae1 FM |
428 | const wxPoint& pos = wxDefaultPosition, |
429 | const wxSize& size = wxDefaultSize, | |
430 | long style = wxDEFAULT_FRAME_STYLE, | |
5267aefd | 431 | const wxString& name = wxFrameNameStr); |
23324ae1 | 432 | |
d2824cdb VZ |
433 | /** |
434 | Returns the MDI parent frame containing this child. | |
435 | ||
436 | Notice that this may return a different object than GetParent() as the | |
437 | child frames may be created as children of the client window | |
438 | internally. | |
439 | */ | |
440 | wxMDIParentFrame *GetMDIParent() const; | |
441 | ||
442 | /** | |
443 | Returns true for MDI children in TDI implementations. | |
444 | ||
445 | TDI-based implementations represent MDI children as pages in a | |
446 | wxNotebook and so they are always maximized and can't be restored or | |
447 | iconized. | |
448 | ||
449 | @see wxMDIParentFrame::IsTDI(). | |
450 | */ | |
451 | virtual bool IsAlwaysMaximized() const; | |
452 | ||
23324ae1 FM |
453 | /** |
454 | Maximizes this MDI child frame. | |
3c4f71cc | 455 | |
d2824cdb VZ |
456 | This function doesn't do anything if IsAlwaysMaximized() returns @true. |
457 | ||
4cc4bfaf | 458 | @see Activate(), Restore() |
23324ae1 | 459 | */ |
5267aefd | 460 | virtual void Maximize(bool maximize = true); |
23324ae1 FM |
461 | |
462 | /** | |
463 | Restores this MDI child frame (unmaximizes). | |
d2824cdb VZ |
464 | |
465 | This function doesn't do anything if IsAlwaysMaximized() returns @true. | |
466 | ||
467 | @see Activate(), Maximize() | |
23324ae1 | 468 | */ |
adaaa686 | 469 | virtual void Restore(); |
23324ae1 | 470 | }; |
e54c96f1 | 471 |