]> git.saurik.com Git - wxWidgets.git/blob - docs/latex/wx/category.tex
Source cleaning for new features.
[wxWidgets.git] / docs / latex / wx / category.tex
1 \chapter{Classes by category}\label{classesbycat}
2 \setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
3 \setfooter{\thepage}{}{}{}{}{\thepage}%
4
5 A classification of wxWidgets classes by category.
6
7 {\large {\bf Managed windows}}
8
9 There are several types of window that are directly controlled by the
10 window manager (such as MS Windows, or the Motif Window Manager).
11 Frames and dialogs are similar in wxWidgets, but only dialogs may be modal.
12
13 \twocolwidtha{6cm}
14 \begin{twocollist}\itemsep=0pt
15 \twocolitem{\helpref{wxTopLevelWindow}{wxtoplevelwindow}}{Any top level window, dialog or frame}
16 \twocolitem{\helpref{wxDialog}{wxdialog}}{Dialog box}
17 \twocolitem{\helpref{wxFrame}{wxframe}}{Normal frame}
18 \twocolitem{\helpref{wxMDIChildFrame}{wxmdichildframe}}{MDI child frame}
19 \twocolitem{\helpref{wxMDIParentFrame}{wxmdiparentframe}}{MDI parent frame}
20 \twocolitem{\helpref{wxMiniFrame}{wxminiframe}}{A frame with a small title bar}
21 \twocolitem{\helpref{wxSplashScreen}{wxsplashscreen}}{Splash screen class}
22 \twocolitem{\helpref{wxPropertySheetDialog}{wxpropertysheetdialog}}{Property sheet dialog}
23 %\twocolitem{\helpref{wxTabbedDialog}{wxtabbeddialog}}{Tabbed dialog
24 %(deprecated, use wxNotebook instead)}
25 \twocolitem{\helpref{wxTipWindow}{wxtipwindow}}{Shows text in a small window}
26 \twocolitem{\helpref{wxWizard}{wxwizard}}{A wizard dialog}
27 \end{twocollist}
28
29 See also {\bf Common dialogs}.
30
31 {\large {\bf Miscellaneous windows}}
32
33 The following are a variety of classes that are derived from wxWindow.
34
35 \twocolwidtha{6cm}
36 \begin{twocollist}\itemsep=0pt
37 \twocolitem{\helpref{wxPanel}{wxpanel}}{A window whose colour changes according to current user settings}
38 \twocolitem{\helpref{wxScrolledWindow}{wxscrolledwindow}}{Window with automatically managed scrollbars}
39 \twocolitem{\helpref{wxGrid}{wxgrid}}{A grid (table) window}
40 \twocolitem{\helpref{wxSplitterWindow}{wxsplitterwindow}}{Window which can be split vertically or horizontally}
41 \twocolitem{\helpref{wxStatusBar}{wxstatusbar}}{Implements the status bar on a frame}
42 \twocolitem{\helpref{wxToolBar}{wxtoolbar}}{Toolbar class}
43 %\twocolitem{\helpref{wxTabbedPanel}{wxtabbedpanel}}{Tabbed panel (to be replaced with wxNotebook)}
44 \twocolitem{\helpref{wxNotebook}{wxnotebook}}{Notebook class}
45 \twocolitem{\helpref{wxListbook}{wxlistbook}}{Similar to notebook but using list control}
46 \twocolitem{\helpref{wxChoicebook}{wxchoicebook}}{Similar to notebook but using choice control}
47 \twocolitem{\helpref{wxTreebook}{wxtreebook}}{Similar to notebook but using tree control}
48 \twocolitem{\helpref{wxSashWindow}{wxsashwindow}}{Window with four optional sashes that can be dragged}
49 \twocolitem{\helpref{wxSashLayoutWindow}{wxsashlayoutwindow}}{Window that can be involved in an IDE-like layout arrangement}
50 \twocolitem{\helpref{wxVScrolledWindow}{wxvscrolledwindow}}{As wxScrolledWindow but supports lines of variable height}
51 \twocolitem{\helpref{wxWizardPage}{wxwizardpage}}{A base class for the page in wizard dialog.}
52 \twocolitem{\helpref{wxWizardPageSimple}{wxwizardpagesimple}}{A page in wizard dialog.}
53 \end{twocollist}
54
55 {\large {\bf Common dialogs}}
56
57 \overview{Overview}{commondialogsoverview}
58
59 Common dialogs are ready-made dialog classes which are frequently used
60 in an application.
61
62 \twocolwidtha{6cm}
63 \begin{twocollist}\itemsep=0pt
64 \twocolitem{\helpref{wxDialog}{wxdialog}}{Base class for common dialogs}
65 \twocolitem{\helpref{wxColourDialog}{wxcolourdialog}}{Colour chooser dialog}
66 \twocolitem{\helpref{wxDirDialog}{wxdirdialog}}{Directory selector dialog}
67 \twocolitem{\helpref{wxFileDialog}{wxfiledialog}}{File selector dialog}
68 \twocolitem{\helpref{wxFindReplaceDialog}{wxfindreplacedialog}}{Text search/replace dialog}
69 \twocolitem{\helpref{wxMultiChoiceDialog}{wxmultichoicedialog}}{Dialog to get one or more selections from a list}
70 \twocolitem{\helpref{wxSingleChoiceDialog}{wxsinglechoicedialog}}{Dialog to get a single selection from a list and return the string}
71 \twocolitem{\helpref{wxTextEntryDialog}{wxtextentrydialog}}{Dialog to get a single line of text from the user}
72 \twocolitem{\helpref{wxPasswordEntryDialog}{wxpasswordentrydialog}}{Dialog to get a password from the user}
73 \twocolitem{\helpref{wxFontDialog}{wxfontdialog}}{Font chooser dialog}
74 \twocolitem{\helpref{wxPageSetupDialog}{wxpagesetupdialog}}{Standard page setup dialog}
75 \twocolitem{\helpref{wxPrintDialog}{wxprintdialog}}{Standard print dialog}
76 \twocolitem{\helpref{wxProgressDialog}{wxprogressdialog}}{Progress indication dialog}
77 \twocolitem{\helpref{wxMessageDialog}{wxmessagedialog}}{Simple message box dialog}
78 \twocolitem{\helpref{wxWizard}{wxwizard}}{A wizard dialog.}
79 \end{twocollist}
80
81 {\large {\bf Controls}}
82
83 Typically, these are small windows which provide interaction with the user. Controls
84 that are not static can have \helpref{validators}{wxvalidator} associated with them.
85
86 \twocolwidtha{6cm}
87 \begin{twocollist}\itemsep=0pt
88 \twocolitem{\helpref{wxControl}{wxcontrol}}{The base class for controls}
89 \twocolitem{\helpref{wxButton}{wxbutton}}{Push button control, displaying text}
90 \twocolitem{\helpref{wxBitmapButton}{wxbitmapbutton}}{Push button control, displaying a bitmap}
91 \twocolitem{\helpref{wxToggleButton}{wxtogglebutton}}{A button which stays pressed when clicked by user.}
92 \twocolitem{\helpref{wxCalendarCtrl}{wxcalendarctrl}}{Control showing an entire calendar month}
93 \twocolitem{\helpref{wxCheckBox}{wxcheckbox}}{Checkbox control}
94 \twocolitem{\helpref{wxCheckListBox}{wxchecklistbox}}{A listbox with a checkbox to the left of each item}
95 \twocolitem{\helpref{wxChoice}{wxchoice}}{Choice control (a combobox without the editable area)}
96 \twocolitem{\helpref{wxComboBox}{wxcombobox}}{A choice with an editable area}
97 \twocolitem{\helpref{wxDatePickerCtrl}{wxdatepickerctrl}}{Small date picker control}
98 \twocolitem{\helpref{wxGauge}{wxgauge}}{A control to represent a varying quantity, such as time remaining}
99 \twocolitem{\helpref{wxGenericDirCtrl}{wxgenericdirctrl}}{A control for displaying a directory tree}
100 \twocolitem{\helpref{wxHtmlListBox}{wxhtmllistbox}}{A listbox showing HTML content}
101 \twocolitem{\helpref{wxStaticBox}{wxstaticbox}}{A static, or group box for visually grouping related controls}
102 \twocolitem{\helpref{wxListBox}{wxlistbox}}{A list of strings for single or multiple selection}
103 \twocolitem{\helpref{wxListCtrl}{wxlistctrl}}{A control for displaying lists of strings and/or icons, plus a multicolumn report view}
104 \twocolitem{\helpref{wxListView}{wxlistview}}{A simpler interface ({\it fa\c{c}ade} for wxListCtrl in report mode}
105 \twocolitem{\helpref{wxTextCtrl}{wxtextctrl}}{Single or multiline text editing control}
106 \twocolitem{\helpref{wxTreeCtrl}{wxtreectrl}}{Tree (hierarchy) control}
107 \twocolitem{\helpref{wxScrollBar}{wxscrollbar}}{Scrollbar control}
108 \twocolitem{\helpref{wxSpinButton}{wxspinbutton}}{A spin or `up-down' control}
109 \twocolitem{\helpref{wxSpinCtrl}{wxspinctrl}}{A spin control - i.e. spin button and text control}
110 \twocolitem{\helpref{wxStaticText}{wxstatictext}}{One or more lines of non-editable text}
111 \twocolitem{\helpref{wxHyperlinkCtrl}{wxhyperlinkctrl}}{A static text which opens an URL when clicked}
112 \twocolitem{\helpref{wxStaticBitmap}{wxstaticbitmap}}{A control to display a bitmap}
113 \twocolitem{\helpref{wxRadioBox}{wxradiobox}}{A group of radio buttons}
114 \twocolitem{\helpref{wxRadioButton}{wxradiobutton}}{A round button to be used with others in a mutually exclusive way}
115 \twocolitem{\helpref{wxSlider}{wxslider}}{A slider that can be dragged by the user}
116 \twocolitem{\helpref{wxVListBox}{wxvlistbox}}{A listbox supporting variable height rows}
117 \end{twocollist}
118
119 {\large {\bf Menus}}
120
121 \twocolwidtha{6cm}
122 \begin{twocollist}\itemsep=0pt
123 \twocolitem{\helpref{wxMenu}{wxmenu}}{Displays a series of menu items for selection}
124 \twocolitem{\helpref{wxMenuBar}{wxmenubar}}{Contains a series of menus for use with a frame}
125 \twocolitem{\helpref{wxMenuItem}{wxmenuitem}}{Represents a single menu item}
126 \end{twocollist}
127
128 {\large {\bf Window layout}}
129
130 There are two different systems for laying out windows (and dialogs in particular).
131 One is based upon so-called sizers and it requires less typing, thinking and calculating
132 and will in almost all cases produce dialogs looking equally well on all platforms, the
133 other is based on so-called constraints and is deprecated, though still available.
134
135 \overview{Sizer overview}{sizeroverview} describes sizer-based layout.
136
137 These are the classes relevant to sizer-based layout.
138
139 \twocolwidtha{6cm}
140 \begin{twocollist}\itemsep=0pt
141 \twocolitem{\helpref{wxSizer}{wxsizer}}{Abstract base class}
142 \twocolitem{\helpref{wxGridSizer}{wxgridsizer}}{A sizer for laying out windows in a grid with all fields having the same size}
143 \twocolitem{\helpref{wxFlexGridSizer}{wxflexgridsizer}}{A sizer for laying out windows in a flexible grid}
144 \twocolitem{\helpref{wxGridBagSizer}{wxgridbagsizer}}{Another grid sizer that lets you specify the cell an item is in, and items can span rows and/or columns.}
145 \twocolitem{\helpref{wxBoxSizer}{wxboxsizer}}{A sizer for laying out windows in a row or column}
146 \twocolitem{\helpref{wxStaticBoxSizer}{wxstaticboxsizer}}{Same as wxBoxSizer, but with a surrounding static box}
147 \end{twocollist}
148
149 \overview{Constraints overview}{constraintsoverview} describes constraints-based layout.
150
151 These are the classes relevant to constraints-based window layout.
152
153 \twocolwidtha{6cm}
154 \begin{twocollist}\itemsep=0pt
155 \twocolitem{\helpref{wxIndividualLayoutConstraint}{wxindividuallayoutconstraint}}{Represents a single constraint dimension}
156 \twocolitem{\helpref{wxLayoutConstraints}{wxlayoutconstraints}}{Represents the constraints for a window class}
157 \end{twocollist}
158
159 {\large {\bf Device contexts}}
160
161 \overview{Overview}{dcoverview}
162
163 Device contexts are surfaces that may be drawn on, and provide an
164 abstraction that allows parameterisation of your drawing code
165 by passing different device contexts.
166
167 \twocolwidtha{6cm}
168 \begin{twocollist}\itemsep=0pt
169 \twocolitem{\helpref{wxBufferedDC}{wxbuffereddc}}{A helper device context for double buffered drawing.}
170 \twocolitem{\helpref{wxBufferedPaintDC}{wxbufferedpaintdc}}{A helper device context for double buffered drawing inside \textbf{OnPaint}.}
171 \twocolitem{\helpref{wxClientDC}{wxclientdc}}{A device context to access the client area outside {\bf OnPaint} events}
172 \twocolitem{\helpref{wxPaintDC}{wxpaintdc}}{A device context to access the client area inside {\bf OnPaint} events}
173 \twocolitem{\helpref{wxWindowDC}{wxwindowdc}}{A device context to access the non-client area}
174 \twocolitem{\helpref{wxScreenDC}{wxscreendc}}{A device context to access the entire screen}
175 \twocolitem{\helpref{wxDC}{wxdc}}{The device context base class}
176 \twocolitem{\helpref{wxMemoryDC}{wxmemorydc}}{A device context for drawing into bitmaps}
177 \twocolitem{\helpref{wxMetafileDC}{wxmetafiledc}}{A device context for drawing into metafiles}
178 \twocolitem{\helpref{wxMirrorDC}{wxmirrordc}}{A proxy device context allowing for simple mirroring.}
179 \twocolitem{\helpref{wxPostScriptDC}{wxpostscriptdc}}{A device context for drawing into PostScript files}
180 \twocolitem{\helpref{wxPrinterDC}{wxprinterdc}}{A device context for drawing to printers}
181 \end{twocollist}
182
183 {\large {\bf Graphics device interface}}
184
185 \overview{Bitmaps overview}{wxbitmapoverview}
186
187 These classes are related to drawing on device contexts and windows.
188
189 \twocolwidtha{6cm}
190 \begin{twocollist}\itemsep=0pt
191 \twocolitem{\helpref{wxColour}{wxcolour}}{Represents the red, blue and green elements of a colour}
192 \twocolitem{\helpref{wxDCClipper}{wxdcclipper}}{Wraps the operations of setting and destroying the clipping region}
193 \twocolitem{\helpref{wxBitmap}{wxbitmap}}{Represents a bitmap}
194 \twocolitem{\helpref{wxBrush}{wxbrush}}{Used for filling areas on a device context}
195 \twocolitem{\helpref{wxBrushList}{wxbrushlist}}{The list of previously-created brushes}
196 \twocolitem{\helpref{wxCursor}{wxcursor}}{A small, transparent bitmap representing the cursor}
197 \twocolitem{\helpref{wxFont}{wxfont}}{Represents fonts}
198 \twocolitem{\helpref{wxFontList}{wxfontlist}}{The list of previously-created fonts}
199 \twocolitem{\helpref{wxIcon}{wxicon}}{A small, transparent bitmap for assigning to frames and drawing on device contexts}
200 \twocolitem{\helpref{wxImage}{wximage}}{A platform-independent image class}
201 \twocolitem{\helpref{wxImageList}{wximagelist}}{A list of images, used with some controls}
202 \twocolitem{\helpref{wxMask}{wxmask}}{Represents a mask to be used with a bitmap for transparent drawing}
203 \twocolitem{\helpref{wxPen}{wxpen}}{Used for drawing lines on a device context}
204 \twocolitem{\helpref{wxPenList}{wxpenlist}}{The list of previously-created pens}
205 \twocolitem{\helpref{wxPalette}{wxpalette}}{Represents a table of indices into RGB values}
206 \twocolitem{\helpref{wxRegion}{wxregion}}{Represents a simple or complex region on a window or device context}
207 \twocolitem{\helpref{wxRendererNative}{wxrenderernative}}{Abstracts high-level drawing primitives}
208 \end{twocollist}
209
210 {\large {\bf Events}}
211
212 \overview{Overview}{eventhandlingoverview}
213
214 An event object contains information about a specific event. Event handlers
215 (usually member functions) have a single, event argument.
216
217 \twocolwidtha{6cm}
218 \begin{twocollist}\itemsep=0pt
219 \twocolitem{\helpref{wxActivateEvent}{wxactivateevent}}{A window or application activation event}
220 \twocolitem{\helpref{wxCalendarEvent}{wxcalendarevent}}{Used with \helpref{wxCalendarCtrl}{wxcalendarctrl}}
221 \twocolitem{\helpref{wxCalculateLayoutEvent}{wxcalculatelayoutevent}}{Used to calculate window layout}
222 \twocolitem{\helpref{wxClipboardTextEvent}{wxclipboardtextevent}}{A clipboard copy/cut/paste treebook event event}
223 \twocolitem{\helpref{wxCloseEvent}{wxcloseevent}}{A close window or end session event}
224 \twocolitem{\helpref{wxCommandEvent}{wxcommandevent}}{An event from a variety of standard controls}
225 \twocolitem{\helpref{wxContextMenuEvent}{wxcontextmenuevent}}{An event generated when the user issues a context menu command}
226 \twocolitem{\helpref{wxDateEvent}{wxdateevent}}{Used with \helpref{wxDatePickerCtrl}{wxdatepickerctrl}}
227 \twocolitem{\helpref{wxDialUpEvent}{wxdialupevent}}{Event send by \helpref{wxDialUpManager}{wxdialupmanager}}
228 \twocolitem{\helpref{wxDropFilesEvent}{wxdropfilesevent}}{A drop files event}
229 \twocolitem{\helpref{wxEraseEvent}{wxeraseevent}}{An erase background event}
230 \twocolitem{\helpref{wxEvent}{wxevent}}{The event base class}
231 \twocolitem{\helpref{wxFindDialogEvent}{wxfinddialogevent}}{Event sent by
232 \helpref{wxFindReplaceDialog}{wxfindreplacedialog}}
233 \twocolitem{\helpref{wxFocusEvent}{wxfocusevent}}{A window focus event}
234 \twocolitem{\helpref{wxKeyEvent}{wxkeyevent}}{A keypress event}
235 \twocolitem{\helpref{wxIconizeEvent}{wxiconizeevent}}{An iconize/restore event}
236 \twocolitem{\helpref{wxIdleEvent}{wxidleevent}}{An idle event}
237 \twocolitem{\helpref{wxInitDialogEvent}{wxinitdialogevent}}{A dialog initialisation event}
238 \twocolitem{\helpref{wxJoystickEvent}{wxjoystickevent}}{A joystick event}
239 \twocolitem{\helpref{wxListEvent}{wxlistevent}}{A list control event}
240 \twocolitem{\helpref{wxMaximizeEvent}{wxmaximizeevent}}{A maximize event}
241 \twocolitem{\helpref{wxMenuEvent}{wxmenuevent}}{A menu event}
242 \twocolitem{\helpref{wxMouseCaptureChangedEvent}{wxmousecapturechangedevent}}{A mouse capture changed event}
243 \twocolitem{\helpref{wxMouseEvent}{wxmouseevent}}{A mouse event}
244 \twocolitem{\helpref{wxMoveEvent}{wxmoveevent}}{A move event}
245 \twocolitem{\helpref{wxNotebookEvent}{wxnotebookevent}}{A notebook control event}
246 \twocolitem{\helpref{wxNotifyEvent}{wxnotifyevent}}{A notification event, which can be vetoed}
247 \twocolitem{\helpref{wxPaintEvent}{wxpaintevent}}{A paint event}
248 \twocolitem{\helpref{wxProcessEvent}{wxprocessevent}}{A process ending event}
249 \twocolitem{\helpref{wxQueryLayoutInfoEvent}{wxquerylayoutinfoevent}}{Used to query layout information}
250 \twocolitem{\helpref{wxScrollEvent}{wxscrollevent}}{A scroll event from sliders, stand-alone scrollbars and spin buttons}
251 \twocolitem{\helpref{wxScrollWinEvent}{wxscrollwinevent}}{A scroll event from scrolled windows}
252 \twocolitem{\helpref{wxSizeEvent}{wxsizeevent}}{A size event}
253 \twocolitem{\helpref{wxSocketEvent}{wxsocketevent}}{A socket event}
254 \twocolitem{\helpref{wxSpinEvent}{wxspinevent}}{An event from \helpref{wxSpinButton}{wxspinbutton}}
255 \twocolitem{\helpref{wxSplitterEvent}{wxsplitterevent}}{An event from \helpref{wxSplitterWindow}{wxsplitterwindow}}
256 \twocolitem{\helpref{wxSysColourChangedEvent}{wxsyscolourchangedevent}}{A system colour change event}
257 \twocolitem{\helpref{wxTimerEvent}{wxtimerevent}}{A timer expiration event}
258 \twocolitem{\helpref{wxTreebookEvent}{wxtreebookevent}}{A treebook control event}
259 \twocolitem{\helpref{wxTreeEvent}{wxtreeevent}}{A tree control event}
260 \twocolitem{\helpref{wxUpdateUIEvent}{wxupdateuievent}}{A user interface update event}
261 \twocolitem{\helpref{wxWindowCreateEvent}{wxwindowcreateevent}}{A window creation event}
262 \twocolitem{\helpref{wxWindowDestroyEvent}{wxwindowdestroyevent}}{A window destruction event}
263 \twocolitem{\helpref{wxWizardEvent}{wxwizardevent}}{A wizard event}
264 \end{twocollist}
265
266 {\large {\bf Validators}}
267
268 \overview{Overview}{validatoroverview}
269
270 These are the window validators, used for filtering and validating
271 user input.
272
273 \twocolwidtha{6cm}
274 \begin{twocollist}\itemsep=0pt
275 \twocolitem{\helpref{wxValidator}{wxvalidator}}{Base validator class}
276 \twocolitem{\helpref{wxTextValidator}{wxtextvalidator}}{Text control validator class}
277 \twocolitem{\helpref{wxGenericValidator}{wxgenericvalidator}}{Generic control validator class}
278 \end{twocollist}
279
280 {\large {\bf Data structures}}
281
282 These are the data structure classes supported by wxWidgets.
283
284 \twocolwidtha{6cm}
285 \begin{twocollist}\itemsep=0pt
286 \twocolitem{\helpref{wxCmdLineParser}{wxcmdlineparser}}{Command line parser class}
287 \twocolitem{\helpref{wxDateSpan}{wxdatespan}}{A logical time interval.}
288 \twocolitem{\helpref{wxDateTime}{wxdatetime}}{A class for date/time manipulations}
289 %\twocolitem{\helpref{wxExpr}{wxexpr}}{A class for flexible I/O}
290 %\twocolitem{\helpref{wxExprDatabase}{wxexprdatabase}}{A class for flexible I/O}
291 \twocolitem{\helpref{wxArray}{wxarray}}{A dynamic array implementation}
292 \twocolitem{\helpref{wxArrayString}{wxarraystring}}{An efficient container for storing \helpref{wxString}{wxstring} objects}
293 \twocolitem{\helpref{wxHashMap}{wxhashmap}}{A simple hash map implementation}
294 \twocolitem{\helpref{wxHashSet}{wxhashset}}{A simple hash set implementation}
295 \twocolitem{\helpref{wxHashTable}{wxhashtable}}{A simple hash table implementation (deprecated, use wxHashMap)}
296 % \twocolitem{\helpref{wxHashTableLong}{wxhashtablelong}}{A wxHashTable version for storing long data}
297 \twocolitem{\helpref{wxList}{wxlist}}{A simple linked list implementation}
298 \twocolitem{\helpref{wxLongLong}{wxlonglong}}{A portable 64 bit integer type}
299 \twocolitem{\helpref{wxNode}{wxnode}}{Represents a node in the wxList implementation}
300 \twocolitem{\helpref{wxObject}{wxobject}}{The root class for most wxWidgets classes}
301 \twocolitem{\helpref{wxPathList}{wxpathlist}}{A class to help search multiple paths}
302 \twocolitem{\helpref{wxPoint}{wxpoint}}{Representation of a point}
303 \twocolitem{\helpref{wxRect}{wxrect}}{A class representing a rectangle}
304 \twocolitem{\helpref{wxRegEx}{wxregex}}{Regular expression support}
305 \twocolitem{\helpref{wxRegion}{wxregion}}{A class representing a region}
306 \twocolitem{\helpref{wxString}{wxstring}}{A string class}
307 \twocolitem{\helpref{wxStringTokenizer}{wxstringtokenizer}}{A class for interpreting a string as a list of tokens or words}
308 \twocolitem{\helpref{wxRealPoint}{wxrealpoint}}{Representation of a point using floating point numbers}
309 \twocolitem{\helpref{wxSize}{wxsize}}{Representation of a size}
310 \twocolitem{\helpref{wxTimeSpan}{wxtimespan}}{A time interval.}
311 \twocolitem{\helpref{wxURI}{wxuri}}{Represents a Uniform Resource Identifier}
312 \twocolitem{\helpref{wxVariant}{wxvariant}}{A class for storing arbitrary types that may change at run-time}
313 \end{twocollist}
314
315 {\large {\bf Run-time class information system}}
316
317 \overview{Overview}{runtimeclassoverview}
318
319 wxWidgets supports run-time manipulation of class information, and dynamic
320 creation of objects given class names.
321
322 \twocolwidtha{6cm}
323 \begin{twocollist}\itemsep=0pt
324 \twocolitem{\helpref{wxClassInfo}{wxclassinfo}}{Holds run-time class information}
325 \twocolitem{\helpref{wxObject}{wxobject}}{Root class for classes with run-time information}
326 \twocolitem{\helpref{RTTI macros}{rttimacros}}{Macros for manipulating run-time information}
327 \end{twocollist}
328
329 {\large {\bf Logging features}}
330
331 \overview{Overview}{wxlogoverview}
332
333 wxWidgets provides several classes and functions for message logging.
334 Please see the \helpref{wxLog overview}{wxlogoverview} for more details.
335
336 \twocolwidtha{6cm}
337 \begin{twocollist}\itemsep=0pt
338 \twocolitem{\helpref{wxLog}{wxlog}}{The base log class}
339 \twocolitem{\helpref{wxLogStderr}{wxlogstderr}}{Log messages to a C STDIO stream}
340 \twocolitem{\helpref{wxLogStream}{wxlogstream}}{Log messages to a C++ iostream}
341 \twocolitem{\helpref{wxLogTextCtrl}{wxlogtextctrl}}{Log messages to a \helpref{wxTextCtrl}{wxtextctrl}}
342 \twocolitem{\helpref{wxLogWindow}{wxlogwindow}}{Log messages to a log frame}
343 \twocolitem{\helpref{wxLogGui}{wxloggui}}{Default log target for GUI programs}
344 \twocolitem{\helpref{wxLogNull}{wxlognull}}{Temporarily suppress message logging}
345 \twocolitem{\helpref{wxLogChain}{wxlogchain}}{Allows to chain two log targets}
346 \twocolitem{\helpref{wxLogPassThrough}{wxlogpassthrough}}{Allows to filter the log messages}
347 \twocolitem{\helpref{wxStreamToTextRedirector}{wxstreamtotextredirector}}{Allows
348 to redirect output sent to {\tt cout} to a \helpref{wxTextCtrl}{wxtextctrl}}
349 \twocolitem{\helpref{Log functions}{logfunctions}}{Error and warning logging functions}
350 \end{twocollist}
351
352 {\large {\bf Debugging features}}
353
354 \overview{Overview}{debuggingoverview}
355
356 wxWidgets supports some aspects of debugging an application through
357 classes, functions and macros.
358
359 \twocolwidtha{6cm}
360 \begin{twocollist}\itemsep=0pt
361 \twocolitem{\helpref{wxDebugContext}{wxdebugcontext}}{Provides memory-checking facilities}
362 \twocolitem{\helpref{Debugging macros}{debugmacros}}{Debug macros for assertion and checking}
363 \twocolitem{\helpref{WXDEBUG\_NEW}{debugnew}}{Use this macro to give further debugging information}
364 \twocolitem{\helpref{wxDebugReport}{wxdebugreport}}{Base class for creating debug reports in case of a program crash.}
365 \twocolitem{\helpref{wxDebugReportCompress}{wxdebugreportcompress}}{Class for creating compressed debug reports.}
366 \twocolitem{\helpref{wxDebugReportUpload}{wxdebugreportupload}}{Class for uploading compressed debug reports via HTTP.}
367 \twocolitem{\helpref{wxDebugReportPreview}{wxdebugreportpreview}}{Abstract base class for previewing the contents of a debug report.}
368 \twocolitem{\helpref{wxDebugReportPreviewStd}{wxdebugreportpreviewstd}}{Standard implementation of wxDebugReportPreview.}
369 \end{twocollist}
370
371 {\large {\bf Networking classes}}
372
373 wxWidgets provides its own classes for socket based networking.
374
375 \twocolwidtha{6cm}
376 \begin{twocollist}\itemsep=0pt
377 \twocolitem{\helpref{wxDialUpManager}{wxdialupmanager}}{Provides functions to check the status of network connection and to establish one}
378 \twocolitem{\helpref{wxIPV4address}{wxipv4address}}{Represents an Internet address}
379 \twocolitem{\helpref{wxIPaddress}{wxipaddress}}{Represents an Internet address}
380 \twocolitem{\helpref{wxSocketBase}{wxsocketbase}}{Represents a socket base object}
381 \twocolitem{\helpref{wxSocketClient}{wxsocketclient}}{Represents a socket client}
382 \twocolitem{\helpref{wxSocketServer}{wxsocketserver}}{Represents a socket server}
383 \twocolitem{\helpref{wxSocketEvent}{wxsocketevent}}{A socket event}
384 \twocolitem{\helpref{wxFTP}{wxftp}}{FTP protocol class}
385 \twocolitem{\helpref{wxHTTP}{wxhttp}}{HTTP protocol class}
386 \twocolitem{\helpref{wxURL}{wxurl}}{Represents a Universal Resource Locator}
387 \end{twocollist}
388
389
390 {\large {\bf Interprocess communication}}
391
392 \overview{Overview}{ipcoverview}
393
394 wxWidgets provides simple interprocess communications facilities
395 based on Windows DDE, but available on most platforms using TCP.
396
397 \twocolwidtha{6cm}
398 \begin{twocollist}\itemsep=0pt
399 \twocolitem{\helpref{wxClient}{wxclient}, \helpref{wxDDEClient}{wxddeclient}}{Represents a client}
400 \twocolitem{\helpref{wxConnection}{wxconnection}, \helpref{wxDDEConnection}{wxddeconnection}}{Represents the connection between a client and a server}
401 \twocolitem{\helpref{wxServer}{wxserver}, \helpref{wxDDEServer}{wxddeserver}}{Represents a server}
402 %\twocolitem{\helpref{wxSocketHandler}{wxsockethandler}}{Represents a socket handler}
403 \end{twocollist}
404
405 {\large {\bf Document/view framework}}
406
407 \overview{Overview}{docviewoverview}
408
409 wxWidgets supports a document/view framework which provides
410 housekeeping for a document-centric application.
411
412 \twocolwidtha{6cm}
413 \begin{twocollist}\itemsep=0pt
414 \twocolitem{\helpref{wxDocument}{wxdocument}}{Represents a document}
415 \twocolitem{\helpref{wxView}{wxview}}{Represents a view}
416 \twocolitem{\helpref{wxDocTemplate}{wxdoctemplate}}{Manages the relationship between a document class and a view class}
417 \twocolitem{\helpref{wxDocManager}{wxdocmanager}}{Manages the documents and views in an application}
418 \twocolitem{\helpref{wxDocChildFrame}{wxdocchildframe}}{A child frame for showing a document view}
419 \twocolitem{\helpref{wxDocParentFrame}{wxdocparentframe}}{A parent frame to contain views}
420 %\twocolitem{\helpref{wxMDIDocChildFrame}{wxmdidocchildframe}}{An MDI child frame for showing a document view}
421 %\twocolitem{\helpref{wxMDIDocParentFrame}{wxmdidocparentframe}}{An MDI parent frame to contain views}
422 \end{twocollist}
423
424 {\large {\bf Printing framework}}
425
426 \overview{Overview}{printingoverview}
427
428 A printing and previewing framework is implemented to
429 make it relatively straightforward to provide document printing
430 facilities.
431
432 \twocolwidtha{6cm}
433 \begin{twocollist}\itemsep=0pt
434 \twocolitem{\helpref{wxPreviewFrame}{wxpreviewframe}}{Frame for displaying a print preview}
435 \twocolitem{\helpref{wxPreviewCanvas}{wxpreviewcanvas}}{Canvas for displaying a print preview}
436 \twocolitem{\helpref{wxPreviewControlBar}{wxpreviewcontrolbar}}{Standard control bar for a print preview}
437 \twocolitem{\helpref{wxPrintDialog}{wxprintdialog}}{Standard print dialog}
438 \twocolitem{\helpref{wxPageSetupDialog}{wxpagesetupdialog}}{Standard page setup dialog}
439 \twocolitem{\helpref{wxPrinter}{wxprinter}}{Class representing the printer}
440 \twocolitem{\helpref{wxPrinterDC}{wxprinterdc}}{Printer device context}
441 \twocolitem{\helpref{wxPrintout}{wxprintout}}{Class representing a particular printout}
442 \twocolitem{\helpref{wxPrintPreview}{wxprintpreview}}{Class representing a print preview}
443 \twocolitem{\helpref{wxPrintData}{wxprintdata}}{Represents information about the document being printed}
444 \twocolitem{\helpref{wxPrintDialogData}{wxprintdialogdata}}{Represents information about the print dialog}
445 \twocolitem{\helpref{wxPageSetupDialogData}{wxpagesetupdialogdata}}{Represents information about the page setup dialog}
446 \end{twocollist}
447
448 {\large {\bf Drag and drop and clipboard classes}}
449
450 \overview{Drag and drop and clipboard overview}{wxdndoverview}
451
452 \twocolwidtha{6cm}
453 \begin{twocollist}\itemsep=0pt
454 \twocolitem{\helpref{wxDataObject}{wxdataobject}}{Data object class}
455 \twocolitem{\helpref{wxDataFormat}{wxdataformat}}{Represents a data format}
456 \twocolitem{\helpref{wxTextDataObject}{wxtextdataobject}}{Text data object class}
457 \twocolitem{\helpref{wxFileDataObject}{wxfiledataobject}}{File data object class}
458 \twocolitem{\helpref{wxBitmapDataObject}{wxbitmapdataobject}}{Bitmap data object class}
459 \twocolitem{\helpref{wxCustomDataObject}{wxcustomdataobject}}{Custom data object class}
460 \twocolitem{\helpref{wxClipboard}{wxclipboard}}{Clipboard class}
461 \twocolitem{\helpref{wxDropTarget}{wxdroptarget}}{Drop target class}
462 \twocolitem{\helpref{wxFileDropTarget}{wxfiledroptarget}}{File drop target class}
463 \twocolitem{\helpref{wxTextDropTarget}{wxtextdroptarget}}{Text drop target class}
464 \twocolitem{\helpref{wxDropSource}{wxdropsource}}{Drop source class}
465 \end{twocollist}
466
467 {\large {\bf File related classes}}
468
469 wxWidgets has several small classes to work with disk files, see \helpref{file classes
470 overview}{wxfileoverview} for more details.
471
472 \twocolwidtha{6cm}
473 \begin{twocollist}\itemsep=0pt
474 \twocolitem{\helpref{wxFileName}{wxfilename}}{Operations with the file name and attributes}
475 \twocolitem{\helpref{wxDir}{wxdir}}{Class for enumerating files/subdirectories.}
476 \twocolitem{\helpref{wxDirTraverser}{wxdirtraverser}}{Class used together with wxDir for recursively enumerating the files/subdirectories}
477 \twocolitem{\helpref{wxFile}{wxfile}}{Low-level file input/output class.}
478 \twocolitem{\helpref{wxFFile}{wxffile}}{Another low-level file input/output class.}
479 \twocolitem{\helpref{wxTempFile}{wxtempfile}}{Class to safely replace an existing file}
480 \twocolitem{\helpref{wxTextFile}{wxtextfile}}{Class for working with text files as with arrays of lines}
481 \twocolitem{\helpref{wxStandardPaths}{wxstandardpaths}}{Paths for standard directories}
482 \end{twocollist}
483
484 {\large {\bf Stream classes}}
485
486 wxWidgets has its own set of stream classes, as an alternative to often buggy standard stream
487 libraries, and to provide enhanced functionality.
488
489 \twocolwidtha{6cm}
490 \begin{twocollist}\itemsep=0pt
491 \twocolitem{\helpref{wxStreamBase}{wxstreambase}}{Stream base class}
492 \twocolitem{\helpref{wxStreamBuffer}{wxstreambuffer}}{Stream buffer class}
493 \twocolitem{\helpref{wxInputStream}{wxinputstream}}{Input stream class}
494 \twocolitem{\helpref{wxOutputStream}{wxoutputstream}}{Output stream class}
495 \twocolitem{\helpref{wxCountingOutputStream}{wxcountingoutputstream}}{Stream class for querying what size a stream would have.}
496 \twocolitem{\helpref{wxFilterInputStream}{wxfilterinputstream}}{Filtered input stream class}
497 \twocolitem{\helpref{wxFilterOutputStream}{wxfilteroutputstream}}{Filtered output stream class}
498 \twocolitem{\helpref{wxBufferedInputStream}{wxbufferedinputstream}}{Buffered input stream class}
499 \twocolitem{\helpref{wxBufferedOutputStream}{wxbufferedoutputstream}}{Buffered output stream class}
500 \twocolitem{\helpref{wxMemoryInputStream}{wxmeminputstream}}{Memory input stream class}
501 \twocolitem{\helpref{wxMemoryOutputStream}{wxmemoutputstream}}{Memory output stream class}
502 \twocolitem{\helpref{wxDataInputStream}{wxdatainputstream}}{Platform-independent binary data input stream class}
503 \twocolitem{\helpref{wxDataOutputStream}{wxdataoutputstream}}{Platform-independent binary data output stream class}
504 \twocolitem{\helpref{wxTextInputStream}{wxtextinputstream}}{Platform-independent text data input stream class}
505 \twocolitem{\helpref{wxTextOutputStream}{wxtextoutputstream}}{Platform-independent text data output stream class}
506 \twocolitem{\helpref{wxFileInputStream}{wxfileinputstream}}{File input stream class}
507 \twocolitem{\helpref{wxFileOutputStream}{wxfileoutputstream}}{File output stream class}
508 \twocolitem{\helpref{wxFFileInputStream}{wxffileinputstream}}{Another file input stream class}
509 \twocolitem{\helpref{wxFFileOutputStream}{wxffileoutputstream}}{Another file output stream class}
510 \twocolitem{\helpref{wxTempFileOutputStream}{wxtempfileoutputstream}}{Stream to safely replace an existing file}
511 \twocolitem{\helpref{wxStringInputStream}{wxstringinputstream}}{String input stream class}
512 \twocolitem{\helpref{wxStringOutputStream}{wxstringoutputstream}}{String output stream class}
513 \twocolitem{\helpref{wxZlibInputStream}{wxzlibinputstream}}{Zlib (compression) input stream class}
514 \twocolitem{\helpref{wxZlibOutputStream}{wxzliboutputstream}}{Zlib (compression) output stream class}
515 \twocolitem{\helpref{wxZipInputStream}{wxzipinputstream}}{Input stream for reading from ZIP archives}
516 \twocolitem{\helpref{wxZipOutputStream}{wxzipoutputstream}}{Output stream for writing from ZIP archives}
517 \twocolitem{\helpref{wxSocketInputStream}{wxsocketinputstream}}{Socket input stream class}
518 \twocolitem{\helpref{wxSocketOutputStream}{wxsocketoutputstream}}{Socket output stream class}
519 \end{twocollist}
520
521 {\large {\bf Threading classes}}
522
523 \overview{Multithreading overview}{wxthreadoverview}
524
525 wxWidgets provides a set of classes to make use of the native thread
526 capabilities of the various platforms.
527
528 \twocolwidtha{6cm}
529 \begin{twocollist}\itemsep=0pt
530 \twocolitem{\helpref{wxThread}{wxthread}}{Thread class}
531 \twocolitem{\helpref{wxThreadHelper}{wxthreadhelper}}{Manages background threads easily}
532 \twocolitem{\helpref{wxMutex}{wxmutex}}{Mutex class}
533 \twocolitem{\helpref{wxMutexLocker}{wxmutexlocker}}{Mutex locker utility class}
534 \twocolitem{\helpref{wxCriticalSection}{wxcriticalsection}}{Critical section class}
535 \twocolitem{\helpref{wxCriticalSectionLocker}{wxcriticalsectionlocker}}{Critical section locker utility class}
536 \twocolitem{\helpref{wxCondition}{wxcondition}}{Condition class}
537 \twocolitem{\helpref{wxSemaphore}{wxsemaphore}}{Semaphore class}
538 \end{twocollist}
539
540 {\large {\bf HTML classes}}
541
542 wxWidgets provides a set of classes to display text in HTML format. These
543 class include a help system based on the HTML widget.
544
545 \twocolwidtha{6cm}
546 \begin{twocollist}\itemsep=0pt
547 \twocolitem{\helpref{wxHtmlHelpController}{wxhtmlhelpcontroller}}{HTML help controller class}
548 \twocolitem{\helpref{wxHtmlWindow}{wxhtmlwindow}}{HTML window class}
549 \twocolitem{\helpref{wxHtmlEasyPrinting}{wxhtmleasyprinting}}{Simple class for printing HTML}
550 \twocolitem{\helpref{wxHtmlPrintout}{wxhtmlprintout}}{Generic HTML wxPrintout class}
551 \twocolitem{\helpref{wxHtmlParser}{wxhtmlparser}}{Generic HTML parser class}
552 \twocolitem{\helpref{wxHtmlTagHandler}{wxhtmltaghandler}}{HTML tag handler, pluginable into wxHtmlParser}
553 \twocolitem{\helpref{wxHtmlWinParser}{wxhtmlwinparser}}{HTML parser class for wxHtmlWindow}
554 \twocolitem{\helpref{wxHtmlWinTagHandler}{wxhtmlwintaghandler}}{HTML tag handler, pluginable into wxHtmlWinParser}
555 \end{twocollist}
556
557 {\large {\bf Virtual file system classes}}
558
559 wxWidgets provides a set of classes that implement an extensible virtual file system,
560 used internally by the HTML classes.
561
562 \twocolwidtha{6cm}
563 \begin{twocollist}\itemsep=0pt
564 \twocolitem{\helpref{wxFSFile}{wxfsfile}}{Represents a file in the virtual file system}
565 \twocolitem{\helpref{wxFileSystem}{wxfilesystem}}{Main interface for the virtual file system}
566 \twocolitem{\helpref{wxFileSystemHandler}{wxfilesystemhandler}}{Class used to announce file system type}
567 \end{twocollist}
568
569 {\large {\bf XML-based resource system classes}}
570
571 \overview{XML-based resource system (XRC) overview}{xrcoverview}
572
573 Resources allow your application to create controls and other user interface elements
574 from specifications stored in an XML format.
575
576 \twocolwidtha{6cm}
577 \begin{twocollist}\itemsep=0pt
578 \twocolitem{\helpref{wxXmlResource}{wxxmlresource}}{The main class for working with resources.}
579 \twocolitem{\helpref{wxXmlResourceHandler}{wxxmlresourcehandler}}{The base class for XML resource handlers.}
580 \end{twocollist}
581
582 {\large {\bf Online help}}
583
584 \twocolwidtha{6cm}
585 \begin{twocollist}\itemsep=0pt
586 \twocolitem{\helpref{wxHelpController}{wxhelpcontroller}}{Family of classes for controlling help windows}
587 \twocolitem{\helpref{wxHtmlHelpController}{wxhtmlhelpcontroller}}{HTML help controller class}
588 \twocolitem{\helpref{wxContextHelp}{wxcontexthelp}}{Class to put application into context-sensitive help mode}
589 \twocolitem{\helpref{wxContextHelpButton}{wxcontexthelpbutton}}{Button class for putting application into context-sensitive help mode}
590 \twocolitem{\helpref{wxHelpProvider}{wxhelpprovider}}{Abstract class for context-sensitive help provision}
591 \twocolitem{\helpref{wxSimpleHelpProvider}{wxsimplehelpprovider}}{Class for simple context-sensitive help provision}
592 \twocolitem{\helpref{wxHelpControllerHelpProvider}{wxhelpcontrollerhelpprovider}}{Class for context-sensitive help provision via a help controller}
593 \twocolitem{\helpref{wxToolTip}{wxtooltip}}{Class implementing tooltips}
594 \end{twocollist}
595
596 {\large {\bf Database classes}}
597
598 \overview{Database classes overview}{odbcoverview}
599
600 wxWidgets provides a set of classes for accessing Microsoft's ODBC (Open Database Connectivity)
601 product, donated by Remstar. This is known as wxODBC.
602
603 \twocolwidtha{6cm}
604 \begin{twocollist}\itemsep=0pt
605 \twocolitem{\helpref{wxDb}{wxdb}}{ODBC database connection}
606 \twocolitem{\helpref{wxDbTable}{wxdbtable}}{Provides access to a database table}
607 \twocolitem{\helpref{wxDbInf}{wxdbinf}}{}
608 \twocolitem{\helpref{wxDbTableInf}{wxdbtableinf}}{}
609 \twocolitem{\helpref{wxDbColDef}{wxdbcoldef}}{}
610 \twocolitem{\helpref{wxDbColInf}{wxdbcolinf}}{}
611 \twocolitem{\helpref{wxDbColDataPtr}{wxdbcoldataptr}}{}
612 \twocolitem{\helpref{wxDbColFor}{wxdbcolfor}}{}
613 \twocolitem{\helpref{wxDbConnectInf}{wxdbconnectinf}}{}
614 \twocolitem{\helpref{wxDbIdxDef}{wxdbidxdef}}{}
615 \end{twocollist}
616
617 {\large {\bf Miscellaneous}}
618
619 \twocolwidtha{6cm}
620 \begin{twocollist}\itemsep=0pt
621 \twocolitem{\helpref{wxApp}{wxapp}}{Application class}
622 \twocolitem{\helpref{wxCaret}{wxcaret}}{A caret (cursor) object}
623 \twocolitem{\helpref{wxCmdLineParser}{wxcmdlineparser}}{Command line parser class}
624 \twocolitem{\helpref{wxConfig}{wxconfigbase}}{Classes for configuration reading/writing (using either INI files or registry)}
625 \twocolitem{\helpref{wxDllLoader}{wxdllloader}}{Class to work with shared libraries.}
626 \twocolitem{\helpref{wxGLCanvas}{wxglcanvas}}{Canvas that you can render OpenGL calls to.}
627 \twocolitem{\helpref{wxGLContext}{wxglcontext}}{Class to ease sharing of OpenGL data resources.}
628 \twocolitem{\helpref{wxLayoutAlgorithm}{wxlayoutalgorithm}}{An alternative window layout facility}
629 \twocolitem{\helpref{wxProcess}{wxprocess}}{Process class}
630 \twocolitem{\helpref{wxTimer}{wxtimer}}{Timer class}
631 \twocolitem{\helpref{wxStopWatch}{wxstopwatch}}{Stop watch class}
632 \twocolitem{\helpref{wxMimeTypesManager}{wxmimetypesmanager}}{MIME-types manager class}
633 \twocolitem{\helpref{wxSystemSettings}{wxsystemsettings}}{System settings class for obtaining various global parameters}
634 \twocolitem{\helpref{wxSystemOptions}{wxsystemoptions}}{System options class for run-time configuration}
635 \twocolitem{\helpref{wxAcceleratorTable}{wxacceleratortable}}{Accelerator table}
636 \twocolitem{\helpref{wxAutomationObject}{wxautomationobject}}{OLE automation class}
637 \twocolitem{\helpref{wxFontMapper}{wxfontmapper}}{Font mapping, finding suitable font for given encoding}
638 \twocolitem{\helpref{wxEncodingConverter}{wxencodingconverter}}{Encoding conversions}
639 \twocolitem{\helpref{wxCalendarDateAttr}{wxcalendardateattr}}{Used with \helpref{wxCalendarCtrl}{wxcalendarctrl}}
640 \twocolitem{\helpref{wxQuantize}{wxquantize}}{Class to perform quantization, or colour reduction}
641 \twocolitem{\helpref{wxSingleInstanceChecker}{wxsingleinstancechecker}}{Check that only single program instance is running}
642 \end{twocollist}