]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/tdialog.tex
removed unneeded wxWeakRefDynamic::AssignCopy() (last part of patch 1870445)
[wxWidgets.git] / docs / latex / wx / tdialog.tex
CommitLineData
a660d684
KB
1\section{wxDialog overview}\label{wxdialogoverview}
2
3aa8e4ea 3Classes: \helpref{wxDialog}{wxdialog}, \helpref{wxDialogLayoutAdapter}{wxdialoglayoutadapter}
a660d684
KB
4
5A dialog box is similar to a panel, in that it is a window which can
6be used for placing controls, with the following exceptions:
7
8\begin{enumerate}
9\item A surrounding frame is implicitly created.
10\item Extra functionality is automatically given to the dialog box,
11 such as tabbing between items (currently Windows only).
12\item If the dialog box is {\it modal}, the calling program is blocked
13 until the dialog box is dismissed.
14\end{enumerate}
15
a660d684
KB
16For a set of dialog convenience functions, including file selection, see
17\rtfsp\helpref{Dialog functions}{dialogfunctions}.
18
3aa8e4ea
JS
19See also \helpref{wxTopLevelWindow}{wxtoplevelwindow} and \helpref{wxWindow}{wxwindow} for inherited
20member functions. Validation of data in controls is covered in \helpref{Validator overview}{validatoroverview}.
21
22\subsection{Automatic scrolling dialogs}\label{autoscrollingdialogs}
23
24As an ever greater variety of mobile hardware comes to market, it becomes more imperative for wxWidgets applications to adapt
25to these platforms without putting too much burden on the programmer. One area where wxWidgets can help is in adapting
26dialogs for the lower resolution screens that inevitably accompany a smaller form factor. wxDialog therefore supplies
27a global \helpref{wxDialogLayoutAdapter}{wxdialoglayoutadapter} class that implements automatic scrolling adaptation for most sizer-based custom dialogs.
28Many applications should therefore be able to adapt to small displays with little or no work, as far as dialogs are concerned.
29
30By default this adaptation is off. To switch scrolling adaptation on globally in your application, call the static function\rtfsp
31\helpref{wxDialog::EnableLayoutAdaptation}{wxdialogenablelayoutadaptation} passing \true. You can also adjust adaptation on a per-dialog basis by calling\rtfsp
32\helpref{wxDialog::SetLayoutAdaptationMode}{wxdialogsetlayoutadaptationmode} with one of {\tt wxDIALOG\_ADAPTATION\_MODE\_DEFAULT} (use the global setting), {\tt wxDIALOG\_ADAPTATION\_MODE\_ENABLED} or {\tt wxDIALOG\_ADAPTATION\_MODE\_DISABLED}.
33The last two modes override the global adaptation setting.
34
35With adaptation enabled, if the display size is too small for the dialog, wxWidgets (or rather the
36standard adapter class wxStandardDialogLayoutAdapter) will
37make part of the dialog scrolling, leaving standard buttons in a non-scrolling part at the bottom of the dialog.
38
39This is done as follows, in \helpref{wxDialogLayoutAdapter::DoLayoutAdaptation}{wxdialoglayoutadapterdolayoutadaptation} called from within wxDialog::Show or wxDialog::ShowModal:
40
41\begin{enumerate}
42\item If \helpref{wxDialog::GetContentWindow}{wxdialoggetcontentwindow} returns a window derived from wxBookCtrlBase, the pages are made scrollable and
43no other adaptation is done.
44\item wxWidgets looks for a \helpref{wxStdDialogButtonSizer}{wxstddialogbuttonsizer} and uses it for the non-scrolling part.
45\item If that search failed, wxWidgets looks for a horizontal \helpref{wxBoxSizer}{wxboxsizer} with one or more
46standard buttons, with identifiers such as {\tt wxID\_OK} and {\tt wxID\_CANCEL}.
47\item If that search failed too, wxWidgets finds 'loose' standard buttons (in any kind of sizer) and adds them to a \helpref{wxStdDialogButtonSizer}{wxstddialogbuttonsizer}.
48If no standard buttons were found, the whole dialog content will scroll.
49\item All the children apart from standard buttons are reparented onto a new \helpref{wxScrolledWindow}{wxscrolledwindow} object,
50using the old top-level sizer for the scrolled window and creating a new top-level sizer to lay out the scrolled window and
51standard button sizer.
52\end{enumerate}
53
54\wxheading{Customising scrolling adaptation}
55
56In addition to switching adaptation on and off globally and per dialog, you can choose how aggressively wxWidgets will
57search for standard buttons by setting \helpref{wxDialog::SetLayoutAdaptationLevel}{wxdialogsetlayoutadaptationlevel}. By default,
58all the steps described above will be performed but by setting the level to 1, for example, you can choose to only look for wxStdDialogButtonSizer.
59
60You can use \helpref{wxDialog::AddMainButtonId}{wxdialogaddmainbuttonid} to add identifiers for buttons that should also be
61treated as standard buttons for the non-scrolling area.
62
63You can derive your own class from \helpref{wxDialogLayoutAdapter}{wxdialoglayoutadapter} or wxStandardDialogLayoutAdapter and call\rtfsp
64\helpref{wxDialog::SetLayoutAdapter}{wxdialogsetlayoutadapter}, deleting the old object that this function returns. Override
65the functions CanDoLayoutAdaptation and DoLayoutAdaptation to test for adaptation applicability and perform the adaptation.
66
67You can also override \helpref{wxDialog::CanDoLayoutAdaptation}{wxdialogcandolayoutadaptation} and \helpref{wxDialog::DoLayoutAdaptation}{wxdialogdolayoutadaptation} in a class derived from wxDialog.
68
69\wxheading{Situations where automatic scrolling adaptation may fail}
70
71Because adaptation rearranges your sizer and window hierarchy, it is not fool-proof, and may fail in the following situations.
72
73\begin{itemize}
74\item The dialog doesn't use sizers.
75\item The dialog implementation makes assumptions about the window hierarchy, for example getting the parent of a control and casting to the dialog class.
76\item The dialog does custom painting and/or event handling not handled by the scrolled window. If this problem can be solved globally,
77you can derive a new adapter class from wxStandardDialogLayoutAdapter and override its CreateScrolledWindow function to return an instance of your own class.
78\item The dialog has unusual layout, for example a vertical sizer containing a mixture of standard buttons and other controls.
79\item The dialog makes assumptions about the sizer hierarchy, for example to show or hide children of the top-level sizer. However, the original sizer hierarchy will still hold
80until Show or ShowModal is called.
81\end{itemize}
82
83You can help make sure that your dialogs will continue to function after adaptation by:
84
85\begin{itemize}
86\item avoiding the above situations and assumptions;
87\item using \helpref{wxStdDialogButtonSizer}{wxstddialogbuttonsizer};
88\item only making assumptions about hierarchy immediately after the dialog is created;
89\item using an intermediate sizer under the main sizer, a false top-level sizer that can be relied on to exist
90for the purposes of manipulating child sizers and windows;
91\item overriding \helpref{wxDialog::GetContentWindow}{wxdialoggetcontentwindow} to return a book control if your dialog implements pages: wxWidgets will then only make the pages
92scrollable.
93\end{itemize}
94
95\wxheading{wxPropertySheetDialog and wxWizard}
a660d684 96
3aa8e4ea
JS
97Adaptation for wxPropertySheetDialog is always done by simply making the pages scrollable, since \helpref{wxDialog::GetContentWindow}{wxdialoggetcontentwindow} returns
98the dialog's book control and this is handled by the standard layout adapter.
a660d684 99
3aa8e4ea 100wxWizard uses its own CanDoLayoutAdaptation and DoLayoutAdaptation functions rather than the global adapter: again, only the wizard pages are made scrollable.
a660d684 101