]> git.saurik.com Git - wxWidgets.git/blame - wxPython/src/_image.i
Docstrings
[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:
b5a5d647 79 wxImage( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
cf694132
RD
80 ~wxImage();
81
d14a1e28
RD
82 // Alternate constructors
83 %name(ImageFromMime) wxImage(const wxString& name, const wxString& mimetype, int index = -1);
84 %name(ImageFromStream) wxImage(wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1);
85 %name(ImageFromStreamMime) wxImage(wxInputStream& stream, const wxString& mimetype, int index = -1 );
86 %extend {
dd9f7fea 87 %name(EmptyImage) wxImage(int width=0, int height=0, bool clear = True) {
d14a1e28
RD
88 if (width > 0 && height > 0)
89 return new wxImage(width, height, clear);
90 else
91 return new wxImage;
92 }
dce2bd22 93
d14a1e28
RD
94 %name(ImageFromBitmap) wxImage(const wxBitmap &bitmap) {
95 return new wxImage(bitmap.ConvertToImage());
96 }
97
98 %name(ImageFromData) wxImage(int width, int height, unsigned char* data) {
99 // Copy the source data so the wxImage can clean it up later
100 unsigned char* copy = (unsigned char*)malloc(width*height*3);
101 if (copy == NULL) {
102 PyErr_NoMemory();
103 return NULL;
104 }
105 memcpy(copy, data, width*height*3);
dd9f7fea 106 return new wxImage(width, height, copy, False);
d14a1e28
RD
107 }
108 }
109
cf694132
RD
110 void Create( int width, int height );
111 void Destroy();
6c0168c9 112
cf694132 113 wxImage Scale( int width, int height );
9cbf6f6e 114 wxImage ShrinkBy( int xFactor , int yFactor ) const ;
f6bcfd97 115 wxImage& Rescale(int width, int height);
cf694132
RD
116
117 void SetRGB( int x, int y, unsigned char r, unsigned char g, unsigned char b );
118 unsigned char GetRed( int x, int y );
119 unsigned char GetGreen( int x, int y );
120 unsigned char GetBlue( int x, int y );
121
9cbf6f6e
RD
122 void SetAlpha(int x, int y, unsigned char alpha);
123 unsigned char GetAlpha(int x, int y);
124 bool HasAlpha();
125
126 // find first colour that is not used in the image and has higher
68bc8549 127 // RGB values than <startR,startG,startB>
dd9f7fea
RD
128 DocDeclAStr(
129 bool, FindFirstUnusedColour( byte *OUTPUT, byte *OUTPUT, byte *OUTPUT,
130 byte startR = 0, byte startG = 0, byte startB = 0 ) const,
131 "FindFirstUnusedColour(int startR=1, int startG=0, int startB=0) -> (success, r, g, b)",
d07d2bc9
RD
132 "Find first colour that is not used in the image and has higher RGB
133values than startR, startG, startB. Returns a tuple consisting of a
134success flag and rgb values.", "");
dd9f7fea 135
68bc8549
RD
136
137 // Set image's mask to the area of 'mask' that has <mr,mg,mb> colour
138 bool SetMaskFromImage(const wxImage & mask,
139 byte mr, byte mg, byte mb);
140
db0ff83e
RD
141// void DoFloodFill (wxCoord x, wxCoord y,
142// const wxBrush & fillBrush,
143// const wxColour& testColour,
144// int style = wxFLOOD_SURFACE,
145// int LogicalFunction = wxCOPY /* currently unused */ ) ;
68bc8549 146
96bfd053 147 static bool CanRead( const wxString& name );
b5a5d647
RD
148 static int GetImageCount( const wxString& name, long type = wxBITMAP_TYPE_ANY );
149
150 bool LoadFile( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
151 %name(LoadMimeFile)bool LoadFile( const wxString& name, const wxString& mimetype, int index = -1 );
cf694132
RD
152
153 bool SaveFile( const wxString& name, int type );
154 %name(SaveMimeFile)bool SaveFile( const wxString& name, const wxString& mimetype );
155
f74ff5ef
RD
156 %name(CanReadStream) static bool CanRead( wxInputStream& stream );
157 %name(LoadStream) bool LoadFile( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1 );
158 %name(LoadMimeStream) bool LoadFile( wxInputStream& stream, const wxString& mimetype, int index = -1 );
159
cf694132
RD
160 bool Ok();
161 int GetWidth();
162 int GetHeight();
163
ba938c3d
RD
164 %extend {
165 wxSize GetSize() {
166 wxSize size(self->GetWidth(), self->GetHeight());
167 return size;
168 }
169 }
170
9d8bd15f 171 wxImage GetSubImage(const wxRect& rect);
f6bcfd97
BP
172 wxImage Copy();
173 void Paste( const wxImage &image, int x, int y );
9d8bd15f 174
1dc2f865
RD
175 //unsigned char *GetData();
176 //void SetData( unsigned char *data );
177
d14a1e28 178 %extend {
9cbf6f6e 179 PyObject* GetData() {
d55d6b3f
RD
180 unsigned char* data = self->GetData();
181 int len = self->GetWidth() * self->GetHeight() * 3;
d14a1e28
RD
182 PyObject* rv;
183 wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len));
184 return rv;
d55d6b3f 185 }
9cbf6f6e
RD
186 void SetData(PyObject* data) {
187 unsigned char* dataPtr;
d55d6b3f 188
9cbf6f6e
RD
189 if (! PyString_Check(data)) {
190 PyErr_SetString(PyExc_TypeError, "Expected string object");
191 return /* NULL */ ;
192 }
193
194 size_t len = self->GetWidth() * self->GetHeight() * 3;
195 dataPtr = (unsigned char*) malloc(len);
d14a1e28 196 wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
9cbf6f6e
RD
197 self->SetData(dataPtr);
198 // wxImage takes ownership of dataPtr...
199 }
200
201
202
203 PyObject* GetDataBuffer() {
1dc2f865
RD
204 unsigned char* data = self->GetData();
205 int len = self->GetWidth() * self->GetHeight() * 3;
d14a1e28
RD
206 PyObject* rv;
207 wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
208 return rv;
1dc2f865 209 }
1e4a197e
RD
210 void SetDataBuffer(PyObject* data) {
211 unsigned char* buffer;
212 int size;
213
da32eb53 214 bool blocked = wxPyBeginBlockThreads();
d14a1e28
RD
215 if (!PyArg_Parse(data, "t#", &buffer, &size))
216 goto done;
1e4a197e
RD
217
218 if (size != self->GetWidth() * self->GetHeight() * 3) {
219 PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
d14a1e28 220 goto done;
1e4a197e 221 }
1e4a197e 222 self->SetData(buffer);
d14a1e28 223 done:
da32eb53 224 wxPyEndBlockThreads(blocked);
1e4a197e
RD
225 }
226
9cbf6f6e
RD
227
228
229 PyObject* GetAlphaData() {
230 unsigned char* data = self->GetAlpha();
231 if (! data) {
232 RETURN_NONE();
233 } else {
234 int len = self->GetWidth() * self->GetHeight();
d14a1e28
RD
235 PyObject* rv;
236 wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len) );
237 return rv;
9cbf6f6e
RD
238 }
239 }
240 void SetAlphaData(PyObject* data) {
1dc2f865
RD
241 unsigned char* dataPtr;
242
243 if (! PyString_Check(data)) {
244 PyErr_SetString(PyExc_TypeError, "Expected string object");
245 return /* NULL */ ;
246 }
9d8bd15f 247
9cbf6f6e 248 size_t len = self->GetWidth() * self->GetHeight();
185d7c3e 249 dataPtr = (unsigned char*) malloc(len);
d14a1e28 250 wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
9cbf6f6e 251 self->SetAlpha(dataPtr);
3b5ccda1 252 // wxImage takes ownership of dataPtr...
1dc2f865 253 }
9cbf6f6e
RD
254
255
256
257 PyObject* GetAlphaBuffer() {
258 unsigned char* data = self->GetAlpha();
259 int len = self->GetWidth() * self->GetHeight();
d14a1e28
RD
260 PyObject* rv;
261 wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
262 return rv;
9cbf6f6e
RD
263 }
264 void SetAlphaBuffer(PyObject* data) {
265 unsigned char* buffer;
266 int size;
267
da32eb53 268 bool blocked = wxPyBeginBlockThreads();
d14a1e28
RD
269 if (!PyArg_Parse(data, "t#", &buffer, &size))
270 goto done;
9cbf6f6e
RD
271
272 if (size != self->GetWidth() * self->GetHeight()) {
273 PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
d14a1e28 274 goto done;
9cbf6f6e
RD
275 }
276 self->SetAlpha(buffer);
d14a1e28 277 done:
da32eb53 278 wxPyEndBlockThreads(blocked);
9cbf6f6e 279 }
1dc2f865 280 }
cf694132
RD
281
282 void SetMaskColour( unsigned char r, unsigned char g, unsigned char b );
283 unsigned char GetMaskRed();
284 unsigned char GetMaskGreen();
285 unsigned char GetMaskBlue();
dd9f7fea 286 void SetMask( bool mask = True );
cf694132
RD
287 bool HasMask();
288
f6bcfd97 289 wxImage Rotate(double angle, const wxPoint & centre_of_rotation,
dd9f7fea
RD
290 bool interpolating = True, wxPoint * offset_after_rotation = NULL) const ;
291 wxImage Rotate90( bool clockwise = True ) ;
292 wxImage Mirror( bool horizontally = True ) ;
f6bcfd97
BP
293
294 void Replace( unsigned char r1, unsigned char g1, unsigned char b1,
295 unsigned char r2, unsigned char g2, unsigned char b2 );
296
6c0168c9
RD
297 // convert to monochrome image (<r,g,b> will be replaced by white, everything else by black)
298 wxImage ConvertToMono( unsigned char r, unsigned char g, unsigned char b ) const;
299
300 void SetOption(const wxString& name, const wxString& value);
301 %name(SetOptionInt)void SetOption(const wxString& name, int value);
302 wxString GetOption(const wxString& name) const;
303 int GetOptionInt(const wxString& name) const;
304 bool HasOption(const wxString& name) const;
305
f6bcfd97 306 unsigned long CountColours( unsigned long stopafter = (unsigned long) -1 );
9cbf6f6e 307 unsigned long ComputeHistogram( wxImageHistogram& h );
f6bcfd97 308
96bfd053
RD
309 static void AddHandler( wxImageHandler *handler );
310 static void InsertHandler( wxImageHandler *handler );
311 static bool RemoveHandler( const wxString& name );
3ef86e32 312 static wxString GetImageExtWildcard();
b96c7a38
RD
313
314
d14a1e28 315 %extend {
b96c7a38
RD
316 wxBitmap ConvertToBitmap() {
317 wxBitmap bitmap(*self);
318 return bitmap;
319 }
320
321 wxBitmap ConvertToMonoBitmap( unsigned char red,
322 unsigned char green,
323 unsigned char blue ) {
324 wxImage mono = self->ConvertToMono( red, green, blue );
325 wxBitmap bitmap( mono, 1 );
326 return bitmap;
327 }
328 }
1fded56b 329
d14a1e28 330 %pythoncode { def __nonzero__(self): return self.Ok() }
cf694132
RD
331};
332
926bb76c 333
f74ff5ef 334
a3150741
RD
335///void wxInitAllImageHandlers();
336
337%pythoncode {
338 def InitAllImageHandlers():
339 """
340 The former functionality of InitAllImageHanders is now done internal to
341 the _core_ extension module and so this function has become a simple NOP.
342 """
343 pass
344}
345
cf694132 346
f74ff5ef 347
d14a1e28
RD
348// See also wxPy_ReinitStockObjects in helpers.cpp
349%immutable;
350const wxImage wxNullImage;
351%mutable;
cf694132 352
d14a1e28 353//---------------------------------------------------------------------------
f74ff5ef 354
b5a5d647 355
d14a1e28
RD
356MAKE_CONST_WXSTRING(IMAGE_OPTION_BMP_FORMAT);
357MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_X);
358MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_Y);
359MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTION);
360MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTIONUNIT);
f74ff5ef 361
d14a1e28
RD
362enum
363{
364 wxIMAGE_RESOLUTION_INCHES = 1,
365 wxIMAGE_RESOLUTION_CM = 2
366};
f74ff5ef
RD
367
368
d14a1e28
RD
369enum
370{
371 wxBMP_24BPP = 24, // default, do not need to set
372 //wxBMP_16BPP = 16, // wxQuantize can only do 236 colors?
373 wxBMP_8BPP = 8, // 8bpp, quantized colors
374 wxBMP_8BPP_GREY = 9, // 8bpp, rgb averaged to greys
375 wxBMP_8BPP_GRAY = wxBMP_8BPP_GREY,
376 wxBMP_8BPP_RED = 10, // 8bpp, red used as greyscale
377 wxBMP_8BPP_PALETTE = 11, // 8bpp, use the wxImage's palette
378 wxBMP_4BPP = 4, // 4bpp, quantized colors
379 wxBMP_1BPP = 1, // 1bpp, quantized "colors"
380 wxBMP_1BPP_BW = 2 // 1bpp, black & white from red
381};
f74ff5ef
RD
382
383
d14a1e28
RD
384class wxBMPHandler : public wxImageHandler {
385public:
386 wxBMPHandler();
387};
cf694132 388
d14a1e28
RD
389class wxICOHandler : public wxBMPHandler {
390public:
391 wxICOHandler();
392};
f74ff5ef 393
d14a1e28
RD
394class wxCURHandler : public wxICOHandler {
395public:
396 wxCURHandler();
397};
f74ff5ef 398
d14a1e28
RD
399class wxANIHandler : public wxCURHandler {
400public:
401 wxANIHandler();
402};
06c0fba4 403
0a651eb8 404
d14a1e28 405//---------------------------------------------------------------------------
0a651eb8 406
d14a1e28
RD
407class wxPNGHandler : public wxImageHandler {
408public:
409 wxPNGHandler();
410};
0a651eb8 411
0a651eb8 412
d14a1e28
RD
413class wxGIFHandler : public wxImageHandler {
414public:
415 wxGIFHandler();
416};
0a651eb8
RD
417
418
d14a1e28
RD
419class wxPCXHandler : public wxImageHandler {
420public:
421 wxPCXHandler();
422};
926bb76c 423
926bb76c 424
d14a1e28
RD
425class wxJPEGHandler : public wxImageHandler {
426public:
427 wxJPEGHandler();
428};
926bb76c 429
926bb76c 430
d14a1e28
RD
431class wxPNMHandler : public wxImageHandler {
432public:
433 wxPNMHandler();
434};
435
436class wxXPMHandler : public wxImageHandler {
437public:
438 wxXPMHandler();
439};
440
441class wxTIFFHandler : public wxImageHandler {
442public:
443 wxTIFFHandler();
444};
445
446
447#if wxUSE_IFF
448class wxIFFHandler : public wxImageHandler {
449public:
450 wxIFFHandler();
451};
452#endif
926bb76c 453
cf694132 454//---------------------------------------------------------------------------