]> git.saurik.com Git - wxWidgets.git/blame - interface/icon.h
fix wxMSW build after wxBrush changes: return wxBRUSHSTYLE_MAX instead of zero; fix...
[wxWidgets.git] / interface / icon.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: icon.h
e54c96f1 3// Purpose: interface of wxIcon
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxIcon
11 @wxheader{icon.h}
7c913512 12
23324ae1
FM
13 An icon is a small rectangular bitmap usually used for denoting a
14 minimized application. It differs from a wxBitmap in always
15 having a mask associated with it for transparent drawing. On some platforms,
16 icons and bitmaps are implemented identically, since there is no real
17 distinction between
18 a wxBitmap with a mask and an icon; and there is no specific icon format on
19 some platforms (X-based applications usually standardize on XPMs for small
20 bitmaps
21 and icons). However, some platforms (such as Windows) make the distinction, so
22 a separate class is provided.
7c913512 23
23324ae1
FM
24 @library{wxcore}
25 @category{gdi}
7c913512 26
23324ae1 27 @stdobjects
e54c96f1 28 ::Objects:, ::wxNullIcon,
7c913512 29
e54c96f1 30 @see @ref overview_wxbitmapoverview "Bitmap and icon overview", @ref
23324ae1
FM
31 overview_supportedbitmapformats "supported bitmap file formats", wxDC::DrawIcon, wxCursor
32*/
33class wxIcon : public wxBitmap
34{
35public:
36 //@{
37 /**
e54c96f1 38 Loads an icon from the specified location().
23324ae1 39
7c913512 40 @param bits
4cc4bfaf 41 Specifies an array of pixel values.
7c913512 42 @param width
4cc4bfaf 43 Specifies the width of the icon.
7c913512 44 @param height
4cc4bfaf 45 Specifies the height of the icon.
7c913512 46 @param desiredWidth
4cc4bfaf
FM
47 Specifies the desired width of the icon. This
48 parameter only has an effect in Windows (32-bit) where icon resources can
23324ae1 49 contain
4cc4bfaf 50 several icons of different sizes.
7c913512 51 @param desiredWidth
4cc4bfaf
FM
52 Specifies the desired height of the icon. This
53 parameter only has an effect in Windows (32-bit) where icon resources can
23324ae1 54 contain
4cc4bfaf 55 several icons of different sizes.
7c913512 56 @param depth
4cc4bfaf
FM
57 Specifies the depth of the icon. If this is omitted, the display depth of
58 the
59 screen is used.
7c913512 60 @param name
4cc4bfaf 61 This can refer to a resource name under MS Windows, or a filename under MS
23324ae1 62 Windows and X.
4cc4bfaf 63 Its meaning is determined by the flags parameter.
7c913512 64 @param loc
4cc4bfaf
FM
65 The object describing the location of the native icon, see
66 wxIconLocation.
7c913512 67 @param type
4cc4bfaf
FM
68 May be one of the following:
69
70
71
72
73
74
75
76 wxBITMAP_TYPE_ICO
77
78
79
80
81 Load a Windows icon file.
82
83
84
85
86
87 wxBITMAP_TYPE_ICO_RESOURCE
88
89
90
91
92 Load a Windows icon from the resource database.
93
94
95
96
97
98 wxBITMAP_TYPE_GIF
99
100
101
102
103 Load a GIF bitmap file.
104
105
106
107
23324ae1 108
4cc4bfaf 109 wxBITMAP_TYPE_XBM
23324ae1 110
23324ae1
FM
111
112
23324ae1 113
4cc4bfaf 114 Load an X bitmap file.
23324ae1
FM
115
116
23324ae1 117
23324ae1
FM
118
119
4cc4bfaf 120 wxBITMAP_TYPE_XPM
23324ae1 121
23324ae1
FM
122
123
23324ae1 124
4cc4bfaf 125 Load an XPM bitmap file.
23324ae1
FM
126
127
23324ae1 128
4cc4bfaf
FM
129
130
131 The validity of these flags depends on the platform and wxWidgets
132 configuration.
133 If all possible wxWidgets settings are used, the Windows platform supports
134 ICO file, ICO resource,
135 XPM data, and XPM file. Under wxGTK, the available formats are BMP file,
136 XPM data, XPM file, and PNG file.
137 Under wxMotif, the available formats are XBM data, XBM file, XPM data, XPM
138 file.
23324ae1
FM
139
140 @remarks The first form constructs an icon object with no data; an
4cc4bfaf
FM
141 assignment or another member function such as Create or
142 LoadFile must be called subsequently.
23324ae1
FM
143 */
144 wxIcon();
7c913512
FM
145 wxIcon(const wxIcon& icon);
146 wxIcon(void* data, int type, int width, int height,
147 int depth = -1);
148 wxIcon(const char bits[], int width, int height,
149 int depth = 1);
150 wxIcon(int width, int height, int depth = -1);
151 wxIcon(const char* const* bits);
152 wxIcon(const wxString& name, wxBitmapType type,
153 int desiredWidth = -1,
154 int desiredHeight = -1);
155 wxIcon(const wxIconLocation& loc);
23324ae1
FM
156 //@}
157
158 /**
159 Destructor.
160 See @ref overview_refcountdestruct "reference-counted object destruction" for
161 more info.
23324ae1
FM
162 If the application omits to delete the icon explicitly, the icon will be
163 destroyed automatically by wxWidgets when the application exits.
23324ae1
FM
164 Do not delete an icon that is selected into a memory device context.
165 */
166 ~wxIcon();
167
168 /**
4cc4bfaf 169 Copies @a bmp bitmap to this icon. Under MS Windows the bitmap
23324ae1 170 must have mask colour set.
4cc4bfaf 171
23324ae1
FM
172 LoadFile()
173
174 Wx::Icon-new( width, height, depth = -1 )
175 Wx::Icon-new( name, type, desiredWidth = -1, desiredHeight = -1 )
176 Wx::Icon-newFromBits( bits, width, height, depth = 1 )
177 Wx::Icon-newFromXPM( data )
178 */
179 void CopyFromBitmap(const wxBitmap& bmp);
180
181 /**
182 Gets the colour depth of the icon. A value of 1 indicates a
183 monochrome icon.
184 */
328f5751 185 int GetDepth() const;
23324ae1
FM
186
187 /**
188 Gets the height of the icon in pixels.
189 */
328f5751 190 int GetHeight() const;
23324ae1
FM
191
192 /**
193 Gets the width of the icon in pixels.
194
4cc4bfaf 195 @see GetHeight()
23324ae1 196 */
328f5751 197 int GetWidth() const;
23324ae1
FM
198
199 /**
200 Returns @true if icon data is present.
201 */
328f5751 202 bool IsOk() const;
23324ae1
FM
203
204 /**
205 Loads an icon from a file or resource.
206
7c913512 207 @param name
4cc4bfaf
FM
208 Either a filename or a Windows resource name.
209 The meaning of name is determined by the type parameter.
7c913512 210 @param type
4cc4bfaf
FM
211 One of the following values:
212
213
214
215
216
217
218
219 wxBITMAP_TYPE_ICO
220
221
222
223
224 Load a Windows icon file.
225
226
227
228
229
230 wxBITMAP_TYPE_ICO_RESOURCE
231
232
233
234
235 Load a Windows icon from the resource database.
236
237
238
239
240
241 wxBITMAP_TYPE_GIF
242
243
244
245
246 Load a GIF bitmap file.
247
248
249
250
251
252 wxBITMAP_TYPE_XBM
253
23324ae1
FM
254
255
23324ae1 256
4cc4bfaf 257 Load an X bitmap file.
23324ae1 258
23324ae1 259
23324ae1
FM
260
261
23324ae1 262
4cc4bfaf 263 wxBITMAP_TYPE_XPM
23324ae1
FM
264
265
23324ae1 266
23324ae1 267
4cc4bfaf 268 Load an XPM bitmap file.
23324ae1 269
23324ae1 270
23324ae1
FM
271
272
23324ae1 273
4cc4bfaf
FM
274 The validity of these flags depends on the platform and wxWidgets
275 configuration.
23324ae1
FM
276
277 @returns @true if the operation succeeded, @false otherwise.
278
4cc4bfaf 279 @see wxIcon()
23324ae1
FM
280 */
281 bool LoadFile(const wxString& name, wxBitmapType type);
282
283 /**
284 Sets the depth member (does not affect the icon data).
285
7c913512 286 @param depth
4cc4bfaf 287 Icon depth.
23324ae1
FM
288 */
289 void SetDepth(int depth);
290
291 /**
292 Sets the height member (does not affect the icon data).
293
7c913512 294 @param height
4cc4bfaf 295 Icon height in pixels.
23324ae1
FM
296 */
297 void SetHeight(int height);
298
299 /**
300 Sets the width member (does not affect the icon data).
301
7c913512 302 @param width
4cc4bfaf 303 Icon width in pixels.
23324ae1
FM
304 */
305 void SetWidth(int width);
306
307 /**
308 Assignment operator, using @ref overview_trefcount "reference counting".
309
7c913512 310 @param icon
4cc4bfaf 311 Icon to assign.
23324ae1
FM
312 */
313 wxIcon operator =(const wxIcon& icon);
314};
e54c96f1
FM
315
316
317/**
318 FIXME
319*/
320wxIcon Objects:
321;
322
323/**
324 FIXME
325*/
326wxIcon wxNullIcon;
327
328