]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/icon.tex
in-place editing code from Michael Bedward integrated (with my docs)
[wxWidgets.git] / docs / latex / wx / icon.tex
CommitLineData
a660d684
KB
1\section{\class{wxIcon}}\label{wxicon}
2
3An icon is a small rectangular bitmap usually used for denoting a
2fd284a4
JS
4minimized application. It differs from a wxBitmap in always
5having a mask associated with it for transparent drawing. On some platforms,
6icons and bitmaps are implemented identically, since there is no real distinction between
7a wxBitmap with a mask and an icon; and there is no specific icon format on
8some platforms (X-based applications usually standardize on XPMs for small bitmaps
9and icons). However, some platforms (such as Windows) make the distinction, so
10a separate class is provided.
a660d684 11
20e85460
JS
12\wxheading{Derived from}
13
14\helpref{wxBitmap}{wxbitmap}\\
15\helpref{wxGDIObject}{wxgdiobject}\\
16\helpref{wxObject}{wxobject}
17
18\wxheading{Include files}
19
20<wx/icon.h>
21
22\wxheading{Predefined objects}
23
24Objects:
25
26{\bf wxNullIcon}
27
a660d684
KB
28\wxheading{Remarks}
29
2fd284a4
JS
30It is usually desirable to associate a pertinent icon with a frame. Icons
31can also be used for other purposes, for example with \helpref{wxTreeCtrl}{wxtreectrl}
32and \helpref{wxListCtrl}{wxlistctrl}.
33
34Icons have different formats on different platforms.
35Therefore, separate icons will usually be created for the different
a660d684
KB
36environments. Platform-specific methods for creating a {\bf wxIcon}\rtfsp
37structure are catered for, and this is an occasion where conditional
38compilation will probably be required.
39
40Note that a new icon must be created for every time the icon is to be
2fd284a4 41used for a new window. In Windows, the icon will not be
a660d684
KB
42reloaded if it has already been used. An icon allocated to a frame will
43be deleted when the frame is deleted.
44
2fd284a4 45For more information please see \helpref{Bitmap and icon overview}{wxbitmapoverview}.
a660d684 46
a660d684
KB
47\wxheading{See also}
48
2fd284a4
JS
49\helpref{Bitmap and icon overview}{wxbitmapoverview}, \helpref{supported bitmap file formats}{supportedbitmapformats},
50\helpref{wxDC::DrawIcon}{wxdcdrawicon}, \helpref{wxCursor}{wxcursor}
a660d684
KB
51
52\latexignore{\rtfignore{\wxheading{Members}}}
53
54\membersection{wxIcon::wxIcon}\label{wxiconconstr}
55
56\func{}{wxIcon}{\void}
57
58Default constructor.
59
60\func{}{wxIcon}{\param{const wxIcon\& }{icon}}
61
1e6d9499 62Copy constructor.
a660d684 63
eaaa6a06 64\func{}{wxIcon}{\param{void*}{ data}, \param{int}{ type}, \param{int}{ width}, \param{int}{ height}, \param{int}{ depth = -1}}
a660d684
KB
65
66Creates an icon from the given data, which can be of arbitrary type.
67
eaaa6a06
JS
68\func{}{wxIcon}{\param{const char}{ bits[]}, \param{int}{ width}, \param{int}{ height}\\
69 \param{int}{ depth = 1}}
a660d684
KB
70
71Creates an icon from an array of bits.
72
eaaa6a06 73\func{}{wxIcon}{\param{int}{ width}, \param{int}{ height}, \param{int}{ depth = -1}}
a660d684
KB
74
75Creates a new icon.
76
77\func{}{wxIcon}{\param{const char**}{ bits}}
78
79Creates an icon from XPM data.
80
f60d0f94
JS
81\func{}{wxIcon}{\param{const wxString\& }{name}, \param{long}{ type},
82 \param{int}{ desiredWidth = -1}, \param{int}{ desiredHeight = -1}}
a660d684
KB
83
84Loads an icon from a file or resource.
85
86\wxheading{Parameters}
87
88\docparam{bits}{Specifies an array of pixel values.}
89
90\docparam{width}{Specifies the width of the icon.}
91
92\docparam{height}{Specifies the height of the icon.}
93
f60d0f94
JS
94\docparam{desiredWidth}{Specifies the desired width of the icon. This
95parameter only has an effect in Windows (32-bit) where icon resources can contain
96several icons of different sizes.}
97
98\docparam{desiredWidth}{Specifies the desired height of the icon. This
99parameter only has an effect in Windows (32-bit) where icon resources can contain
100several icons of different sizes.}
101
a660d684
KB
102\docparam{depth}{Specifies the depth of the icon. If this is omitted, the display depth of the
103screen is used.}
104
105\docparam{name}{This can refer to a resource name under MS Windows, or a filename under MS Windows and X.
106Its meaning is determined by the {\it flags} parameter.}
107
108\docparam{type}{May be one of the following:
109
110\twocolwidtha{5cm}
111\begin{twocollist}
112\twocolitem{{\bf \indexit{wxBITMAP\_TYPE\_ICO}}}{Load a Windows icon file.}
113\twocolitem{{\bf \indexit{wxBITMAP\_TYPE\_ICO\_RESOURCE}}}{Load a Windows icon from the resource database.}
114\twocolitem{{\bf \indexit{wxBITMAP\_TYPE\_GIF}}}{Load a GIF bitmap file.}
115\twocolitem{{\bf \indexit{wxBITMAP\_TYPE\_XBM}}}{Load an X bitmap file.}
116\twocolitem{{\bf \indexit{wxBITMAP\_TYPE\_XPM}}}{Load an XPM bitmap file.}
117%\twocolitem{{\bf \indexit{wxBITMAP\_TYPE\_RESOURCE}}}{Load a Windows resource name.}
118\end{twocollist}
119
120The validity of these flags depends on the platform and wxWindows configuration.
2fd284a4
JS
121If all possible wxWindows settings are used, the Windows platform supports ICO file, ICO resource,
122XPM data, and XPM file. Under wxGTK, the available formats are BMP file, XPM data, XPM file, and PNG file.
123Under wxMotif, the available formats are XBM data, XBM file, XPM data, XPM file.}
a660d684
KB
124
125\wxheading{Remarks}
126
127The first form constructs an icon object with no data; an assignment or another member function such as Create
128or LoadFile must be called subsequently.
129
130The second and third forms provide copy constructors. Note that these do not copy the
131icon data, but instead a pointer to the data, keeping a reference count. They are therefore
132very efficient operations.
133
134The fourth form constructs an icon from data whose type and value depends on
135the value of the {\it type} argument.
136
137The fifth form constructs a (usually monochrome) icon from an array of pixel values, under both
138X and Windows.
139
140The sixth form constructs a new icon.
141
142The seventh form constructs an icon from pixmap (XPM) data, if wxWindows has been configured
143to incorporate this feature.
144
145To use this constructor, you must first include an XPM file. For
146example, assuming that the file {\tt mybitmap.xpm} contains an XPM array
147of character pointers called mybitmap:
148
149\begin{verbatim}
150#include "mybitmap.xpm"
151
152...
153
154wxIcon *icon = new wxIcon(mybitmap);
155\end{verbatim}
156
2fd284a4
JS
157A macro, wxICON, is available which creates an icon using an XPM
158on the appropriate platform, or an icon resource on Windows.
159
160\begin{verbatim}
161wxIcon icon(wxICON(mondrian));
162
163// Equivalent to:
164
165#if defined(__WXGTK__) || defined(__WXMOTIF__)
166wxIcon icon(mondrian_xpm);
167#endif
168
169#if defined(__WXMSW__)
170wxIcon icon("mondrian");
171#endif
172\end{verbatim}
173
a660d684
KB
174The eighth form constructs an icon from a file or resource. {\it name} can refer
175to a resource name under MS Windows, or a filename under MS Windows and X.
176
177Under Windows, {\it type} defaults to wxBITMAP\_TYPE\_ICO\_RESOURCE.
2fd284a4 178Under X, {\it type} defaults to wxBITMAP\_TYPE\_XPM.
a660d684
KB
179
180\wxheading{See also}
181
182\helpref{wxIcon::LoadFile}{wxiconloadfile}
183
184\membersection{wxIcon::\destruct{wxIcon}}
185
186\func{}{\destruct{wxIcon}}{\void}
187
188Destroys the wxIcon object and possibly the underlying icon data.
189Because reference counting is used, the icon may not actually be
190destroyed at this point - only when the reference count is zero will the
191data be deleted.
192
193If the application omits to delete the icon explicitly, the icon will be
194destroyed automatically by wxWindows when the application exits.
195
196Do not delete an icon that is selected into a memory device context.
197
a660d684
KB
198\membersection{wxIcon::GetDepth}
199
200\constfunc{int}{GetDepth}{\void}
201
202Gets the colour depth of the icon. A value of 1 indicates a
203monochrome icon.
204
205\membersection{wxIcon::GetHeight}\label{wxicongetheight}
206
207\constfunc{int}{GetHeight}{\void}
208
209Gets the height of the icon in pixels.
210
211\membersection{wxIcon::GetWidth}\label{wxicongetwidth}
212
213\constfunc{int}{GetWidth}{\void}
214
215Gets the width of the icon in pixels.
216
217\wxheading{See also}
218
219\helpref{wxIcon::GetHeight}{wxicongetheight}
220
221\membersection{wxIcon::LoadFile}\label{wxiconloadfile}
222
eaaa6a06 223\func{bool}{LoadFile}{\param{const wxString\&}{ name}, \param{long}{ type}}
a660d684
KB
224
225Loads an icon from a file or resource.
226
227\wxheading{Parameters}
228
229\docparam{name}{Either a filename or a Windows resource name.
230The meaning of {\it name} is determined by the {\it type} parameter.}
231
232\docparam{type}{One of the following values:
233
234\twocolwidtha{5cm}
235\begin{twocollist}
236\twocolitem{{\bf wxBITMAP\_TYPE\_ICO}}{Load a Windows icon file.}
237\twocolitem{{\bf wxBITMAP\_TYPE\_ICO\_RESOURCE}}{Load a Windows icon from the resource database.}
238\twocolitem{{\bf wxBITMAP\_TYPE\_GIF}}{Load a GIF bitmap file.}
239\twocolitem{{\bf wxBITMAP\_TYPE\_XBM}}{Load an X bitmap file.}
240\twocolitem{{\bf wxBITMAP\_TYPE\_XPM}}{Load an XPM bitmap file.}
241\end{twocollist}
242
243The validity of these flags depends on the platform and wxWindows configuration.}
244
245\wxheading{Return value}
246
247TRUE if the operation succeeded, FALSE otherwise.
248
249\wxheading{See also}
250
251\helpref{wxIcon::wxIcon}{wxiconconstr}
252
253\membersection{wxIcon::Ok}\label{wxiconok}
254
255\constfunc{bool}{Ok}{\void}
256
257Returns TRUE if icon data is present.
258
259\begin{comment}
260\membersection{wxIcon::SaveFile}\label{wxiconsavefile}
261
262\func{bool}{SaveFile}{\param{const wxString\& }{name}, \param{int}{ type}, \param{wxPalette* }{palette = NULL}}
263
264Saves an icon in the named file.
265
266\wxheading{Parameters}
267
268\docparam{name}{A filename. The meaning of {\it name} is determined by the {\it type} parameter.}
269
270\docparam{type}{One of the following values:
271
272\twocolwidtha{5cm}
273\begin{twocollist}
274\twocolitem{{\bf wxBITMAP\_TYPE\_ICO}}{Save a Windows icon file.}
275%\twocolitem{{\bf wxBITMAP\_TYPE\_GIF}}{Save a GIF icon file.}
276%\twocolitem{{\bf wxBITMAP\_TYPE\_XBM}}{Save an X bitmap file.}
277\twocolitem{{\bf wxBITMAP\_TYPE\_XPM}}{Save an XPM bitmap file.}
278\end{twocollist}
279
280The validity of these flags depends on the platform and wxWindows configuration.}
281
5b6aa0ff 282\docparam{palette}{An optional palette used for saving the icon.}
a660d684
KB
283
284\wxheading{Return value}
285
286TRUE if the operation succeeded, FALSE otherwise.
287
288\wxheading{Remarks}
289
290Depending on how wxWindows has been configured, not all formats may be available.
291
292\wxheading{See also}
293
294\helpref{wxIcon::LoadFile}{wxiconloadfile}
295\end{comment}
296
297\membersection{wxIcon::SetDepth}\label{wxiconsetdepth}
298
299\func{void}{SetDepth}{\param{int }{depth}}
300
301Sets the depth member (does not affect the icon data).
302
303\wxheading{Parameters}
304
305\docparam{depth}{Icon depth.}
306
307\membersection{wxIcon::SetHeight}\label{wxiconsetheight}
308
309\func{void}{SetHeight}{\param{int }{height}}
310
311Sets the height member (does not affect the icon data).
312
313\wxheading{Parameters}
314
315\docparam{height}{Icon height in pixels.}
316
317\membersection{wxIcon::SetOk}
318
319\func{void}{SetOk}{\param{int }{isOk}}
320
321Sets the validity member (does not affect the icon data).
322
323\wxheading{Parameters}
324
325\docparam{isOk}{Validity flag.}
326
327\membersection{wxIcon::SetWidth}
328
329\func{void}{SetWidth}{\param{int }{width}}
330
331Sets the width member (does not affect the icon data).
332
333\wxheading{Parameters}
334
335\docparam{width}{Icon width in pixels.}
336
337\membersection{wxIcon::operator $=$}
338
339\func{wxIcon\& }{operator $=$}{\param{const wxIcon\& }{icon}}
340
341Assignment operator. This operator does not copy any data, but instead
342passes a pointer to the data in {\it icon} and increments a reference
343counter. It is a fast operation.
344
345\wxheading{Parameters}
346
347\docparam{icon}{Icon to assign.}
348
349\wxheading{Return value}
350
351Returns 'this' object.
352
353\membersection{wxIcon::operator $==$}
354
355\func{bool}{operator $==$}{\param{const wxIcon\& }{icon}}
356
357Equality operator. This operator tests whether the internal data pointers are
358equal (a fast test).
359
360\wxheading{Parameters}
361
362\docparam{icon}{Icon to compare with 'this'}
363
364\wxheading{Return value}
365
366Returns TRUE if the icons were effectively equal, FALSE otherwise.
367
368\membersection{wxIcon::operator $!=$}
369
370\func{bool}{operator $!=$}{\param{const wxIcon\& }{icon}}
371
372Inequality operator. This operator tests whether the internal data pointers are
373unequal (a fast test).
374
375\wxheading{Parameters}
376
377\docparam{icon}{Icon to compare with 'this'}
378
379\wxheading{Return value}
380
381Returns TRUE if the icons were unequal, FALSE otherwise.
382
383