]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/tlw.tex
wxBORDER_THEME now means 'use an appropriate themed border' on all plaforms
[wxWidgets.git] / docs / latex / wx / tlw.tex
CommitLineData
834ed994
VZ
1%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2%% Name: tlw.tex
3%% Purpose: wxTopLevelWindow documentation
4%% Author: Vadim Zeitlin
5%% Modified by:
6%% Created: 2004-09-07 (partly extracted from frame.tex)
7%% RCS-ID: $Id$
8%% Copyright: (c) 2004 Vadim Zeitlin
8795498c 9%% License: wxWindows license
834ed994
VZ
10%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
11
12\section{\class{wxTopLevelWindow}}\label{wxtoplevelwindow}
13
60fef964 14wxTopLevelWindow is a common base class for \helpref{wxDialog}{wxdialog} and
9eace708 15\helpref{wxFrame}{wxframe}. It is an abstract base class meaning that you never
834ed994
VZ
16work with objects of this class directly, but all of its methods are also
17applicable for the two classes above.
18
9eace708
VZ
19\wxheading{Derived from}
20
21\helpref{wxWindow}{wxwindow}\\
22\helpref{wxEvtHandler}{wxevthandler}\\
23\helpref{wxObject}{wxobject}
24
25\wxheading{Include files}
26
27<wx/toplevel.h>
28
a7af285d
VZ
29\wxheading{Library}
30
31\helpref{wxCore}{librarieslist}
32
834ed994
VZ
33
34\latexignore{\rtfignore{\wxheading{Members}}}
35
07880314 36\membersection{wxTopLevelWindow::CanSetTransparent}\label{wxtoplevelwindowcansettransparent}
50f3c41d 37
07880314 38\func{virtual bool}{CanSetTransparent}{\void}
50f3c41d
RD
39
40Returns \true if the platform supports making the window translucent.
41
42\wxheading{See also}
43
07880314 44\helpref{wxTopLevelWindow::SetTransparent}{wxtoplevelwindowsettransparent}
50f3c41d 45
834ed994 46
b13ffca1
RR
47\membersection{wxTopLevelWindow::EnableCloseButton}\label{wxtoplevelenableclosebutton}
48
49\func{bool}{EnableCloseButton}{\param{bool}{ enable = true}}
50
51Enables or disables the Close button (most often in the right
52upper corner of a dialog) and the Close entry of the system
53menu (most often in the left upper corner of the dialog).
a43ec16b
RR
54Currently only implemented for wxMSW and wxGTK. Returns
55true if operation was successful. This may be wrong on
56X11 (including GTK+) where the window manager may not support
57this operation and there is no way to find out.
b13ffca1 58
4334c3d5
VZ
59\membersection{wxTopLevelWindow::GetDefaultItem}\label{wxtoplevelwindowgetdefaultitem}
60
61\constfunc{wxWindow *}{GetDefaultItem}{\void}
62
63Returns a pointer to the button which is the default for this window, or \NULL.
64The default button is the one activated by pressing the Enter key.
65
66
5a8e93c4
VZ
67\membersection{wxTopLevelWindow::GetIcon}\label{wxtoplevelwindowgeticon}
68
69\constfunc{const wxIcon\&}{GetIcon}{\void}
70
71Returns the standard icon of the window. The icon will be invalid if it hadn't
72been previously set by \helpref{SetIcon}{wxtoplevelwindowseticon}.
73
74\wxheading{See also}
75
76\helpref{GetIcons}{wxtoplevelwindowgeticons}
77
78
79\membersection{wxTopLevelWindow::GetIcons}\label{wxtoplevelwindowgeticons}
80
81\constfunc{const wxIconBundle\&}{GetIcons}{\void}
82
83Returns all icons associated with the window, there will be none of them if
60fef964 84neither \helpref{SetIcon}{wxtoplevelwindowseticon} nor
5a8e93c4
VZ
85\helpref{SetIcons}{wxtoplevelwindowseticons} had been called before.
86
87Use \helpref{GetIcon}{wxtoplevelwindowgeticon} to get the main icon of the
88window.
89
90\wxheading{See also}
91
92\helpref{wxIconBundle}{wxiconbundle}
93
94
834ed994
VZ
95\membersection{wxTopLevelWindow::GetTitle}\label{wxtoplevelwindowgettitle}
96
97\constfunc{wxString}{GetTitle}{\void}
98
99Gets a string containing the window title.
100
60fef964
WS
101\wxheading{See also}
102
103\helpref{wxTopLevelWindow::SetTitle}{wxtoplevelwindowsettitle}
834ed994
VZ
104
105
08b97268
WS
106\membersection{wxTopLevelWindow::HandleSettingChange}\label{wxtoplevelwindowhandlesettingchange}
107
108\func{virtual bool}{HandleSettingChange}{\param{WXWPARAM}{ wParam}, \param{WXLPARAM}{ lParam}}
109
110Unique to the wxWinCE port. Responds to showing/hiding SIP (soft input panel) area and resize
394b206f 111window accordingly. Override this if you want to avoid resizing or do additional
08b97268
WS
112operations.
113
114
6b30a44e
VZ
115\membersection{wxTopLevelWindow::IsActive}\label{wxtoplevelwindowisactive}
116
117\constfunc{bool}{IsActive}{\void}
118
119Returns \true if this window is currently active, i.e. if the user is currently
120working with it.
121
122
979a0320
WS
123\membersection{wxTopLevelWindow::IsAlwaysMaximized}\label{wxtoplevelwindowisalwaysmaximized}
124
125\constfunc{virtual bool}{IsAlwaysMaximized}{\void}
126
127Returns \true if this window is expected to be always maximized, either due to platform policy
128or due to local policy regarding particular class.
129
130
834ed994
VZ
131\membersection{wxTopLevelWindow::Iconize}\label{wxtoplevelwindowiconize}
132
133\func{void}{Iconize}{\param{bool}{ iconize}}
134
135Iconizes or restores the window.
136
137\wxheading{Parameters}
138
139\docparam{iconize}{If \true, iconizes the window; if \false, shows and restores it.}
140
141\wxheading{See also}
142
143\helpref{wxTopLevelWindow::IsIconized}{wxtoplevelwindowisiconized}, \helpref{wxTopLevelWindow::Maximize}{wxtoplevelwindowmaximize}.
144
145
146\membersection{wxTopLevelWindow::IsFullScreen}\label{wxtoplevelwindowisfullscreen}
147
148\func{bool}{IsFullScreen}{\void}
149
150Returns \true if the window is in fullscreen mode.
151
152\wxheading{See also}
153
154\helpref{wxTopLevelWindow::ShowFullScreen}{wxtoplevelwindowshowfullscreen}
155
156
157\membersection{wxTopLevelWindow::IsIconized}\label{wxtoplevelwindowisiconized}
158
159\constfunc{bool}{IsIconized}{\void}
160
161Returns \true if the window is iconized.
162
163
164\membersection{wxTopLevelWindow::IsMaximized}\label{wxtoplevelwindowismaximized}
165
166\constfunc{bool}{IsMaximized}{\void}
167
168Returns \true if the window is maximized.
169
170
f491be10 171\membersection{wxTopLevelWindow::IsUsingNativeDecorations}\label{wxtoplevelwindowisusingnativedecorations}
b48f51ca
VZ
172
173\constfunc{bool}{IsUsingNativeDecorations}{\void}
174
175\bftt{This method is specific to wxUniversal port}
176
177Returns \true if this window is using native decorations, \false if we draw
178them ourselves.
179
180\wxheading{See also}
181
182\helpref{UseNativeDecorations}{wxtoplevelwindowusenativedecorations},\\
183\helpref{UseNativeDecorationsByDefault}{wxtoplevelwindowusenativedecorationsbydefault}
184
185
834ed994
VZ
186\membersection{wxTopLevelWindow::Maximize}\label{wxtoplevelwindowmaximize}
187
188\func{void}{Maximize}{\param{bool }{maximize}}
189
190Maximizes or restores the window.
191
192\wxheading{Parameters}
193
194\docparam{maximize}{If \true, maximizes the window, otherwise it restores it.}
195
834ed994
VZ
196\wxheading{See also}
197
198\helpref{wxTopLevelWindow::Iconize}{wxtoplevelwindowiconize}
199
200
dc92adaf
VZ
201\membersection{wxTopLevelWindow::RequestUserAttention}\label{wxtoplevelwindowrequestuserattention}
202
203\func{void}{RequestUserAttention}{\param{int }{flags = wxUSER\_ATTENTION\_INFO}}
204
205Use a system-dependent way to attract users attention to the window when it is
206in background.
207
208\arg{flags} may have the value of either \texttt{wxUSER\_ATTENTION\_INFO}
209(default) or \texttt{wxUSER\_ATTENTION\_ERROR} which results in a more drastic
210action. When in doubt, use the default value.
211
212Note that this function should normally be only used when the application is
213not already in foreground.
214
dca92ddf
MR
215This function is currently implemented for Win32 where it flashes the
216window icon in the taskbar, and for wxGTK with task bars supporting it.
dc92adaf
VZ
217
218
4334c3d5
VZ
219\membersection{wxTopLevelWindow::SetDefaultItem}\label{wxtoplevelwindowsetdefaultitem}
220
221\func{void}{SetDefaultItem}{\param{wxWindow }{*win}}
222
223Changes the default item for the panel, usually \arg{win} is a button.
224
225\wxheading{See also}
226
227\helpref{GetDefaultItem}{wxtoplevelwindowgetdefaultitem}
228
229
834ed994
VZ
230\membersection{wxTopLevelWindow::SetIcon}\label{wxtoplevelwindowseticon}
231
232\func{void}{SetIcon}{\param{const wxIcon\& }{icon}}
233
234Sets the icon for this window.
235
236\wxheading{Parameters}
237
238\docparam{icon}{The icon to associate with this window.}
239
240\wxheading{Remarks}
241
242The window takes a `copy' of {\it icon}, but since it uses reference
243counting, the copy is very quick. It is safe to delete {\it icon} after
244calling this function.
245
246See also \helpref{wxIcon}{wxicon}.
247
248
249\membersection{wxTopLevelWindow::SetIcons}\label{wxtoplevelwindowseticons}
250
251\func{void}{SetIcons}{\param{const wxIconBundle\& }{icons}}
252
5a8e93c4
VZ
253Sets several icons of different sizes for this window: this allows to use
254different icons for different situations (e.g. task switching bar, taskbar,
255window title bar) instead of scaling, with possibly bad looking results, the
256only icon set by \helpref{SetIcon}{wxtoplevelwindowseticon}.
834ed994
VZ
257
258\wxheading{Parameters}
259
260\docparam{icons}{The icons to associate with this window.}
261
5a8e93c4
VZ
262\wxheading{See also}
263
264\helpref{wxIconBundle}{wxiconbundle}.
834ed994
VZ
265
266
9ca7505f
WS
267\membersection{wxTopLevelWindow::SetLeftMenu}\label{wxtoplevelwindowsetleftmenu}
268
7c57ddc3 269\func{void}{SetLeftMenu}{\param{int}{ id = wxID\_ANY}, \param{const wxString\&}{ label = wxEmptyString}, \param{wxMenu *}{ subMenu = NULL}}
9ca7505f
WS
270
271Sets action or menu activated by pressing left hardware button on the smart phones.
272Unavailable on full keyboard machines.
273
274\wxheading{Parameters}
275
276\docparam{id}{Identifier for this button.}
277
278\docparam{label}{Text to be displayed on the screen area dedicated to this hardware button.}
279
280\docparam{subMenu}{The menu to be opened after pressing this hardware button.}
281
282\wxheading{See also}
283
284\helpref{wxTopLevelWindow::SetRightMenu}{wxtoplevelwindowsetrightmenu}.
285
286
a1b05a60
RR
287\membersection{wxTopLevelWindow::SetMaxSize}\label{wxtoplevelwindowsetmaxsize}
288
289\func{void}{SetMaxSize}{\param{const wxSize\& }{size}}
290
291A simpler interface for setting the size hints than
292\helpref{SetSizeHints}{wxtoplevelwindowsetsizehints}.
293
294\membersection{wxTopLevelWindow::SetMinSize}\label{wxtoplevelwindowsetminsize}
295
296\func{void}{SetMinSize}{\param{const wxSize\& }{size}}
297
298A simpler interface for setting the size hints than
299\helpref{SetSizeHints}{wxtoplevelwindowsetsizehints}.
300
9379c0d7
RR
301\membersection{wxTopLevelWindow::SetSizeHints}\label{wxtoplevelwindowsetsizehints}
302
303\func{virtual void}{SetSizeHints}{\param{int}{ minW}, \param{int}{ minH}, \param{int}{ maxW=-1}, \param{int}{ maxH=-1},
304 \param{int}{ incW=-1}, \param{int}{ incH=-1}}
305
306\func{void}{SetSizeHints}{\param{const wxSize\&}{ minSize},
307\param{const wxSize\&}{ maxSize=wxDefaultSize}, \param{const wxSize\&}{ incSize=wxDefaultSize}}
308
309Allows specification of minimum and maximum window sizes, and window size increments.
310If a pair of values is not set (or set to -1), the default values will be used.
311
d6c11fa9 312\docparam{incW}{Specifies the increment for sizing the width (GTK/Motif/Xt only).}
9379c0d7 313
d6c11fa9 314\docparam{incH}{Specifies the increment for sizing the height (GTK/Motif/Xt only).}
9379c0d7 315
d6c11fa9 316\docparam{incSize}{Increment size (GTK/Motif/Xt only).}
9379c0d7
RR
317
318\wxheading{Remarks}
319
320If this function is called, the user will not be able to size the window outside
d6c11fa9 321the given bounds. The resizing increments are only significant under GTK, Motif or Xt.
9379c0d7
RR
322
323
9ca7505f
WS
324\membersection{wxTopLevelWindow::SetRightMenu}\label{wxtoplevelwindowsetrightmenu}
325
7c57ddc3 326\func{void}{SetRightMenu}{\param{int}{ id = wxID\_ANY}, \param{const wxString\&}{ label = wxEmptyString}, \param{wxMenu *}{ subMenu = NULL}}
9ca7505f
WS
327
328Sets action or menu activated by pressing right hardware button on the smart phones.
329Unavailable on full keyboard machines.
330
331\wxheading{Parameters}
332
333\docparam{id}{Identifier for this button.}
334
335\docparam{label}{Text to be displayed on the screen area dedicated to this hardware button.}
336
337\docparam{subMenu}{The menu to be opened after pressing this hardware button.}
338
339\wxheading{See also}
340
341\helpref{wxTopLevelWindow::SetLeftMenu}{wxtoplevelwindowsetleftmenu}.
342
343
834ed994
VZ
344\membersection{wxTopLevelWindow::SetShape}\label{wxtoplevelwindowsetshape}
345
346\func{bool}{SetShape}{\param{const wxRegion\&}{ region}}
347
348If the platform supports it, sets the shape of the window to that
349depicted by {\it region}. The system will not display or
350respond to any mouse event for the pixels that lie outside of the
351region. To reset the window to the normal rectangular shape simply
60fef964 352call {\it SetShape} again with an empty region. Returns true if the
834ed994
VZ
353operation is successful.
354
355
356\membersection{wxTopLevelWindow::SetTitle}\label{wxtoplevelwindowsettitle}
357
358\func{virtual void}{SetTitle}{\param{const wxString\& }{ title}}
359
360Sets the window title.
361
362\wxheading{Parameters}
363
364\docparam{title}{The window title.}
365
366\wxheading{See also}
367
368\helpref{wxTopLevelWindow::GetTitle}{wxtoplevelwindowgettitle}
369
370
07880314 371\membersection{wxTopLevelWindow::SetTransparent}\label{wxtoplevelwindowsettransparent}
50f3c41d 372
07880314 373\func{virtual bool}{SetTransparent}{\param{int }{ alpha}}
50f3c41d
RD
374
375If the platform supports it will set the window to be translucent
376
377\wxheading{Parameters}
378
379\docparam{alpha}{Determines how opaque or transparent the window will
07880314
RD
380 be, if the platform supports the opreration. A value of 0 sets the
381 window to be fully transparent, and a value of 255 sets the window
382 to be fully opaque.}
50f3c41d 383
07880314 384Returns \true if the transparency was successfully changed.
50f3c41d
RD
385
386
387
65afac3f
VZ
388\membersection{wxTopLevelWindow::ShouldPreventAppExit}\label{wxtoplevelwindowshouldpreventappexit}
389
390\constfunc{virtual bool}{ShouldPreventAppExit}{\void}
391
392This virtual function is not meant to be called directly but can be overridden
393to return \false (it returns \true by default) to allow the application to
394close even if this, presumably not very important, window is still opened.
395By default, the application stays alive as long as there are any open top level
396windows.
397
398
834ed994
VZ
399\membersection{wxTopLevelWindow::ShowFullScreen}\label{wxtoplevelwindowshowfullscreen}
400
401\func{bool}{ShowFullScreen}{\param{bool}{ show}, \param{long}{ style = wxFULLSCREEN\_ALL}}
402
403Depending on the value of {\it show} parameter the window is either shown full
404screen or restored to its normal state. {\it style} is a bit list containing
405some or all of the following values, which indicate what elements of the window
406to hide in full-screen mode:
407
408\begin{itemize}\itemsep=0pt
409\item wxFULLSCREEN\_NOMENUBAR
410\item wxFULLSCREEN\_NOTOOLBAR
411\item wxFULLSCREEN\_NOSTATUSBAR
412\item wxFULLSCREEN\_NOBORDER
413\item wxFULLSCREEN\_NOCAPTION
414\item wxFULLSCREEN\_ALL (all of the above)
415\end{itemize}
416
417This function has not been tested with MDI frames.
418
419Note that showing a window full screen also actually
420\helpref{Show()s}{wxwindowshow} if it hadn't been shown yet.
421
422\wxheading{See also}
423
424\helpref{wxTopLevelWindow::IsFullScreen}{wxtoplevelwindowisfullscreen}
b48f51ca
VZ
425
426
427\membersection{wxTopLevelWindow::UseNativeDecorations}\label{wxtoplevelwindowusenativedecorations}
428
429\func{void}{UseNativeDecorations}{\param{bool }{native = \true}}
430
431\bftt{This method is specific to wxUniversal port}
432
433Use native or custom-drawn decorations for this window only. Notice that to
434have any effect this method must be called before really creating the window,
435i.e. two step creation must be used:
436\begin{verbatim}
437 MyFrame *frame = new MyFrame; // use default ctor
438 frame->UseNativeDecorations(false); // change from default "true"
439 frame->Create(parent, title, ...); // really create the frame
440\end{verbatim}
441
442\wxheading{See also}
443
444\helpref{UseNativeDecorationsByDefault}{wxtoplevelwindowusenativedecorationsbydefault},\\
445\helpref{IsUsingNativeDecorations}{wxtoplevelwindowisusingnativedecorations}
446
447
448\membersection{wxTopLevelWindow::UseNativeDecorationsByDefault}\label{wxtoplevelwindowusenativedecorationsbydefault}
449
450\func{void}{UseNativeDecorationsByDefault}{\param{bool }{native = \true}}
451
452\bftt{This method is specific to wxUniversal port}
453
454Top level windows in wxUniversal port can use either system-provided window
455decorations (i.e. title bar and various icons, buttons and menus in it) or draw
456the decorations themselves. By default the system decorations are used if they
457are available, but this method can be called with \arg{native} set to \false to
458change this for all windows created after this point.
459
460Also note that if \texttt{WXDECOR} environment variable is set, then custom
461decorations are used by default and so it may make sense to call this method
462with default argument if the application can't use custom decorations at all
463for some reason.
464
465\wxheading{See also}
466
467\helpref{UseNativeDecorations}{wxtoplevelwindowusenativedecorations}
b67a86d5 468