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