]> git.saurik.com Git - wxWidgets.git/blame - utils/dialoged/docs/body.tex
tests for sorted wxChoice added
[wxWidgets.git] / utils / dialoged / docs / body.tex
CommitLineData
a660d684
KB
1\chapter{Introduction}\label{introduction}
2\pagenumbering{arabic}%
3\setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
4\setfooter{\thepage}{}{}{}{}{\thepage}%
5
6The wxWindows Dialog Editor is a tool for creating dialog resource files, in {\tt .wxr} format.
7It differs from wxBuilder in the following respectes:
8
9\begin{enumerate}\itemsep=0pt
10\item Scope. It is written for dialog editing only, and is therefore more convenient than wxBuilder for this purpose.
11\item File format. Dialog editor reads and writes wxWindows resource files (extension {\tt .wxr}) and has
12no independent file format.
13\item Robustness. It is written in a more principled way than wxBuilder, and is less ambitious.
14\item Ease of use. Windows are edited using the mouse or via consistent {\it property editors}, which
15provide immediate visual feedback of changed properties.
16\end{enumerate}
17
e3a43801 18Dialog Editor 2.0 should be compiled and used with wxWindows 2.0.
a660d684
KB
19
20\section{Current status}
21
e3a43801
JS
22Dialog Editor currently runs under wxMSW and wxGTK. It has yet to
23be tested under wxMotif.
a660d684
KB
24
25\section{Future developments}
26
27\begin{itemize}\itemsep=0pt
e3a43801 28\item Motif compilation.
a660d684
KB
29\item It would be nice to have a dialog browser, showing thumbnails of
30all dialogs in a particular directory.
31\item Maybe add a menubar editor (from wxBuilder).
32\item Maybe convert Windows .rc files.
33\end{itemize}
34
35\chapter{Commands}\label{commands}
36\setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
37\setfooter{\thepage}{}{}{}{}{\thepage}%
38
39\section{Dialog editor menu bar}
40
41\subsection{File menu}
42
43\begin{twocollist}\itemsep=0pt
a660d684 44\twocolitem{New dialog}{Creates a new dialog resource.}
e3a43801 45\twocolitem{New project}{Creates a new project (clears index and resets project name).}
a660d684
KB
46\twocolitem{Open}{Opens an existing resource file.}
47\twocolitem{Save}{Saves the current resources.}
e3a43801 48\twocolitem{Save As...}{Saves the current resources in a named file.}
a660d684 49\twocolitem{Clear}{Clears the current resources.}
e3a43801 50\twocolitem{Exit}{Exits the program.}
a660d684
KB
51\end{twocollist}
52
53\subsection{Edit menu}
54
55\begin{twocollist}\itemsep=0pt
e3a43801
JS
56\twocolitem{Test Dialog}{Creates the current dialog for test purposes.}
57\twocolitem{Recreate}{Recreates the currently selected control from the underlying resource. This may be necessary
a660d684
KB
58to regenerate items that cannot be changed dynamically, and which have got out of sync with the displayed
59item.}
60\twocolitem{Delete}{Deletes the currently selected resource.}
a660d684
KB
61\end{twocollist}
62
63\subsection{Help menu}
64
65\begin{twocollist}\itemsep=0pt
66\twocolitem{Help topics}{Displays on-line help at the contents page.}
67\twocolitem{About}{Displays an dialog showing the Dialog Editor version and author.}
68\end{twocollist}
69
70\latexonly{\newpage}
71\section{Command toolbar}
72
73The command toolbar consists of the following tools:
74
75\begin{twocollist}%\itemsep=0pt
76\twocolitem{\icon{new.eps}{New}}{Clears the project.}
77\twocolitem{\icon{open.eps}{Open}}{Opens an existing resource file.}
78\twocolitem{\icon{save.eps}{Save}}{Saves the current resources.}
79\twocolitem{\icon{vert.eps}{Horizontal align}}{Aligns the centre of the selected items horizontally.}
80\twocolitem{\icon{alignt.eps}{Horizontal top-align}}{Aligns the top sides of the selected items horizontally.}
81\twocolitem{\icon{alignb.eps}{Horizontal bottom-align}}{Aligns the bottom sides of the selected items horizontally.}
82\twocolitem{\icon{horiz.eps}{Vertical align}}{Aligns the centre of the selected items vertically.}
83\twocolitem{\icon{alignl.eps}{Vertical left-align}}{Aligns the left sides of the selected items vertically.}
84\twocolitem{\icon{alignr.eps}{Vertical right-align}}{Aligns the right sides of the selected items vertically.}
85\twocolitem{\icon{copysize.eps}{Copy size}}{Copies the size of the first selected item to the subsequently selected item(s).}
86\twocolitem{\icon{tofront.eps}{To front}}{Puts the selected item(s) to the front of the display list.}
87\twocolitem{\icon{toback.eps}{To back}}{Puts the selected item(s) to the back of the display list.}
88\twocolitem{\icon{help.eps}{Help}}{Invokes Dialog Editor help.}
89\end{twocollist}
90
91\latexonly{\newpage}
92\section{Tool palette}
93
e3a43801
JS
94The tool palette is used to select a type of control to create on the dialog.
95To create a new control, select a tool with left-click, then left-click on the dialog.
96Select the pointer tool to use left-click for selecting and deselecting
a660d684
KB
97items.
98
e3a43801 99\section{Resource tree}
a660d684 100
e3a43801
JS
101The resource tree shows a list of the dialogs, controls and bitmaps currently loaded
102in Dialog Editor. Double-clicking on an item shows the associated resource.
a660d684
KB
103
104\chapter{Procedures}\label{procedures}
105\setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
106\setfooter{\thepage}{}{}{}{}{\thepage}%
107
108\section{Running Dialog Editor}
109
110To run Dialog Editor under Windows, click on the Program Manager or Explorer icon.
111Under UNIX, run from the command line.
112
113The main window shows a menu bar, command toolbar, tool palette, resource list, and
114status line.
115
116\section{Creating a dialog}
117
118To create a new dialog, click on the {\bf File: New} menu item, or equivalent
e3a43801 119toolbar button. A dialog will appear. To put a control on the dialog, left-click
a660d684
KB
120on the appropriate palette icon and then left-click on the dialog. A new item
121will appear at the place you clicked.
122
e3a43801 123You can edit any control or dialog by control-left clicking. A property editor
a660d684
KB
124will appear, allowing any property to be selected and edited (see \helpref{Using property editors}{propeditors}).
125You can also edit items by right-clicking to show a menu, and then selecting {\it Edit properties}.
126
e3a43801
JS
127To move a control, drag the item with the left mouse button, or edit
128the position values in the property editor. To resize a control, you
a660d684
KB
129can either select it by left-clicking and then dragging on a selection
130handle, or edit the size values in the property editor.
131
132You can delete items from the right-click menu, or by selecting the item and
133choosing {\bf Edit: Delete} from the menu bar.
134
135\section{Using property editors}\label{propeditors}
136
137Property editors consist of a list of properties and current values, plus controls at the top of
138the editor. If the property is of an appropriate type, you can edit the value directly in the
139text field, and confirm or cancel the value using the two buttons to the left of it.
140If the property has a predefined range of values, such as labelFontFamily, you can
141see a list of permissable values by clicking on the button labelled with an ellipsis symbol ({\bf ...}).
142This will show a listbox with possible values and current selection. You may also be able
143to cycle through values by double-clicking the value in the listbox.
144
145Properties may have special editors appropriate to the type. Filename properties invoke
146the file selector, and properties containing list of user-definable strings use a
147string editor.
148
149When you change a property value, this value is immediately reflected in
e3a43801 150the dialog or control. If the item allows this value to be changed
a660d684
KB
151dynamically, the relevant wxWindows function will be called internally
152to effect the change. If the value cannot be changed dynamically, the
153item will be destroyed and re-created, which means that there will be
154more flickering associated with some kinds of property changes than
155others.
156
157\section{Saving and loading files}
158
159Use {\it File: Save} and {\it File: Save as} or the equivalent toolbar button
160to save the current dialog(s) in a wxWindows resource file (extension {\tt .wxr}).
161
162The {\tt .wxr} file can be used directly in a wxWindows program, if
163wxWindows resources have been enabled when building the wxWindows library.
164These files can be loaded dynamically, or included directly into program source
165with a \verb$#include$ directive. See the wxWindows user manual for further details.
166
e3a43801
JS
167\section{Working with identifiers}
168
169Dialog Editor keeps track of identifiers in your resources, and reads and writes an include file of the
170form {\tt name.h} where 'name' is the root name of your {\tt .wxr} file. Dialog Editor
171knows about the predefined identifiers such as wxID\_OK.
172
173When you create a dialog or control, the identifier is initially generated. When you
174edit the identifier via a property editor, you can choose a new name, such as a predefined
175symbol and optionally change the integer assigned to the name (assuming it's not a
176predefined symbol).
177
178When you save the project, the identifier include file is saved as well. Include this file
179in your project so that you can refer to controls and dialogs by identifier rather than
180obscure integers. Note that the {\tt .wxr} file itself can only contain integer ids and not the symbols,
181due to way in which the resource file is loaded.
182
a660d684
KB
183\section{Multi-platform development}
184
e3a43801
JS
185{\tt .wxr} files generated on one environment (e.g. Windows) can be used in another (e.g. GTK).
186If you use default fonts and colouring (set {\bf useSystemDefaults} to True in the dialog properties)
187then the dialog fonts and colours will take on the native values, rather than ones specified in the
188resource. Without this, colours in the dialog resource may not match system colours.
189
190Also, set {\bf useDialogUnits} to True whenever possible since this will cause the dialog
191to be created using a scale based on the current system font size, and will result in dialogs that are
192portable between screen resolutions as well as platforms.
193
194Because the same control can have different sizes on different GUIs,
a660d684
KB
195the user should be cautious in assuming that one resource file will work for all
196platforms. It may be better to plan to conditionally include or load different
197resource files for different platforms, with spacing modified to suit each
e3a43801
JS
198environment. The best thing is to try your dialog resource on several platforms
199and see whether tweaking is required for some platforms.
a660d684 200