X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f6bcfd974ef26faf6f91a62cac09827e09463fd1..4179da8a81ee3110e2a8b5615e1a4f8c8b75a16b:/docs/latex/wx/tconstr.tex diff --git a/docs/latex/wx/tconstr.tex b/docs/latex/wx/tconstr.tex index 35cf9baeb4..32ea2bf62e 100644 --- a/docs/latex/wx/tconstr.tex +++ b/docs/latex/wx/tconstr.tex @@ -2,8 +2,10 @@ Classes: \helpref{wxLayoutConstraints}{wxlayoutconstraints}, \helpref{wxIndividualLayoutConstraint}{wxindividuallayoutconstraint}. -Objects of class wxLayoutConstraint can be associated with a window to define the -way its subwindows are laid out, with respect to their siblings or parent. +{\bf Note:} constraints are now deprecated and you should use \helpref{sizers}{sizeroverview} instead. + +Objects of class wxLayoutConstraint can be associated with a window to define +the way it is laid out, with respect to its siblings or the parent. The class consists of the following eight constraints of class wxIndividualLayoutConstraint, some or all of which should be accessed directly to set the appropriate @@ -34,11 +36,14 @@ label). The constrains calculation is done in \helpref{wxWindow::Layout}{wxwindowlayout} function which evaluates constraints. To call it you can either call -wxWindow::SetAutoLayout to tell default OnSize handlers to call Layout -automatically whenever the window size changes, or override OnSize and call Layout -yourself. +\helpref{wxWindow::SetAutoLayout}{wxwindowsetautolayout} if the parent window +is a frame, panel or a dialog to tell default OnSize handlers to call Layout +automatically whenever the window size changes, or override OnSize and call +Layout yourself (note that you do have to call +\helpref{Layout}{wxwindowlayout} yourself if the parent window is not a +frame, panel or dialog). -\subsection{Constraint layout: more detail} +\subsection{Constraint layout: more details}\label{constraintlayoutdetails} By default, windows do not have a wxLayoutConstraints object. In this case, much layout must be done explicitly, by performing calculations in OnSize members, except @@ -52,13 +57,13 @@ This object contains a constraint for each of the window edges, two for the cent and two for the window size. By setting some or all of these constraints appropriately, the user can achieve quite complex layout by defining relationships between windows. -In wxWindows, each window can be constrained relative to either its {\it +In wxWidgets, each window can be constrained relative to either its {\it siblings} on the same window, or the {\it parent}. The layout algorithm therefore operates in a top-down manner, finding the correct layout for the children of a window, then the layout for the grandchildren, and so on. Note that this differs markedly from native Motif layout, where constraints can ripple upwards and can eventually change the frame -window or dialog box size. We assume in wxWindows that the {\it user} is +window or dialog box size. We assume in wxWidgets that the {\it user} is always `boss' and specifies the size of the outer window, to which subwindows must conform. Obviously, this might be a limitation in some circumstances, but it suffices for most situations, and the @@ -92,7 +97,7 @@ natural left-to-right order. \subsection{Window layout examples}\label{layoutexamples} -\subsubsection{Example 1: subwindow layout} +\subsubsection{Example 1: subwindow layout}\label{subwindowlayoutexample} This example specifies a panel and a window side by side, with a text subwindow below it. @@ -132,7 +137,7 @@ with a text subwindow below it. frame->text_window->SetConstraints(c3); \end{verbatim} -\subsubsection{Example 2: panel item layout} +\subsubsection{Example 2: panel item layout}\label{panelitemlayoutexample} This example sizes a button width to 80 percent of the panel width, and centres it horizontally. A listbox and multitext item are placed below it. The listbox