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