]> git.saurik.com Git - wxWidgets.git/blame - wxPython/src/_image.i
warning fix
[wxWidgets.git] / wxPython / src / _image.i
CommitLineData
cf694132 1/////////////////////////////////////////////////////////////////////////////
d14a1e28
RD
2// Name: _image.i
3// Purpose: SWIG definitions for wxImage and such
cf694132
RD
4//
5// Author: Robin Dunn
6//
d14a1e28 7// Created: 25-Sept-2000
cf694132 8// RCS-ID: $Id$
d14a1e28 9// Copyright: (c) 2003 by Total Control Software
cf694132
RD
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
d14a1e28 13// Not a %module
cf694132 14
d14a1e28
RD
15
16//---------------------------------------------------------------------------
cf694132
RD
17
18%{
d14a1e28 19#include "wx/wxPython/pyistream.h"
cf694132
RD
20%}
21
9cbf6f6e 22//---------------------------------------------------------------------------
d14a1e28 23%newgroup
9cbf6f6e 24
cf694132 25
9416aa89 26class wxImageHandler : public wxObject {
cf694132 27public:
1dec68aa 28 // wxImageHandler(); Abstract Base Class
cf694132
RD
29 wxString GetName();
30 wxString GetExtension();
31 long GetType();
32 wxString GetMimeType();
33
34 //bool LoadFile(wxImage* image, wxInputStream& stream);
35 //bool SaveFile(wxImage* image, wxOutputStream& stream);
b5a5d647
RD
36 //virtual int GetImageCount( wxInputStream& stream );
37 //bool CanRead( wxInputStream& stream );
38
39 bool CanRead( const wxString& name );
cf694132
RD
40
41 void SetName(const wxString& name);
42 void SetExtension(const wxString& extension);
43 void SetType(long type);
44 void SetMimeType(const wxString& mimetype);
45};
46
cf694132 47
d14a1e28 48//---------------------------------------------------------------------------
cf694132 49
d14a1e28
RD
50class wxImageHistogram /* : public wxImageHistogramBase */
51{
06c0fba4 52public:
d14a1e28 53 wxImageHistogram();
cf694132 54
d07d2bc9 55 DocStr(MakeKey, "Get the key in the histogram for the given RGB values", "");
d14a1e28
RD
56 static unsigned long MakeKey(unsigned char r,
57 unsigned char g,
58 unsigned char b);
cf694132 59
dd9f7fea
RD
60 DocDeclAStr(
61 bool, FindFirstUnusedColour(unsigned char *OUTPUT,
62 unsigned char *OUTPUT,
63 unsigned char *OUTPUT,
64 unsigned char startR = 1,
65 unsigned char startG = 0,
66 unsigned char startB = 0 ) const,
67 "FindFirstUnusedColour(int startR=1, int startG=0, int startB=0) -> (success, r, g, b)",
d07d2bc9
RD
68 "Find first colour that is not used in the image and has higher RGB
69values than startR, startG, startB. Returns a tuple consisting of a
70success flag and rgb values.", "");
9b3d3bc4
RD
71};
72
73
cf694132
RD
74//---------------------------------------------------------------------------
75
d14a1e28 76
9416aa89 77class wxImage : public wxObject {
cf694132 78public:
1b8c7ba6
RD
79 DocCtorStr(
80 wxImage( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 ),
81 "", "");
82
cf694132
RD
83 ~wxImage();
84
d14a1e28 85 // Alternate constructors
1b8c7ba6
RD
86 DocCtorStrName(
87 wxImage(const wxString& name, const wxString& mimetype, int index = -1),
88 "", "",
89 ImageFromMime);
90
91 DocCtorStrName(
92 wxImage(wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1),
93 "", "",
94 ImageFromStream);
95
96 DocCtorStrName(
97 wxImage(wxInputStream& stream, const wxString& mimetype, int index = -1 ),
98 "", "",
99 ImageFromStreamMime);
100
d14a1e28 101 %extend {
1b8c7ba6
RD
102 %rename(EmptyImage) wxImage(int width=0, int height=0, bool clear = true);
103 wxImage(int width=0, int height=0, bool clear = true)
104 {
d14a1e28
RD
105 if (width > 0 && height > 0)
106 return new wxImage(width, height, clear);
107 else
108 return new wxImage;
be43ef04 109 }
ab1f7d2a
RD
110
111 MustHaveApp(wxImage(const wxBitmap &bitmap));
1b8c7ba6
RD
112 %rename(ImageFromBitmap) wxImage(const wxBitmap &bitmap);
113 wxImage(const wxBitmap &bitmap)
114 {
d14a1e28
RD
115 return new wxImage(bitmap.ConvertToImage());
116 }
be43ef04 117
1b8c7ba6
RD
118 %rename(ImageFromData) wxImage(int width, int height, unsigned char* data);
119 wxImage(int width, int height, unsigned char* data)
120 {
d14a1e28
RD
121 // Copy the source data so the wxImage can clean it up later
122 unsigned char* copy = (unsigned char*)malloc(width*height*3);
123 if (copy == NULL) {
124 PyErr_NoMemory();
125 return NULL;
126 }
127 memcpy(copy, data, width*height*3);
a72f4631 128 return new wxImage(width, height, copy, false);
d14a1e28 129 }
1b8c7ba6
RD
130
131
132 %rename(ImageFromDataWithAlpha) wxImage(int width, int height, unsigned char* data, unsigned char* alpha);
133 wxImage(int width, int height, unsigned char* data, unsigned char* alpha)
134 {
c6d42899
RD
135 // Copy the source data so the wxImage can clean it up later
136 unsigned char* dcopy = (unsigned char*)malloc(width*height*3);
137 if (dcopy == NULL) {
138 PyErr_NoMemory();
139 return NULL;
140 }
141 memcpy(dcopy, data, width*height*3);
142 unsigned char* acopy = (unsigned char*)malloc(width*height);
143 if (acopy == NULL) {
144 PyErr_NoMemory();
145 return NULL;
146 }
147 memcpy(acopy, alpha, width*height);
148
149 return new wxImage(width, height, dcopy, acopy, false);
150 }
d14a1e28 151 }
be43ef04 152
cf694132
RD
153 void Create( int width, int height );
154 void Destroy();
6c0168c9 155
cf694132 156 wxImage Scale( int width, int height );
9cbf6f6e 157 wxImage ShrinkBy( int xFactor , int yFactor ) const ;
f6bcfd97 158 wxImage& Rescale(int width, int height);
cf694132
RD
159
160 void SetRGB( int x, int y, unsigned char r, unsigned char g, unsigned char b );
161 unsigned char GetRed( int x, int y );
162 unsigned char GetGreen( int x, int y );
163 unsigned char GetBlue( int x, int y );
164
9cbf6f6e
RD
165 void SetAlpha(int x, int y, unsigned char alpha);
166 unsigned char GetAlpha(int x, int y);
167 bool HasAlpha();
168
655e17cf
RD
169 DocDeclStr(
170 void , InitAlpha(),
171 "Initializes the image alpha channel data. It is an error to call it if
172the image already has alpha data. If it doesn't, alpha data will be by
173default initialized to all pixels being fully opaque. But if the image
174has a a mask colour, all mask pixels will be completely transparent.", "");
175
176
9cbf6f6e 177 // find first colour that is not used in the image and has higher
68bc8549 178 // RGB values than <startR,startG,startB>
dd9f7fea
RD
179 DocDeclAStr(
180 bool, FindFirstUnusedColour( byte *OUTPUT, byte *OUTPUT, byte *OUTPUT,
181 byte startR = 0, byte startG = 0, byte startB = 0 ) const,
182 "FindFirstUnusedColour(int startR=1, int startG=0, int startB=0) -> (success, r, g, b)",
d07d2bc9
RD
183 "Find first colour that is not used in the image and has higher RGB
184values than startR, startG, startB. Returns a tuple consisting of a
185success flag and rgb values.", "");
dd9f7fea 186
125c972b
RD
187
188 DocDeclStr(
189 bool , ConvertAlphaToMask(byte threshold = 128),
190 "If the image has alpha channel, this method converts it to mask. All pixels
191with alpha value less than ``threshold`` are replaced with mask colour and the
192alpha channel is removed. Mask colour is chosen automatically using
193`FindFirstUnusedColour`.
194
195If the image image doesn't have alpha channel, ConvertAlphaToMask does
196nothing.", "");
197
198
6f7ecb3b
RD
199 DocDeclStr(
200 bool , ConvertColourToAlpha( unsigned char r, unsigned char g, unsigned char b ),
201 "This method converts an image where the original alpha information is
202only available as a shades of a colour (actually shades of grey)
203typically when you draw anti-aliased text into a bitmap. The DC
204drawing routines draw grey values on the black background although
205they actually mean to draw white with differnt alpha values. This
206method reverses it, assuming a black (!) background and white text.
207The method will then fill up the whole image with the colour given.", "");
208
209
125c972b 210
68bc8549
RD
211 // Set image's mask to the area of 'mask' that has <mr,mg,mb> colour
212 bool SetMaskFromImage(const wxImage & mask,
213 byte mr, byte mg, byte mb);
214
db0ff83e
RD
215// void DoFloodFill (wxCoord x, wxCoord y,
216// const wxBrush & fillBrush,
217// const wxColour& testColour,
218// int style = wxFLOOD_SURFACE,
219// int LogicalFunction = wxCOPY /* currently unused */ ) ;
68bc8549 220
96bfd053 221 static bool CanRead( const wxString& name );
b5a5d647
RD
222 static int GetImageCount( const wxString& name, long type = wxBITMAP_TYPE_ANY );
223
224 bool LoadFile( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
1b8c7ba6 225 %Rename(LoadMimeFile, bool, LoadFile( const wxString& name, const wxString& mimetype, int index = -1 ));
cf694132
RD
226
227 bool SaveFile( const wxString& name, int type );
1b8c7ba6 228 %Rename(SaveMimeFile, bool, SaveFile( const wxString& name, const wxString& mimetype ));
cf694132 229
1b8c7ba6
RD
230 %Rename(CanReadStream, static bool, CanRead( wxInputStream& stream ));
231 %Rename(LoadStream, bool, LoadFile( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1 ));
232 %Rename(LoadMimeStream, bool, LoadFile( wxInputStream& stream, const wxString& mimetype, int index = -1 ));
f74ff5ef 233
cf694132
RD
234 bool Ok();
235 int GetWidth();
236 int GetHeight();
237
ba938c3d
RD
238 %extend {
239 wxSize GetSize() {
240 wxSize size(self->GetWidth(), self->GetHeight());
241 return size;
242 }
243 }
244
9d8bd15f 245 wxImage GetSubImage(const wxRect& rect);
f6bcfd97
BP
246 wxImage Copy();
247 void Paste( const wxImage &image, int x, int y );
9d8bd15f 248
1dc2f865
RD
249 //unsigned char *GetData();
250 //void SetData( unsigned char *data );
251
d14a1e28 252 %extend {
9cbf6f6e 253 PyObject* GetData() {
d55d6b3f
RD
254 unsigned char* data = self->GetData();
255 int len = self->GetWidth() * self->GetHeight() * 3;
d14a1e28
RD
256 PyObject* rv;
257 wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len));
258 return rv;
d55d6b3f 259 }
9cbf6f6e
RD
260 void SetData(PyObject* data) {
261 unsigned char* dataPtr;
d55d6b3f 262
9cbf6f6e 263 if (! PyString_Check(data)) {
debff7aa
RD
264 wxPyBLOCK_THREADS(PyErr_SetString(PyExc_TypeError,
265 "Expected string object"));
9cbf6f6e
RD
266 return /* NULL */ ;
267 }
268
269 size_t len = self->GetWidth() * self->GetHeight() * 3;
270 dataPtr = (unsigned char*) malloc(len);
d14a1e28 271 wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
9cbf6f6e
RD
272 self->SetData(dataPtr);
273 // wxImage takes ownership of dataPtr...
274 }
275
276
277
278 PyObject* GetDataBuffer() {
1dc2f865
RD
279 unsigned char* data = self->GetData();
280 int len = self->GetWidth() * self->GetHeight() * 3;
d14a1e28
RD
281 PyObject* rv;
282 wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
283 return rv;
1dc2f865 284 }
1e4a197e
RD
285 void SetDataBuffer(PyObject* data) {
286 unsigned char* buffer;
287 int size;
288
da32eb53 289 bool blocked = wxPyBeginBlockThreads();
d14a1e28
RD
290 if (!PyArg_Parse(data, "t#", &buffer, &size))
291 goto done;
1e4a197e
RD
292
293 if (size != self->GetWidth() * self->GetHeight() * 3) {
294 PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
d14a1e28 295 goto done;
1e4a197e 296 }
1e4a197e 297 self->SetData(buffer);
d14a1e28 298 done:
da32eb53 299 wxPyEndBlockThreads(blocked);
1e4a197e
RD
300 }
301
9cbf6f6e
RD
302
303
304 PyObject* GetAlphaData() {
305 unsigned char* data = self->GetAlpha();
306 if (! data) {
307 RETURN_NONE();
308 } else {
309 int len = self->GetWidth() * self->GetHeight();
d14a1e28
RD
310 PyObject* rv;
311 wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len) );
312 return rv;
9cbf6f6e
RD
313 }
314 }
315 void SetAlphaData(PyObject* data) {
1dc2f865
RD
316 unsigned char* dataPtr;
317
318 if (! PyString_Check(data)) {
319 PyErr_SetString(PyExc_TypeError, "Expected string object");
320 return /* NULL */ ;
321 }
9d8bd15f 322
9cbf6f6e 323 size_t len = self->GetWidth() * self->GetHeight();
185d7c3e 324 dataPtr = (unsigned char*) malloc(len);
d14a1e28 325 wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
9cbf6f6e 326 self->SetAlpha(dataPtr);
3b5ccda1 327 // wxImage takes ownership of dataPtr...
1dc2f865 328 }
9cbf6f6e
RD
329
330
331
332 PyObject* GetAlphaBuffer() {
333 unsigned char* data = self->GetAlpha();
334 int len = self->GetWidth() * self->GetHeight();
d14a1e28
RD
335 PyObject* rv;
336 wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
337 return rv;
9cbf6f6e
RD
338 }
339 void SetAlphaBuffer(PyObject* data) {
340 unsigned char* buffer;
341 int size;
342
da32eb53 343 bool blocked = wxPyBeginBlockThreads();
d14a1e28
RD
344 if (!PyArg_Parse(data, "t#", &buffer, &size))
345 goto done;
9cbf6f6e
RD
346
347 if (size != self->GetWidth() * self->GetHeight()) {
348 PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
d14a1e28 349 goto done;
9cbf6f6e
RD
350 }
351 self->SetAlpha(buffer);
d14a1e28 352 done:
da32eb53 353 wxPyEndBlockThreads(blocked);
9cbf6f6e 354 }
1dc2f865 355 }
cf694132
RD
356
357 void SetMaskColour( unsigned char r, unsigned char g, unsigned char b );
358 unsigned char GetMaskRed();
359 unsigned char GetMaskGreen();
360 unsigned char GetMaskBlue();
a72f4631 361 void SetMask( bool mask = true );
cf694132
RD
362 bool HasMask();
363
f6bcfd97 364 wxImage Rotate(double angle, const wxPoint & centre_of_rotation,
a72f4631
RD
365 bool interpolating = true, wxPoint * offset_after_rotation = NULL) const ;
366 wxImage Rotate90( bool clockwise = true ) ;
367 wxImage Mirror( bool horizontally = true ) ;
f6bcfd97
BP
368
369 void Replace( unsigned char r1, unsigned char g1, unsigned char b1,
370 unsigned char r2, unsigned char g2, unsigned char b2 );
371
6c0168c9
RD
372 // convert to monochrome image (<r,g,b> will be replaced by white, everything else by black)
373 wxImage ConvertToMono( unsigned char r, unsigned char g, unsigned char b ) const;
374
375 void SetOption(const wxString& name, const wxString& value);
1b8c7ba6 376 %Rename(SetOptionInt, void, SetOption(const wxString& name, int value));
6c0168c9
RD
377 wxString GetOption(const wxString& name) const;
378 int GetOptionInt(const wxString& name) const;
379 bool HasOption(const wxString& name) const;
380
f6bcfd97 381 unsigned long CountColours( unsigned long stopafter = (unsigned long) -1 );
9cbf6f6e 382 unsigned long ComputeHistogram( wxImageHistogram& h );
f6bcfd97 383
96bfd053
RD
384 static void AddHandler( wxImageHandler *handler );
385 static void InsertHandler( wxImageHandler *handler );
386 static bool RemoveHandler( const wxString& name );
3ef86e32 387 static wxString GetImageExtWildcard();
b96c7a38
RD
388
389
ab1f7d2a
RD
390MustHaveApp(ConvertToBitmap);
391MustHaveApp(ConvertToMonoBitmap);
be43ef04 392
d14a1e28 393 %extend {
12523ae4
RD
394 wxBitmap ConvertToBitmap(int depth=-1) {
395 wxBitmap bitmap(*self, depth);
b96c7a38
RD
396 return bitmap;
397 }
398
399 wxBitmap ConvertToMonoBitmap( unsigned char red,
400 unsigned char green,
401 unsigned char blue ) {
402 wxImage mono = self->ConvertToMono( red, green, blue );
403 wxBitmap bitmap( mono, 1 );
404 return bitmap;
405 }
406 }
1fded56b 407
d14a1e28 408 %pythoncode { def __nonzero__(self): return self.Ok() }
cf694132
RD
409};
410
926bb76c 411
f74ff5ef 412
a3150741
RD
413///void wxInitAllImageHandlers();
414
415%pythoncode {
416 def InitAllImageHandlers():
417 """
418 The former functionality of InitAllImageHanders is now done internal to
419 the _core_ extension module and so this function has become a simple NOP.
420 """
421 pass
422}
423
cf694132 424
f74ff5ef 425
d14a1e28
RD
426// See also wxPy_ReinitStockObjects in helpers.cpp
427%immutable;
428const wxImage wxNullImage;
429%mutable;
cf694132 430
d14a1e28 431//---------------------------------------------------------------------------
f74ff5ef 432
655e17cf 433MAKE_CONST_WXSTRING(IMAGE_OPTION_FILENAME);
d14a1e28
RD
434MAKE_CONST_WXSTRING(IMAGE_OPTION_BMP_FORMAT);
435MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_X);
436MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_Y);
437MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTION);
655e17cf
RD
438MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTIONX);
439MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTIONY);
be43ef04 440MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTIONUNIT);
f74ff5ef 441
d14a1e28
RD
442enum
443{
444 wxIMAGE_RESOLUTION_INCHES = 1,
445 wxIMAGE_RESOLUTION_CM = 2
446};
f74ff5ef
RD
447
448
655e17cf
RD
449MAKE_CONST_WXSTRING(IMAGE_OPTION_BITSPERSAMPLE);
450MAKE_CONST_WXSTRING(IMAGE_OPTION_SAMPLESPERPIXEL);
451MAKE_CONST_WXSTRING(IMAGE_OPTION_COMPRESSION);
452MAKE_CONST_WXSTRING(IMAGE_OPTION_IMAGEDESCRIPTOR);
453
454
d14a1e28
RD
455enum
456{
457 wxBMP_24BPP = 24, // default, do not need to set
458 //wxBMP_16BPP = 16, // wxQuantize can only do 236 colors?
459 wxBMP_8BPP = 8, // 8bpp, quantized colors
460 wxBMP_8BPP_GREY = 9, // 8bpp, rgb averaged to greys
461 wxBMP_8BPP_GRAY = wxBMP_8BPP_GREY,
462 wxBMP_8BPP_RED = 10, // 8bpp, red used as greyscale
463 wxBMP_8BPP_PALETTE = 11, // 8bpp, use the wxImage's palette
464 wxBMP_4BPP = 4, // 4bpp, quantized colors
465 wxBMP_1BPP = 1, // 1bpp, quantized "colors"
466 wxBMP_1BPP_BW = 2 // 1bpp, black & white from red
467};
f74ff5ef
RD
468
469
d14a1e28
RD
470class wxBMPHandler : public wxImageHandler {
471public:
472 wxBMPHandler();
473};
cf694132 474
d14a1e28
RD
475class wxICOHandler : public wxBMPHandler {
476public:
477 wxICOHandler();
478};
f74ff5ef 479
d14a1e28
RD
480class wxCURHandler : public wxICOHandler {
481public:
482 wxCURHandler();
483};
f74ff5ef 484
d14a1e28
RD
485class wxANIHandler : public wxCURHandler {
486public:
487 wxANIHandler();
488};
06c0fba4 489
0a651eb8 490
d14a1e28 491//---------------------------------------------------------------------------
0a651eb8 492
d14a1e28
RD
493class wxPNGHandler : public wxImageHandler {
494public:
495 wxPNGHandler();
496};
0a651eb8 497
0a651eb8 498
d14a1e28
RD
499class wxGIFHandler : public wxImageHandler {
500public:
501 wxGIFHandler();
502};
0a651eb8
RD
503
504
d14a1e28
RD
505class wxPCXHandler : public wxImageHandler {
506public:
507 wxPCXHandler();
508};
926bb76c 509
926bb76c 510
d14a1e28
RD
511class wxJPEGHandler : public wxImageHandler {
512public:
513 wxJPEGHandler();
514};
926bb76c 515
926bb76c 516
d14a1e28
RD
517class wxPNMHandler : public wxImageHandler {
518public:
519 wxPNMHandler();
520};
521
522class wxXPMHandler : public wxImageHandler {
523public:
524 wxXPMHandler();
525};
526
527class wxTIFFHandler : public wxImageHandler {
528public:
529 wxTIFFHandler();
530};
531
532
533#if wxUSE_IFF
534class wxIFFHandler : public wxImageHandler {
535public:
536 wxIFFHandler();
537};
538#endif
926bb76c 539
be43ef04
RD
540//---------------------------------------------------------------------------
541
542%{
543#include <wx/quantize.h>
544%}
545
546enum {
547 wxQUANTIZE_INCLUDE_WINDOWS_COLOURS,
548// wxQUANTIZE_RETURN_8BIT_DATA,
549 wxQUANTIZE_FILL_DESTINATION_IMAGE
550};
551
552
553DocStr(wxQuantize,
554 "Performs quantization, or colour reduction, on a wxImage.", "");
555
556class wxQuantize /*: public wxObject */
557{
558public:
559
560 %extend {
561 DocStr(
562 Quantize,
563 "Reduce the colours in the source image and put the result into the
39101468 564destination image, setting the palette in the destination if
be43ef04
RD
565needed. Both images may be the same, to overwrite the source image.", "
566:todo: Create a version that returns the wx.Palette used.");
567
568 static bool Quantize(const wxImage& src, wxImage& dest, int desiredNoColours = 236,
569 int flags = wxQUANTIZE_INCLUDE_WINDOWS_COLOURS|wxQUANTIZE_FILL_DESTINATION_IMAGE)
570 {
571 return wxQuantize::Quantize(src, dest,
572 //NULL, // palette
573 desiredNoColours,
574 NULL, // eightBitData
575 flags);
576 }
577 }
578};
579
580
cf694132 581//---------------------------------------------------------------------------