]> git.saurik.com Git - wxWidgets.git/blame_incremental - docs/latex/wx/image.tex
wxRect::SetSize documented.
[wxWidgets.git] / docs / latex / wx / image.tex
... / ...
CommitLineData
1\section{\class{wxImage}}\label{wximage}
2
3This class encapsulates a platform-independent image. An image can be created
4from data, or using \helpref{wxBitmap::ConvertToImage}{wxbitmapconverttoimage}. An image
5can be loaded from a file in a variety of formats, and is extensible to new formats
6via image format handlers. Functions are available to set and get image bits, so
7it can be used for basic image manipulation.
8
9A wxImage cannot (currently) be drawn directly to a \helpref{wxDC}{wxdc}. Instead,
10a platform-specific \helpref{wxBitmap}{wxbitmap} object must be created from it using
11the \helpref{wxBitmap::wxBitmap(wxImage,int depth)}{wxbitmapctor} constructor.
12This bitmap can then
13be drawn in a device context, using \helpref{wxDC::DrawBitmap}{wxdcdrawbitmap}.
14
15One colour value of the image may be used as a mask colour which will lead to the automatic
16creation of a \helpref{wxMask}{wxmask} object associated to the bitmap object.
17
18\wxheading{Alpha channel support}
19
20Starting from wxWidgets 2.5.0 wxImage supports alpha channel data, that is in
21addition to a byte for the red, green and blue colour components for each pixel
22it also stores a byte representing the pixel opacity. An alpha value of $0$
23corresponds to a transparent pixel (null opacity) while a value of $255$
24means that the pixel is 100\% opaque.
25
26Unlike RGB data, not all images have an alpha channel and before using
27\helpref{GetAlpha}{wximagegetalpha} you should check if this image contains
28an alpha channel with \helpref{HasAlpha}{wximagehasalpha}. Note that currently only
29images loaded from PNG files with transparency information will have an alpha
30channel but alpha support will be added to the other formats as well (as well
31as support for saving images with alpha channel which also isn't implemented).
32
33\wxheading{Available image handlers}
34
35The following image handlers are available. {\bf wxBMPHandler} is always
36installed by default. To use other image formats, install the appropriate
37handler with \helpref{wxImage::AddHandler}{wximageaddhandler} or
38\helpref{wxInitAllImageHandlers}{wxinitallimagehandlers}.
39
40\twocolwidtha{5cm}%
41\begin{twocollist}
42\twocolitem{\indexit{wxBMPHandler}}{For loading and saving, always installed.}
43\twocolitem{\indexit{wxPNGHandler}}{For loading (including alpha support) and saving.}
44\twocolitem{\indexit{wxJPEGHandler}}{For loading and saving.}
45\twocolitem{\indexit{wxGIFHandler}}{Only for loading, due to legal issues.}
46\twocolitem{\indexit{wxPCXHandler}}{For loading and saving (see below).}
47\twocolitem{\indexit{wxPNMHandler}}{For loading and saving (see below).}
48\twocolitem{\indexit{wxTIFFHandler}}{For loading and saving.}
49\twocolitem{\indexit{wxIFFHandler}}{For loading only.}
50\twocolitem{\indexit{wxXPMHandler}}{For loading and saving.}
51\twocolitem{\indexit{wxICOHandler}}{For loading and saving.}
52\twocolitem{\indexit{wxCURHandler}}{For loading and saving.}
53\twocolitem{\indexit{wxANIHandler}}{For loading only.}
54\end{twocollist}
55
56When saving in PCX format, {\bf wxPCXHandler} will count the number of
57different colours in the image; if there are 256 or less colours, it will
58save as 8 bit, else it will save as 24 bit.
59
60Loading PNMs only works for ASCII or raw RGB images. When saving in
61PNM format, {\bf wxPNMHandler} will always save as raw RGB.
62
63\wxheading{Derived from}
64
65\helpref{wxObject}{wxobject}
66
67\wxheading{Include files}
68
69<wx/image.h>
70
71\wxheading{See also}
72
73\helpref{wxBitmap}{wxbitmap},
74\helpref{wxInitAllImageHandlers}{wxinitallimagehandlers}
75
76\latexignore{\rtfignore{\wxheading{Members}}}
77
78
79\membersection{wxImage::wxImage}\label{wximagector}
80
81\func{}{wxImage}{\void}
82
83Default constructor.
84
85\func{}{wxImage}{\param{const wxImage\& }{image}}
86
87Copy constructor.
88
89\func{}{wxImage}{\param{const wxBitmap\&}{ bitmap}}
90
91(Deprecated form, use \helpref{wxBitmap::ConvertToImage}{wxbitmapconverttoimage}
92instead.) Constructs an image from a platform-dependent bitmap. This preserves
93mask information so that bitmaps and images can be converted back
94and forth without loss in that respect.
95
96\func{}{wxImage}{\param{int}{ width}, \param{int}{ height}, \param{bool}{ clear=true}}
97
98Creates an image with the given width and height. If {\it clear} is true, the new image will be initialized to black.
99Otherwise, the image data will be uninitialized.
100
101\func{}{wxImage}{\param{int}{ width}, \param{int}{ height}, \param{unsigned char*}{ data}, \param{bool}{ static\_data=false}}
102
103Creates an image from given data with the given width and height. If
104{\it static\_data} is true, then wxImage will not delete the actual
105image data in its destructor, otherwise it will free it by calling
106{\it free()}.
107
108\func{}{wxImage}{\param{const wxString\& }{name}, \param{long}{ type = wxBITMAP\_TYPE\_ANY}, \param{int}{ index = -1}}
109
110\func{}{wxImage}{\param{const wxString\& }{name}, \param{const wxString\&}{ mimetype}, \param{int}{ index = -1}}
111
112Loads an image from a file.
113
114\func{}{wxImage}{\param{wxInputStream\& }{stream}, \param{long}{ type = wxBITMAP\_TYPE\_ANY}, \param{int}{ index = -1}}
115
116\func{}{wxImage}{\param{wxInputStream\& }{stream}, \param{const wxString\&}{ mimetype}, \param{int}{ index = -1}}
117
118Loads an image from an input stream.
119
120\wxheading{Parameters}
121
122\docparam{width}{Specifies the width of the image.}
123
124\docparam{height}{Specifies the height of the image.}
125
126\docparam{name}{Name of the file from which to load the image.}
127
128\docparam{stream}{Opened input stream from which to load the image. Currently, the stream must support seeking.}
129
130\docparam{type}{May be one of the following:
131
132\twocolwidtha{5cm}%
133\begin{twocollist}
134\twocolitem{\indexit{wxBITMAP\_TYPE\_BMP}}{Load a Windows bitmap file.}
135\twocolitem{\indexit{wxBITMAP\_TYPE\_GIF}}{Load a GIF bitmap file.}
136\twocolitem{\indexit{wxBITMAP\_TYPE\_JPEG}}{Load a JPEG bitmap file.}
137\twocolitem{\indexit{wxBITMAP\_TYPE\_PNG}}{Load a PNG bitmap file.}
138\twocolitem{\indexit{wxBITMAP\_TYPE\_PCX}}{Load a PCX bitmap file.}
139\twocolitem{\indexit{wxBITMAP\_TYPE\_PNM}}{Load a PNM bitmap file.}
140\twocolitem{\indexit{wxBITMAP\_TYPE\_TIF}}{Load a TIFF bitmap file.}
141\twocolitem{\indexit{wxBITMAP\_TYPE\_XPM}}{Load a XPM bitmap file.}
142\twocolitem{\indexit{wxBITMAP\_TYPE\_ICO}}{Load a Windows icon file (ICO).}
143\twocolitem{\indexit{wxBITMAP\_TYPE\_CUR}}{Load a Windows cursor file (CUR).}
144\twocolitem{\indexit{wxBITMAP\_TYPE\_ANI}}{Load a Windows animated cursor file (ANI).}
145\twocolitem{\indexit{wxBITMAP\_TYPE\_ANY}}{Will try to autodetect the format.}
146\end{twocollist}}
147
148\docparam{mimetype}{MIME type string (for example 'image/jpeg')}
149
150\docparam{index}{Index of the image to load in the case that the image file contains multiple images.
151This is only used by GIF, ICO and TIFF handlers. The default value (-1) means
152"choose the default image" and is interpreted as the first image (index=0) by
153the GIF and TIFF handler and as the largest and most colourful one by the ICO handler.}
154
155\wxheading{Remarks}
156
157Depending on how wxWidgets has been configured, not all formats may be available.
158
159Note: any handler other than BMP must be previously
160initialized with \helpref{wxImage::AddHandler}{wximageaddhandler} or
161\helpref{wxInitAllImageHandlers}{wxinitallimagehandlers}.
162
163Note: you can use \helpref{GetOptionInt}{wximagegetoptionint} to get the
164hotspot for loaded cursor file:
165\begin{verbatim}
166 int hotspot_x = image.GetOptionInt(wxIMAGE_OPTION_CUR_HOTSPOT_X);
167 int hotspot_y = image.GetOptionInt(wxIMAGE_OPTION_CUR_HOTSPOT_Y);
168
169\end{verbatim}
170
171\wxheading{See also}
172
173\helpref{wxImage::LoadFile}{wximageloadfile}
174
175\pythonnote{Constructors supported by wxPython are:\par
176\indented{2cm}{\begin{twocollist}
177\twocolitem{{\bf wxImage(name, flag)}}{Loads an image from a file}
178\twocolitem{{\bf wxNullImage()}}{Create a null image (has no size or
179image data)}
180\twocolitem{{\bf wxEmptyImage(width, height)}}{Creates an empty image
181of the given size}
182\twocolitem{{\bf wxImageFromMime(name, mimetype}}{Creates an image from
183the given file of the given mimetype}
184\twocolitem{{\bf wxImageFromBitmap(bitmap)}}{Creates an image from a
185platform-dependent bitmap}
186\end{twocollist}}
187}
188
189\perlnote{Constructors supported by wxPerl are:\par
190\begin{itemize}
191\item{Wx::Image->new( bitmap )}
192\item{Wx::Image->new( icon )}
193\item{Wx::Image->new( width, height )}
194\item{Wx::Image->new( width, height, data )}
195\item{Wx::Image->new( file, type, index )}
196\item{Wx::Image->new( file, mimetype, index )}
197\item{Wx::Image->new( stream, type, index )}
198\item{Wx::Image->new( stream, mimetype, index )}
199\end{itemize}
200}
201
202
203\membersection{wxImage::\destruct{wxImage}}\label{wximagedtor}
204
205\func{}{\destruct{wxImage}}{\void}
206
207Destructor.
208
209
210\membersection{wxImage::AddHandler}\label{wximageaddhandler}
211
212\func{static void}{AddHandler}{\param{wxImageHandler*}{ handler}}
213
214Adds a handler to the end of the static list of format handlers.
215
216\docparam{handler}{A new image format handler object. There is usually only one instance
217of a given handler class in an application session.}
218
219\wxheading{See also}
220
221\helpref{wxImageHandler}{wximagehandler}
222
223\func{bool}{CanRead}{\param{const wxString\&}{ filename}}
224
225returns true if the current image handlers can read this file
226
227\pythonnote{In wxPython this static method is named {\tt wxImage\_AddHandler}.}
228
229\membersection{wxImage::CleanUpHandlers}\label{wximagecleanuphandlers}
230
231\func{static void}{CleanUpHandlers}{\void}
232
233Deletes all image handlers.
234
235This function is called by wxWidgets on exit.
236
237
238\membersection{wxImage::ComputeHistogram}\label{wximagecomputehistogram}
239
240\constfunc{unsigned long}{ComputeHistogram}{\param{wxImageHistogram\& }{histogram}}
241
242Computes the histogram of the image. {\it histogram} is a reference to
243wxImageHistogram object. wxImageHistogram is a specialization of
244\helpref{wxHashMap}{wxhashmap} "template" and is defined as follows:
245
246\begin{verbatim}
247class WXDLLEXPORT wxImageHistogramEntry
248{
249public:
250 wxImageHistogramEntry() : index(0), value(0) {}
251 unsigned long index;
252 unsigned long value;
253};
254
255WX_DECLARE_EXPORTED_HASH_MAP(unsigned long, wxImageHistogramEntry,
256 wxIntegerHash, wxIntegerEqual,
257 wxImageHistogram);
258\end{verbatim}
259
260\wxheading{Return value}
261
262Returns number of colours in the histogram.
263
264
265\membersection{wxImage::ConvertAlphaToMask}\label{wximageconvertalphatomask}
266
267\func{bool}{ConvertAlphaToMask}{\param{unsigned char}{ threshold = 128}}
268
269If the image has alpha channel, this method converts it to mask. All pixels
270with alpha value less than \arg{threshold} are replaced with mask colour
271and the alpha channel is removed. Mask colour is chosen automatically using
272\helpref{FindFirstUnusedColour}{wximagefindfirstunusedcolour}.
273
274If the image image doesn't have alpha channel,
275ConvertAlphaToMask does nothing.
276
277\wxheading{Return value}
278
279\false if FindFirstUnusedColour returns \false, \true otherwise.
280
281
282\membersection{wxImage::ConvertToBitmap}\label{wximageconverttobitmap}
283
284\constfunc{wxBitmap}{ConvertToBitmap}{\void}
285
286Deprecated, use equivalent \helpref{wxBitmap constructor}{wxbitmapctor}
287(which takes wxImage and depth as its arguments) instead.
288
289
290\membersection{wxImage::ConvertToMono}\label{wxbitmapconverttomono}
291
292\constfunc{wxImage}{ConvertToMono}{\param{unsigned char}{ r}, \param{unsigned char}{ g}, \param{unsigned char}{ b}}
293
294Returns monochromatic version of the image. The returned image has white
295colour where the original has {\it (r,g,b)} colour and black colour
296everywhere else.
297
298
299\membersection{wxImage::Copy}\label{wximagecopy}
300
301\constfunc{wxImage}{Copy}{\void}
302
303Returns an identical copy of the image.
304
305
306\membersection{wxImage::Create}\label{wximagecreate}
307
308\func{bool}{Create}{\param{int}{ width}, \param{int}{ height}, \param{bool}{ clear=true}}
309
310Creates a fresh image. If {\it clear} is true, the new image will be initialized to black.
311Otherwise, the image data will be uninitialized.
312
313\wxheading{Parameters}
314
315\docparam{width}{The width of the image in pixels.}
316
317\docparam{height}{The height of the image in pixels.}
318
319\wxheading{Return value}
320
321true if the call succeeded, false otherwise.
322
323
324\membersection{wxImage::Destroy}\label{wximagedestroy}
325
326\func{void}{Destroy}{\void}
327
328Destroys the image data.
329
330
331\membersection{wxImage::FindFirstUnusedColour}\label{wximagefindfirstunusedcolour}
332
333\func{bool}{FindFirstUnusedColour}{\param{unsigned char *}{ r}, \param{unsigned char *}{ g}, \param{unsigned char *}{ b}, \param{unsigned char}{ startR = 1}, \param{unsigned char}{ startG = 0}, \param{unsigned char}{ startB = 0}}
334
335\wxheading{Parameters}
336
337\docparam{r,g,b}{Pointers to variables to save the colour.}
338
339\docparam{startR,startG,startB}{Initial values of the colour. Returned colour
340will have RGB values equal to or greater than these.}
341
342Finds the first colour that is never used in the image. The search begins at
343given initial colour and continues by increasing R, G and B components (in this
344order) by 1 until an unused colour is found or the colour space exhausted.
345
346\wxheading{Return value}
347
348Returns false if there is no unused colour left, true on success.
349
350\wxheading{Notes}
351
352Note that this method involves computing the histogram, which is
353computationally intensive operation.
354
355
356\membersection{wxImage::FindHandler}\label{wximagefindhandler}
357
358\func{static wxImageHandler*}{FindHandler}{\param{const wxString\& }{name}}
359
360Finds the handler with the given name.
361
362\func{static wxImageHandler*}{FindHandler}{\param{const wxString\& }{extension}, \param{long}{ imageType}}
363
364Finds the handler associated with the given extension and type.
365
366\func{static wxImageHandler*}{FindHandler}{\param{long }{imageType}}
367
368Finds the handler associated with the given image type.
369
370\func{static wxImageHandler*}{FindHandlerMime}{\param{const wxString\& }{mimetype}}
371
372Finds the handler associated with the given MIME type.
373
374\docparam{name}{The handler name.}
375
376\docparam{extension}{The file extension, such as ``bmp".}
377
378\docparam{imageType}{The image type, such as wxBITMAP\_TYPE\_BMP.}
379
380\docparam{mimetype}{MIME type.}
381
382\wxheading{Return value}
383
384A pointer to the handler if found, NULL otherwise.
385
386\wxheading{See also}
387
388\helpref{wxImageHandler}{wximagehandler}
389
390
391\membersection{wxImage::GetImageExtWildcard}\label{wximagegetimageextwildcard}
392
393\func{static wxString}{GetImageExtWildcard}{\void}
394
395Iterates all registered wxImageHandler objects, and returns a string containing file extension masks
396suitable for passing to file open/save dialog boxes.
397
398\wxheading{Return value}
399
400The format of the returned string is "(*.ext1;*.ext2)|*.ext1;*.ext2".
401
402It is usually a good idea to prepend a description before passing the result to the dialog.
403
404Example:
405
406\begin{verbatim}
407 wxFileDialog FileDlg( this, "Choose Image", ::wxGetWorkingDirectory(), "", _("Image Files ") + wxImage::GetImageExtWildcard(), wxOPEN );
408\end{verbatim}
409
410\wxheading{See also}
411
412\helpref{wxImageHandler}{wximagehandler}
413
414
415\membersection{wxImage::GetAlpha}\label{wximagegetalpha}
416
417\constfunc{unsigned char}{GetAlpha}{\param{int}{ x}, \param{int}{ y}}
418
419Returns the alpha value for the given pixel. This function may only be called
420for the images with alpha channel, use \helpref{HasAlpha}{wximagehasalpha} to
421check for this.
422
423The returned value is the {\it opacity} of the image, i.e. the value of $0$
424corresponds to the transparent pixels while the value of $255$ -- to the opaque
425ones.
426
427\constfunc{unsigned char *}{GetAlpha}{\void}
428
429Returns pointer to the array storing the alpha values for this image. This
430pointer is {\tt NULL} for the images without the alpha channel. If the image
431does have it, this pointer may be used to directly manipulate the alpha values
432which are stored as the \helpref{RGB}{wximagegetdata} ones.
433
434
435\membersection{wxImage::GetBlue}\label{wximagegetblue}
436
437\constfunc{unsigned char}{GetBlue}{\param{int}{ x}, \param{int}{ y}}
438
439Returns the blue intensity at the given coordinate.
440
441
442\membersection{wxImage::GetData}\label{wximagegetdata}
443
444\constfunc{unsigned char*}{GetData}{\void}
445
446Returns the image data as an array. This is most often used when doing
447direct image manipulation. The return value points to an array of
448characters in RGBRGBRGB$\ldots$ format in the top-to-bottom, left-to-right
449order, that is the first RGB triplet corresponds to the pixel first pixel of
450the first row, the second one --- to the second pixel of the first row and so
451on until the end of the first row, with second row following after it and so
452on.
453
454You should not delete the returned pointer nor pass it to
455\helpref{wxImage::SetData}{wximagesetdata}.
456
457
458\membersection{wxImage::GetGreen}\label{wximagegetgreen}
459
460\constfunc{unsigned char}{GetGreen}{\param{int}{ x}, \param{int}{ y}}
461
462Returns the green intensity at the given coordinate.
463
464
465\membersection{wxImage::GetImageCount}\label{wximagegetimagecount}
466
467\func{static int}{GetImageCount}{\param{const wxString\&}{ filename}, \param{long}{ type = wxBITMAP\_TYPE\_ANY}}
468
469\func{static int}{GetImageCount}{\param{wxInputStream\&}{ stream}, \param{long}{ type = wxBITMAP\_TYPE\_ANY}}
470
471If the image file contains more than one image and the image handler is capable
472of retrieving these individually, this function will return the number of
473available images.
474
475\docparam{name}{Name of the file to query.}
476
477\docparam{stream}{Opened input stream with image data. Currently, the stream must support seeking.}
478
479\docparam{type}{May be one of the following:
480
481\twocolwidtha{5cm}%
482\begin{twocollist}
483\twocolitem{\indexit{wxBITMAP\_TYPE\_BMP}}{Load a Windows bitmap file.}
484\twocolitem{\indexit{wxBITMAP\_TYPE\_GIF}}{Load a GIF bitmap file.}
485\twocolitem{\indexit{wxBITMAP\_TYPE\_JPEG}}{Load a JPEG bitmap file.}
486\twocolitem{\indexit{wxBITMAP\_TYPE\_PNG}}{Load a PNG bitmap file.}
487\twocolitem{\indexit{wxBITMAP\_TYPE\_PCX}}{Load a PCX bitmap file.}
488\twocolitem{\indexit{wxBITMAP\_TYPE\_PNM}}{Load a PNM bitmap file.}
489\twocolitem{\indexit{wxBITMAP\_TYPE\_TIF}}{Load a TIFF bitmap file.}
490\twocolitem{\indexit{wxBITMAP\_TYPE\_XPM}}{Load a XPM bitmap file.}
491\twocolitem{\indexit{wxBITMAP\_TYPE\_ICO}}{Load a Windows icon file (ICO).}
492\twocolitem{\indexit{wxBITMAP\_TYPE\_CUR}}{Load a Windows cursor file (CUR).}
493\twocolitem{\indexit{wxBITMAP\_TYPE\_ANI}}{Load a Windows animated cursor file (ANI).}
494\twocolitem{\indexit{wxBITMAP\_TYPE\_ANY}}{Will try to autodetect the format.}
495\end{twocollist}}
496
497\wxheading{Return value}
498
499Number of available images. For most image handlers, this is 1 (exceptions
500are TIFF and ICO formats).
501
502
503\membersection{wxImage::GetHandlers}\label{wximagegethandlers}
504
505\func{static wxList\&}{GetHandlers}{\void}
506
507Returns the static list of image format handlers.
508
509\wxheading{See also}
510
511\helpref{wxImageHandler}{wximagehandler}
512
513
514\membersection{wxImage::GetHeight}\label{wximagegetheight}
515
516\constfunc{int}{GetHeight}{\void}
517
518Gets the height of the image in pixels.
519
520
521\membersection{wxImage::GetMaskBlue}\label{wximagegetmaskblue}
522
523\constfunc{unsigned char}{GetMaskBlue}{\void}
524
525Gets the blue value of the mask colour.
526
527
528\membersection{wxImage::GetMaskGreen}\label{wximagegetmaskgreen}
529
530\constfunc{unsigned char}{GetMaskGreen}{\void}
531
532Gets the green value of the mask colour.
533
534
535\membersection{wxImage::GetMaskRed}\label{wximagegetmaskred}
536
537\constfunc{unsigned char}{GetMaskRed}{\void}
538
539Gets the red value of the mask colour.
540
541
542\membersection{wxImage::GetPalette}\label{wximagegetpalette}
543
544\constfunc{const wxPalette\&}{GetPalette}{\void}
545
546Returns the palette associated with the image. Currently the palette is only
547used when converting to wxBitmap under Windows.
548
549Eventually wxImage handlers will set the palette if one exists in the image file.
550
551
552\membersection{wxImage::GetRed}\label{wximagegetred}
553
554\constfunc{unsigned char}{GetRed}{\param{int}{ x}, \param{int}{ y}}
555
556Returns the red intensity at the given coordinate.
557
558
559\membersection{wxImage::GetSubImage}\label{wximagegetsubimage}
560
561\constfunc{wxImage}{GetSubImage}{\param{const wxRect\&}{ rect}}
562
563Returns a sub image of the current one as long as the rect belongs entirely to
564the image.
565
566
567\membersection{wxImage::GetWidth}\label{wximagegetwidth}
568
569\constfunc{int}{GetWidth}{\void}
570
571Gets the width of the image in pixels.
572
573\wxheading{See also}
574
575\helpref{wxImage::GetHeight}{wximagegetheight}
576
577
578\membersection{wxImage::HasAlpha}\label{wximagehasalpha}
579
580\constfunc{bool}{HasAlpha}{\void}
581
582Returns true if this image has alpha channel, false otherwise.
583
584\wxheading{See also}
585
586\helpref{GetAlpha}{wximagegetalpha}, \helpref{SetAlpha}{wximagesetalpha}
587
588
589\membersection{wxImage::HasMask}\label{wximagehasmask}
590
591\constfunc{bool}{HasMask}{\void}
592
593Returns true if there is a mask active, false otherwise.
594
595
596\membersection{wxImage::GetOption}\label{wximagegetoption}
597
598\constfunc{wxString}{GetOption}{\param{const wxString\&}{ name}}
599
600Gets a user-defined option. The function is case-insensitive to {\it name}.
601
602For example, when saving as a JPEG file, the option {\bf quality} is
603used, which is a number between 0 and 100 (0 is terrible, 100 is very good).
604
605\wxheading{See also}
606
607\helpref{wxImage::SetOption}{wximagesetoption},\rtfsp
608\helpref{wxImage::GetOptionInt}{wximagegetoptionint},\rtfsp
609\helpref{wxImage::HasOption}{wximagehasoption}
610
611
612\membersection{wxImage::GetOptionInt}\label{wximagegetoptionint}
613
614\constfunc{int}{GetOptionInt}{\param{const wxString\&}{ name}}
615
616Gets a user-defined option as an integer. The function is case-insensitive to {\it name}.
617
618If the given option is not present, the function returns $0$. Use
619\helpref{wxImage::HasOption}{wximagehasoption} is $0$ is a possibly valid value
620for the option.
621
622\wxheading{See also}
623
624\helpref{wxImage::SetOption}{wximagesetoption},\rtfsp
625\helpref{wxImage::GetOption}{wximagegetoption}
626
627
628\membersection{wxImage::HasOption}\label{wximagehasoption}
629
630\constfunc{bool}{HasOption}{\param{const wxString\&}{ name}}
631
632Returns true if the given option is present. The function is case-insensitive to {\it name}.
633
634\wxheading{See also}
635
636\helpref{wxImage::SetOption}{wximagesetoption},\rtfsp
637\helpref{wxImage::GetOption}{wximagegetoption},\rtfsp
638\helpref{wxImage::GetOptionInt}{wximagegetoptionint}
639
640
641\membersection{wxImage::InitAlpha}\label{wximageinitalpha}
642
643\func{void}{InitAlpha}{\void}
644
645Initializes the image alpha channel data. It is an error to call it
646if the image already has alpha data. If it doesn't, alpha data will be
647by default initialized to all pixels being fully opaque. But if the image has a
648a mask colour, all mask pixels will be completely transparent.
649
650
651\membersection{wxImage::InitStandardHandlers}\label{wximageinitstandardhandlers}
652
653\func{static void}{InitStandardHandlers}{\void}
654
655Internal use only. Adds standard image format handlers. It only install BMP
656for the time being, which is used by wxBitmap.
657
658This function is called by wxWidgets on startup, and shouldn't be called by
659the user.
660
661\wxheading{See also}
662
663\helpref{wxImageHandler}{wximagehandler},
664\helpref{wxInitAllImageHandlers}{wxinitallimagehandlers}
665
666
667\membersection{wxImage::InsertHandler}\label{wximageinserthandler}
668
669\func{static void}{InsertHandler}{\param{wxImageHandler*}{ handler}}
670
671Adds a handler at the start of the static list of format handlers.
672
673\docparam{handler}{A new image format handler object. There is usually only one instance
674of a given handler class in an application session.}
675
676\wxheading{See also}
677
678\helpref{wxImageHandler}{wximagehandler}
679
680
681\membersection{wxImage::LoadFile}\label{wximageloadfile}
682
683\func{bool}{LoadFile}{\param{const wxString\&}{ name}, \param{long}{ type = wxBITMAP\_TYPE\_ANY}, \param{int}{ index = -1}}
684
685\func{bool}{LoadFile}{\param{const wxString\&}{ name}, \param{const wxString\&}{ mimetype}, \param{int}{ index = -1}}
686
687Loads an image from a file. If no handler type is provided, the library will
688try to autodetect the format.
689
690\func{bool}{LoadFile}{\param{wxInputStream\&}{ stream}, \param{long}{ type}, \param{int}{ index = -1}}
691
692\func{bool}{LoadFile}{\param{wxInputStream\&}{ stream}, \param{const wxString\&}{ mimetype}, \param{int}{ index = -1}}
693
694Loads an image from an input stream.
695
696\wxheading{Parameters}
697
698\docparam{name}{Name of the file from which to load the image.}
699
700\docparam{stream}{Opened input stream from which to load the image. Currently, the stream must support seeking.}
701
702\docparam{type}{One of the following values:
703
704\twocolwidtha{5cm}%
705\begin{twocollist}
706\twocolitem{{\bf wxBITMAP\_TYPE\_BMP}}{Load a Windows image file.}
707\twocolitem{{\bf wxBITMAP\_TYPE\_GIF}}{Load a GIF image file.}
708\twocolitem{{\bf wxBITMAP\_TYPE\_JPEG}}{Load a JPEG image file.}
709\twocolitem{{\bf wxBITMAP\_TYPE\_PCX}}{Load a PCX image file.}
710\twocolitem{{\bf wxBITMAP\_TYPE\_PNG}}{Load a PNG image file.}
711\twocolitem{{\bf wxBITMAP\_TYPE\_PNM}}{Load a PNM image file.}
712\twocolitem{{\bf wxBITMAP\_TYPE\_TIF}}{Load a TIFF image file.}
713\twocolitem{{\bf wxBITMAP\_TYPE\_XPM}}{Load a XPM image file.}
714\twocolitem{{\bf wxBITMAP\_TYPE\_ICO}}{Load a Windows icon file (ICO).}
715\twocolitem{{\bf wxBITMAP\_TYPE\_CUR}}{Load a Windows cursor file (CUR).}
716\twocolitem{\indexit{wxBITMAP\_TYPE\_ANI}}{Load a Windows animated cursor file (ANI).}
717\twocolitem{{\bf wxBITMAP\_TYPE\_ANY}}{Will try to autodetect the format.}
718\end{twocollist}}
719
720\docparam{mimetype}{MIME type string (for example 'image/jpeg')}
721
722\docparam{index}{Index of the image to load in the case that the image file contains multiple images.
723This is only used by GIF, ICO and TIFF handlers. The default value (-1) means
724"choose the default image" and is interpreted as the first image (index=0) by
725the GIF and TIFF handler and as the largest and most colourful one by the ICO handler.}
726
727\wxheading{Remarks}
728
729Depending on how wxWidgets has been configured, not all formats may be available.
730
731Note: you can use \helpref{GetOptionInt}{wximagegetoptionint} to get the
732hotspot for loaded cursor file:
733\begin{verbatim}
734 int hotspot_x = image.GetOptionInt(wxIMAGE_OPTION_CUR_HOTSPOT_X);
735 int hotspot_y = image.GetOptionInt(wxIMAGE_OPTION_CUR_HOTSPOT_Y);
736
737\end{verbatim}
738
739\wxheading{Return value}
740
741true if the operation succeeded, false otherwise. If the optional index parameter is out of range,
742false is returned and a call to wxLogError() takes place.
743
744\wxheading{See also}
745
746\helpref{wxImage::SaveFile}{wximagesavefile}
747
748\pythonnote{In place of a single overloaded method name, wxPython
749implements the following methods:\par
750\indented{2cm}{\begin{twocollist}
751\twocolitem{{\bf LoadFile(filename, type)}}{Loads an image of the given
752type from a file}
753\twocolitem{{\bf LoadMimeFile(filename, mimetype)}}{Loads an image of the given
754mimetype from a file}
755\end{twocollist}}
756}
757
758\perlnote{Methods supported by wxPerl are:\par
759\begin{itemize}
760\item{bitmap->LoadFile( name, type )}
761\item{bitmap->LoadFile( name, mimetype )}
762\end{itemize}
763}
764
765
766
767\membersection{wxImage::Ok}\label{wximageok}
768
769\constfunc{bool}{Ok}{\void}
770
771Returns true if image data is present.
772
773
774\membersection{wxImage::RemoveHandler}\label{wximageremovehandler}
775
776\func{static bool}{RemoveHandler}{\param{const wxString\& }{name}}
777
778Finds the handler with the given name, and removes it. The handler
779is not deleted.
780
781\docparam{name}{The handler name.}
782
783\wxheading{Return value}
784
785true if the handler was found and removed, false otherwise.
786
787\wxheading{See also}
788
789\helpref{wxImageHandler}{wximagehandler}
790
791
792\membersection{wxImage::Mirror}\label{wximagemirror}
793
794\constfunc{wxImage}{Mirror}{\param{bool}{ horizontally = true}}
795
796Returns a mirrored copy of the image. The parameter {\it horizontally}
797indicates the orientation.
798
799
800\membersection{wxImage::Replace}\label{wximagereplace}
801
802\func{void}{Replace}{\param{unsigned char}{ r1}, \param{unsigned char}{ g1}, \param{unsigned char}{ b1},
803\param{unsigned char}{ r2}, \param{unsigned char}{ g2}, \param{unsigned char}{ b2}}
804
805Replaces the colour specified by {\it r1,g1,b1} by the colour {\it r2,g2,b2}.
806
807
808\membersection{wxImage::Rescale}\label{wximagerescale}
809
810\func{wxImage \&}{Rescale}{\param{int}{ width}, \param{int}{ height}}
811
812Changes the size of the image in-place: after a call to this function, the
813image will have the given width and height.
814
815Returns the (modified) image itself.
816
817\wxheading{See also}
818
819\helpref{Scale}{wximagescale}
820
821
822\membersection{wxImage::Rotate}\label{wximagerotate}
823
824\func{wxImage}{Rotate}{\param{double}{ angle}, \param{const wxPoint\& }{rotationCentre},
825 \param{bool}{ interpolating = true}, \param{wxPoint*}{ offsetAfterRotation = NULL}}
826
827Rotates the image about the given point, by {\it angle} radians. Passing true
828to {\it interpolating} results in better image quality, but is slower. If the
829image has a mask, then the mask colour is used for the uncovered pixels in the
830rotated image background. Else, black (rgb 0, 0, 0) will be used.
831
832Returns the rotated image, leaving this image intact.
833
834
835\membersection{wxImage::Rotate90}\label{wximagerotate90}
836
837\constfunc{wxImage}{Rotate90}{\param{bool}{ clockwise = true}}
838
839Returns a copy of the image rotated 90 degrees in the direction
840indicated by {\it clockwise}.
841
842
843\membersection{wxImage::SaveFile}\label{wximagesavefile}
844
845\constfunc{bool}{SaveFile}{\param{const wxString\& }{name}, \param{int}{ type}}
846
847\constfunc{bool}{SaveFile}{\param{const wxString\& }{name}, \param{const wxString\&}{ mimetype}}
848
849Saves an image in the named file.
850
851\constfunc{bool}{SaveFile}{\param{const wxString\& }{name}}
852
853Saves an image in the named file. File type is determined from the extension of the
854file name. Note that this function may fail if the extension is not recognized! You
855can use one of the forms above to save images to files with non-standard extensions.
856
857\constfunc{bool}{SaveFile}{\param{wxOutputStream\& }{stream}, \param{int}{ type}}
858
859\constfunc{bool}{SaveFile}{\param{wxOutputStream\& }{stream}, \param{const wxString\&}{ mimetype}}
860
861Saves an image in the given stream.
862
863\wxheading{Parameters}
864
865\docparam{name}{Name of the file to save the image to.}
866
867\docparam{stream}{Opened output stream to save the image to.}
868
869\docparam{type}{Currently these types can be used:
870
871\twocolwidtha{5cm}%
872\begin{twocollist}
873\twocolitem{{\bf wxBITMAP\_TYPE\_BMP}}{Save a BMP image file.}
874\twocolitem{{\bf wxBITMAP\_TYPE\_JPEG}}{Save a JPEG image file.}
875\twocolitem{{\bf wxBITMAP\_TYPE\_PNG}}{Save a PNG image file.}
876\twocolitem{{\bf wxBITMAP\_TYPE\_PCX}}{Save a PCX image file (tries to save as 8-bit if possible, falls back to 24-bit otherwise).}
877\twocolitem{{\bf wxBITMAP\_TYPE\_PNM}}{Save a PNM image file (as raw RGB always).}
878\twocolitem{{\bf wxBITMAP\_TYPE\_TIFF}}{Save a TIFF image file.}
879\twocolitem{{\bf wxBITMAP\_TYPE\_XPM}}{Save a XPM image file.}
880\twocolitem{{\bf wxBITMAP\_TYPE\_ICO}}{Save a Windows icon file (ICO) (the size may be up to 255 wide by 127 high. A single image is saved in 8 colors at the size supplied).}
881\twocolitem{{\bf wxBITMAP\_TYPE\_CUR}}{Save a Windows cursor file (CUR).}
882\end{twocollist}}
883
884\docparam{mimetype}{MIME type.}
885
886\wxheading{Return value}
887
888true if the operation succeeded, false otherwise.
889
890\wxheading{Remarks}
891
892Depending on how wxWidgets has been configured, not all formats may be available.
893
894Note: you can use \helpref{GetOptionInt}{wximagegetoptionint} to set the
895hotspot before saving an image into a cursor file (default hotspot is in
896the centre of the image):
897\begin{verbatim}
898 image.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_X, hotspotX);
899 image.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_Y, hotspotY);
900
901\end{verbatim}
902
903\wxheading{See also}
904
905\helpref{wxImage::LoadFile}{wximageloadfile}
906
907\pythonnote{In place of a single overloaded method name, wxPython
908implements the following methods:\par
909\indented{2cm}{\begin{twocollist}
910\twocolitem{{\bf SaveFile(filename, type)}}{Saves the image using the given
911type to the named file}
912\twocolitem{{\bf SaveMimeFile(filename, mimetype)}}{Saves the image using the given
913mimetype to the named file}
914\end{twocollist}}
915}
916
917\perlnote{Methods supported by wxPerl are:\par
918\begin{itemize}
919\item{bitmap->SaveFile( name, type )}
920\item{bitmap->SaveFile( name, mimetype )}
921\end{itemize}
922}
923
924
925\membersection{wxImage::Scale}\label{wximagescale}
926
927\constfunc{wxImage}{Scale}{\param{int}{ width}, \param{int}{ height}}
928
929Returns a scaled version of the image. This is also useful for
930scaling bitmaps in general as the only other way to scale bitmaps
931is to blit a wxMemoryDC into another wxMemoryDC.
932
933It may be mentioned that the GTK port uses this function internally
934to scale bitmaps when using mapping modes in wxDC.
935
936Example:
937
938\begin{verbatim}
939 // get the bitmap from somewhere
940 wxBitmap bmp = ...;
941
942 // rescale it to have size of 32*32
943 if ( bmp.GetWidth() != 32 || bmp.GetHeight() != 32 )
944 {
945 wxImage image = bmp.ConvertToImage();
946 bmp = wxBitmap(image.Scale(32, 32));
947
948 // another possibility:
949 image.Rescale(32, 32);
950 bmp = image;
951 }
952
953\end{verbatim}
954
955\wxheading{See also}
956
957\helpref{Rescale}{wximagerescale}
958
959
960\membersection{wxImage::SetAlpha}\label{wximagesetalpha}
961
962\func{void}{SetAlpha}{\param{unsigned char *}{alpha = {\tt NULL}}}
963
964This function is similar to \helpref{SetData}{wximagesetdata} and has similar
965restrictions. The pointer passed to it may however be {\tt NULL} in which case
966the function will allocate the alpha array internally -- this is useful to add
967alpha channel data to an image which doesn't have any. If the pointer is not
968{\tt NULL}, it must have one byte for each image pixel and be allocated with
969{\tt malloc()}. wxImage takes ownership of the pointer and will free it.
970
971\func{void}{SetAlpha}{\param{int }{x}, \param{int }{y}, \param{unsigned char }{alpha}}
972
973Sets the alpha value for the given pixel. This function should only be called
974if the image has alpha channel data, use \helpref{HasAlpha}{wximagehasalpha} to
975check for this.
976
977
978\membersection{wxImage::SetData}\label{wximagesetdata}
979
980\func{void}{SetData}{\param{unsigned char*}{data}}
981
982Sets the image data without performing checks. The data given must have
983the size (width*height*3) or results will be unexpected. Don't use this
984method if you aren't sure you know what you are doing.
985
986The data must have been allocated with {\tt malloc()}, {\large {\bf NOT}} with
987{\tt operator new}.
988
989After this call the pointer to the data is owned by the wxImage object,
990that will be responsible for deleting it.
991Do not pass to this function a pointer obtained through
992\helpref{wxImage::GetData}{wximagegetdata}.
993
994
995\membersection{wxImage::SetMask}\label{wximagesetmask}
996
997\func{void}{SetMask}{\param{bool}{ hasMask = true}}
998
999Specifies whether there is a mask or not. The area of the mask is determined by the current mask colour.
1000
1001
1002\membersection{wxImage::SetMaskColour}\label{wximagesetmaskcolour}
1003
1004\func{void}{SetMaskColour}{\param{unsigned char }{red}, \param{unsigned char }{green}, \param{unsigned char }{blue}}
1005
1006Sets the mask colour for this image (and tells the image to use the mask).
1007
1008
1009\membersection{wxImage::SetMaskFromImage}\label{wximagesetmaskfromimage}
1010
1011\func{bool}{SetMaskFromImage}{\param{const wxImage\&}{ mask}, \param{unsigned char}{ mr}, \param{unsigned char}{ mg}, \param{unsigned char}{ mb}}
1012
1013\wxheading{Parameters}
1014
1015\docparam{mask}{The mask image to extract mask shape from. Must have same dimensions as the image.}
1016
1017\docparam{mr,mg,mb}{RGB value of pixels in {\it mask} that will be used to create the mask.}
1018
1019Sets image's mask so that the pixels that have RGB value of {\it mr,mg,mb}
1020in {\it mask} will be masked in the image. This is done by first finding an
1021unused colour in the image, setting this colour as the mask colour and then
1022using this colour to draw all pixels in the image who corresponding pixel
1023in {\it mask} has given RGB value.
1024
1025\wxheading{Return value}
1026
1027Returns false if {\it mask} does not have same dimensions as the image or if
1028there is no unused colour left. Returns true if the mask was successfully
1029applied.
1030
1031\wxheading{Notes}
1032
1033Note that this method involves computing the histogram, which is
1034computationally intensive operation.
1035
1036
1037\membersection{wxImage::SetOption}\label{wximagesetoption}
1038
1039\func{void}{SetOption}{\param{const wxString\&}{ name}, \param{const wxString\&}{ value}}
1040
1041\func{void}{SetOption}{\param{const wxString\&}{ name}, \param{int}{ value}}
1042
1043Sets a user-defined option. The function is case-insensitive to {\it name}.
1044
1045For example, when saving as a JPEG file, the option {\bf quality} is
1046used, which is a number between 0 and 100 (0 is terrible, 100 is very good).
1047
1048\wxheading{See also}
1049
1050\helpref{wxImage::GetOption}{wximagegetoption},\rtfsp
1051\helpref{wxImage::GetOptionInt}{wximagegetoptionint},\rtfsp
1052\helpref{wxImage::HasOption}{wximagehasoption}
1053
1054
1055\membersection{wxImage::SetPalette}\label{wximagesetpalette}
1056
1057\func{void}{SetPalette}{\param{const wxPalette\&}{ palette}}
1058
1059Associates a palette with the image. The palette may be used when converting
1060wxImage to wxBitmap (MSW only at present) or in file save operations (none as yet).
1061
1062
1063\membersection{wxImage::SetRGB}\label{wximagesetrgb}
1064
1065\func{void}{SetRGB}{\param{int }{x}, \param{int }{y}, \param{unsigned char }{red}, \param{unsigned char }{green}, \param{unsigned char }{blue}}
1066
1067Sets the pixel at the given coordinate. This routine performs bounds-checks
1068for the coordinate so it can be considered a safe way to manipulate the
1069data, but in some cases this might be too slow so that the data will have to
1070be set directly. In that case you will have to get access to the image data
1071using the \helpref{GetData}{wximagegetdata} method.
1072
1073
1074\membersection{wxImage::operator $=$}\label{wximageassign}
1075
1076\func{wxImage\& }{operator $=$}{\param{const wxImage\& }{image}}
1077
1078Assignment operator. This operator does not copy any data, but instead
1079passes a pointer to the data in {\it image} and increments a reference
1080counter. It is a fast operation.
1081
1082\wxheading{Parameters}
1083
1084\docparam{image}{Image to assign.}
1085
1086\wxheading{Return value}
1087
1088Returns 'this' object.
1089
1090
1091\membersection{wxImage::operator $==$}\label{wximageequal}
1092
1093\constfunc{bool}{operator $==$}{\param{const wxImage\& }{image}}
1094
1095Equality operator. This operator tests whether the internal data pointers are
1096equal (a fast test).
1097
1098\wxheading{Parameters}
1099
1100\docparam{image}{Image to compare with 'this'}
1101
1102\wxheading{Return value}
1103
1104Returns true if the images were effectively equal, false otherwise.
1105
1106
1107\membersection{wxImage::operator $!=$}\label{wximagenotequal}
1108
1109\constfunc{bool}{operator $!=$}{\param{const wxImage\& }{image}}
1110
1111Inequality operator. This operator tests whether the internal data pointers are
1112unequal (a fast test).
1113
1114\wxheading{Parameters}
1115
1116\docparam{image}{Image to compare with 'this'}
1117
1118\wxheading{Return value}
1119
1120Returns true if the images were unequal, false otherwise.
1121
1122\section{\class{wxImageHandler}}\label{wximagehandler}
1123
1124This is the base class for implementing image file loading/saving, and image creation from data.
1125It is used within wxImage and is not normally seen by the application.
1126
1127If you wish to extend the capabilities of wxImage, derive a class from wxImageHandler
1128and add the handler using \helpref{wxImage::AddHandler}{wximageaddhandler} in your
1129application initialisation.
1130
1131\wxheading{Note (Legal Issue)}
1132
1133This software is based in part on the work of the Independent JPEG Group.
1134
1135(Applies when wxWidgets is linked with JPEG support. wxJPEGHandler uses libjpeg
1136created by IJG.)
1137
1138\wxheading{Derived from}
1139
1140\helpref{wxObject}{wxobject}
1141
1142\wxheading{Include files}
1143
1144<wx/image.h>
1145
1146\wxheading{See also}
1147
1148\helpref{wxImage}{wximage},
1149\helpref{wxInitAllImageHandlers}{wxinitallimagehandlers}
1150
1151\latexignore{\rtfignore{\wxheading{Members}}}
1152
1153
1154\membersection{wxImageHandler::wxImageHandler}\label{wximagehandlerctor}
1155
1156\func{}{wxImageHandler}{\void}
1157
1158Default constructor. In your own default constructor, initialise the members
1159m\_name, m\_extension and m\_type.
1160
1161
1162\membersection{wxImageHandler::\destruct{wxImageHandler}}\label{wximagehandlerdtor}
1163
1164\func{}{\destruct{wxImageHandler}}{\void}
1165
1166Destroys the wxImageHandler object.
1167
1168
1169\membersection{wxImageHandler::GetName}\label{wximagehandlergetname}
1170
1171\constfunc{wxString}{GetName}{\void}
1172
1173Gets the name of this handler.
1174
1175
1176\membersection{wxImageHandler::GetExtension}\label{wximagehandlergetextension}
1177
1178\constfunc{wxString}{GetExtension}{\void}
1179
1180Gets the file extension associated with this handler.
1181
1182
1183\membersection{wxImageHandler::GetImageCount}\label{wximagehandlergetimagecount}
1184
1185\func{int}{GetImageCount}{\param{wxInputStream\&}{ stream}}
1186
1187If the image file contains more than one image and the image handler is capable
1188of retrieving these individually, this function will return the number of
1189available images.
1190
1191\docparam{stream}{Opened input stream for reading image data. Currently, the stream must support seeking.}
1192
1193\wxheading{Return value}
1194
1195Number of available images. For most image handlers, this is 1 (exceptions
1196are TIFF and ICO formats).
1197
1198
1199\membersection{wxImageHandler::GetType}\label{wximagehandlergettype}
1200
1201\constfunc{long}{GetType}{\void}
1202
1203Gets the image type associated with this handler.
1204
1205
1206\membersection{wxImageHandler::GetMimeType}\label{wximagehandlergetmimetype}
1207
1208\constfunc{wxString}{GetMimeType}{\void}
1209
1210Gets the MIME type associated with this handler.
1211
1212
1213\membersection{wxImageHandler::LoadFile}\label{wximagehandlerloadfile}
1214
1215\func{bool}{LoadFile}{\param{wxImage* }{image}, \param{wxInputStream\&}{ stream}, \param{bool}{ verbose=true}, \param{int}{ index=0}}
1216
1217Loads a image from a stream, putting the resulting data into {\it image}. If the image file contains
1218more than one image and the image handler is capable of retrieving these individually, {\it index}
1219indicates which image to read from the stream.
1220
1221\wxheading{Parameters}
1222
1223\docparam{image}{The image object which is to be affected by this operation.}
1224
1225\docparam{stream}{Opened input stream for reading image data.}
1226
1227\docparam{verbose}{If set to true, errors reported by the image handler will produce wxLogMessages.}
1228
1229\docparam{index}{The index of the image in the file (starting from zero).}
1230
1231\wxheading{Return value}
1232
1233true if the operation succeeded, false otherwise.
1234
1235\wxheading{See also}
1236
1237\helpref{wxImage::LoadFile}{wximageloadfile},
1238\helpref{wxImage::SaveFile}{wximagesavefile},
1239\helpref{wxImageHandler::SaveFile}{wximagehandlersavefile}
1240
1241
1242\membersection{wxImageHandler::SaveFile}\label{wximagehandlersavefile}
1243
1244\func{bool}{SaveFile}{\param{wxImage* }{image}, \param{wxOutputStream\& }{stream}}
1245
1246Saves a image in the output stream.
1247
1248\wxheading{Parameters}
1249
1250\docparam{image}{The image object which is to be affected by this operation.}
1251
1252\docparam{stream}{Opened output stream for writing the data.}
1253
1254\wxheading{Return value}
1255
1256true if the operation succeeded, false otherwise.
1257
1258\wxheading{See also}
1259
1260\helpref{wxImage::LoadFile}{wximageloadfile},
1261\helpref{wxImage::SaveFile}{wximagesavefile},
1262\helpref{wxImageHandler::LoadFile}{wximagehandlerloadfile}
1263
1264
1265\membersection{wxImageHandler::SetName}\label{wximagehandlersetname}
1266
1267\func{void}{SetName}{\param{const wxString\& }{name}}
1268
1269Sets the handler name.
1270
1271\wxheading{Parameters}
1272
1273\docparam{name}{Handler name.}
1274
1275
1276\membersection{wxImageHandler::SetExtension}\label{wximagehandlersetextension}
1277
1278\func{void}{SetExtension}{\param{const wxString\& }{extension}}
1279
1280Sets the handler extension.
1281
1282\wxheading{Parameters}
1283
1284\docparam{extension}{Handler extension.}
1285
1286
1287\membersection{wxImageHandler::SetMimeType}\label{wximagehandlersetmimetype}
1288
1289\func{void}{SetMimeType}{\param{const wxString\& }{mimetype}}
1290
1291Sets the handler MIME type.
1292
1293\wxheading{Parameters}
1294
1295\docparam{mimename}{Handler MIME type.}
1296
1297
1298\membersection{wxImageHandler::SetType}\label{wximagehandlersettype}
1299
1300\func{void}{SetType}{\param{long }{type}}
1301
1302Sets the handler type.
1303
1304\wxheading{Parameters}
1305
1306\docparam{name}{Handler type.}
1307