1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: SWIG definitions for wxImage and such
7 // Created: 25-Sept-2000
9 // Copyright: (c) 2003 by Total Control Software
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
16 //---------------------------------------------------------------------------
19 #include "wx/wxPython/pyistream.h"
22 //---------------------------------------------------------------------------
26 class wxImageHandler : public wxObject {
28 // wxImageHandler(); Abstract Base Class
30 wxString GetExtension();
32 wxString GetMimeType();
34 //bool LoadFile(wxImage* image, wxInputStream& stream);
35 //bool SaveFile(wxImage* image, wxOutputStream& stream);
36 //virtual int GetImageCount( wxInputStream& stream );
37 //bool CanRead( wxInputStream& stream );
39 bool CanRead( const wxString& name );
41 void SetName(const wxString& name);
42 void SetExtension(const wxString& extension);
43 void SetType(long type);
44 void SetMimeType(const wxString& mimetype);
48 //---------------------------------------------------------------------------
50 class wxImageHistogram /* : public wxImageHistogramBase */
55 DocStr(MakeKey, "Get the key in the histogram for the given RGB values", "");
56 static unsigned long MakeKey(unsigned char r,
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)",
68 "Find first colour that is not used in the image and has higher RGB
69 values than startR, startG, startB. Returns a tuple consisting of a
70 success flag and rgb values.", "");
74 //---------------------------------------------------------------------------
77 class wxImage : public wxObject {
79 wxImage( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
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 );
87 %name(EmptyImage) wxImage(int width=0, int height=0, bool clear = true) {
88 if (width > 0 && height > 0)
89 return new wxImage(width, height, clear);
94 MustHaveApp(wxImage(const wxBitmap &bitmap));
95 %name(ImageFromBitmap) wxImage(const wxBitmap &bitmap) {
96 return new wxImage(bitmap.ConvertToImage());
99 %name(ImageFromData) wxImage(int width, int height, unsigned char* data) {
100 // Copy the source data so the wxImage can clean it up later
101 unsigned char* copy = (unsigned char*)malloc(width*height*3);
106 memcpy(copy, data, width*height*3);
107 return new wxImage(width, height, copy, false);
111 void Create( int width, int height );
114 wxImage Scale( int width, int height );
115 wxImage ShrinkBy( int xFactor , int yFactor ) const ;
116 wxImage& Rescale(int width, int height);
118 void SetRGB( int x, int y, unsigned char r, unsigned char g, unsigned char b );
119 unsigned char GetRed( int x, int y );
120 unsigned char GetGreen( int x, int y );
121 unsigned char GetBlue( int x, int y );
123 void SetAlpha(int x, int y, unsigned char alpha);
124 unsigned char GetAlpha(int x, int y);
127 // find first colour that is not used in the image and has higher
128 // RGB values than <startR,startG,startB>
130 bool, FindFirstUnusedColour( byte *OUTPUT, byte *OUTPUT, byte *OUTPUT,
131 byte startR = 0, byte startG = 0, byte startB = 0 ) const,
132 "FindFirstUnusedColour(int startR=1, int startG=0, int startB=0) -> (success, r, g, b)",
133 "Find first colour that is not used in the image and has higher RGB
134 values than startR, startG, startB. Returns a tuple consisting of a
135 success flag and rgb values.", "");
139 bool , ConvertAlphaToMask(byte threshold = 128),
140 "If the image has alpha channel, this method converts it to mask. All pixels
141 with alpha value less than ``threshold`` are replaced with mask colour and the
142 alpha channel is removed. Mask colour is chosen automatically using
143 `FindFirstUnusedColour`.
145 If the image image doesn't have alpha channel, ConvertAlphaToMask does
150 bool , ConvertColourToAlpha( unsigned char r, unsigned char g, unsigned char b ),
151 "This method converts an image where the original alpha information is
152 only available as a shades of a colour (actually shades of grey)
153 typically when you draw anti-aliased text into a bitmap. The DC
154 drawing routines draw grey values on the black background although
155 they actually mean to draw white with differnt alpha values. This
156 method reverses it, assuming a black (!) background and white text.
157 The method will then fill up the whole image with the colour given.", "");
161 // Set image's mask to the area of 'mask' that has <mr,mg,mb> colour
162 bool SetMaskFromImage(const wxImage & mask,
163 byte mr, byte mg, byte mb);
165 // void DoFloodFill (wxCoord x, wxCoord y,
166 // const wxBrush & fillBrush,
167 // const wxColour& testColour,
168 // int style = wxFLOOD_SURFACE,
169 // int LogicalFunction = wxCOPY /* currently unused */ ) ;
171 static bool CanRead( const wxString& name );
172 static int GetImageCount( const wxString& name, long type = wxBITMAP_TYPE_ANY );
174 bool LoadFile( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
175 %name(LoadMimeFile)bool LoadFile( const wxString& name, const wxString& mimetype, int index = -1 );
177 bool SaveFile( const wxString& name, int type );
178 %name(SaveMimeFile)bool SaveFile( const wxString& name, const wxString& mimetype );
180 %name(CanReadStream) static bool CanRead( wxInputStream& stream );
181 %name(LoadStream) bool LoadFile( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1 );
182 %name(LoadMimeStream) bool LoadFile( wxInputStream& stream, const wxString& mimetype, int index = -1 );
190 wxSize size(self->GetWidth(), self->GetHeight());
195 wxImage GetSubImage(const wxRect& rect);
197 void Paste( const wxImage &image, int x, int y );
199 //unsigned char *GetData();
200 //void SetData( unsigned char *data );
203 PyObject* GetData() {
204 unsigned char* data = self->GetData();
205 int len = self->GetWidth() * self->GetHeight() * 3;
207 wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len));
210 void SetData(PyObject* data) {
211 unsigned char* dataPtr;
213 if (! PyString_Check(data)) {
214 wxPyBLOCK_THREADS(PyErr_SetString(PyExc_TypeError,
215 "Expected string object"));
219 size_t len = self->GetWidth() * self->GetHeight() * 3;
220 dataPtr = (unsigned char*) malloc(len);
221 wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
222 self->SetData(dataPtr);
223 // wxImage takes ownership of dataPtr...
228 PyObject* GetDataBuffer() {
229 unsigned char* data = self->GetData();
230 int len = self->GetWidth() * self->GetHeight() * 3;
232 wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
235 void SetDataBuffer(PyObject* data) {
236 unsigned char* buffer;
239 bool blocked = wxPyBeginBlockThreads();
240 if (!PyArg_Parse(data, "t#", &buffer, &size))
243 if (size != self->GetWidth() * self->GetHeight() * 3) {
244 PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
247 self->SetData(buffer);
249 wxPyEndBlockThreads(blocked);
254 PyObject* GetAlphaData() {
255 unsigned char* data = self->GetAlpha();
259 int len = self->GetWidth() * self->GetHeight();
261 wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len) );
265 void SetAlphaData(PyObject* data) {
266 unsigned char* dataPtr;
268 if (! PyString_Check(data)) {
269 PyErr_SetString(PyExc_TypeError, "Expected string object");
273 size_t len = self->GetWidth() * self->GetHeight();
274 dataPtr = (unsigned char*) malloc(len);
275 wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
276 self->SetAlpha(dataPtr);
277 // wxImage takes ownership of dataPtr...
282 PyObject* GetAlphaBuffer() {
283 unsigned char* data = self->GetAlpha();
284 int len = self->GetWidth() * self->GetHeight();
286 wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
289 void SetAlphaBuffer(PyObject* data) {
290 unsigned char* buffer;
293 bool blocked = wxPyBeginBlockThreads();
294 if (!PyArg_Parse(data, "t#", &buffer, &size))
297 if (size != self->GetWidth() * self->GetHeight()) {
298 PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
301 self->SetAlpha(buffer);
303 wxPyEndBlockThreads(blocked);
307 void SetMaskColour( unsigned char r, unsigned char g, unsigned char b );
308 unsigned char GetMaskRed();
309 unsigned char GetMaskGreen();
310 unsigned char GetMaskBlue();
311 void SetMask( bool mask = true );
314 wxImage Rotate(double angle, const wxPoint & centre_of_rotation,
315 bool interpolating = true, wxPoint * offset_after_rotation = NULL) const ;
316 wxImage Rotate90( bool clockwise = true ) ;
317 wxImage Mirror( bool horizontally = true ) ;
319 void Replace( unsigned char r1, unsigned char g1, unsigned char b1,
320 unsigned char r2, unsigned char g2, unsigned char b2 );
322 // convert to monochrome image (<r,g,b> will be replaced by white, everything else by black)
323 wxImage ConvertToMono( unsigned char r, unsigned char g, unsigned char b ) const;
325 void SetOption(const wxString& name, const wxString& value);
326 %name(SetOptionInt)void SetOption(const wxString& name, int value);
327 wxString GetOption(const wxString& name) const;
328 int GetOptionInt(const wxString& name) const;
329 bool HasOption(const wxString& name) const;
331 unsigned long CountColours( unsigned long stopafter = (unsigned long) -1 );
332 unsigned long ComputeHistogram( wxImageHistogram& h );
334 static void AddHandler( wxImageHandler *handler );
335 static void InsertHandler( wxImageHandler *handler );
336 static bool RemoveHandler( const wxString& name );
337 static wxString GetImageExtWildcard();
340 MustHaveApp(ConvertToBitmap);
341 MustHaveApp(ConvertToMonoBitmap);
344 wxBitmap ConvertToBitmap(int depth=-1) {
345 wxBitmap bitmap(*self, depth);
349 wxBitmap ConvertToMonoBitmap( unsigned char red,
351 unsigned char blue ) {
352 wxImage mono = self->ConvertToMono( red, green, blue );
353 wxBitmap bitmap( mono, 1 );
358 %pythoncode { def __nonzero__(self): return self.Ok() }
363 ///void wxInitAllImageHandlers();
366 def InitAllImageHandlers():
368 The former functionality of InitAllImageHanders is now done internal to
369 the _core_ extension module and so this function has become a simple NOP.
376 // See also wxPy_ReinitStockObjects in helpers.cpp
378 const wxImage wxNullImage;
381 //---------------------------------------------------------------------------
384 MAKE_CONST_WXSTRING(IMAGE_OPTION_BMP_FORMAT);
385 MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_X);
386 MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_Y);
387 MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTION);
388 MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTIONUNIT);
392 wxIMAGE_RESOLUTION_INCHES = 1,
393 wxIMAGE_RESOLUTION_CM = 2
399 wxBMP_24BPP = 24, // default, do not need to set
400 //wxBMP_16BPP = 16, // wxQuantize can only do 236 colors?
401 wxBMP_8BPP = 8, // 8bpp, quantized colors
402 wxBMP_8BPP_GREY = 9, // 8bpp, rgb averaged to greys
403 wxBMP_8BPP_GRAY = wxBMP_8BPP_GREY,
404 wxBMP_8BPP_RED = 10, // 8bpp, red used as greyscale
405 wxBMP_8BPP_PALETTE = 11, // 8bpp, use the wxImage's palette
406 wxBMP_4BPP = 4, // 4bpp, quantized colors
407 wxBMP_1BPP = 1, // 1bpp, quantized "colors"
408 wxBMP_1BPP_BW = 2 // 1bpp, black & white from red
412 class wxBMPHandler : public wxImageHandler {
417 class wxICOHandler : public wxBMPHandler {
422 class wxCURHandler : public wxICOHandler {
427 class wxANIHandler : public wxCURHandler {
433 //---------------------------------------------------------------------------
435 class wxPNGHandler : public wxImageHandler {
441 class wxGIFHandler : public wxImageHandler {
447 class wxPCXHandler : public wxImageHandler {
453 class wxJPEGHandler : public wxImageHandler {
459 class wxPNMHandler : public wxImageHandler {
464 class wxXPMHandler : public wxImageHandler {
469 class wxTIFFHandler : public wxImageHandler {
476 class wxIFFHandler : public wxImageHandler {
482 //---------------------------------------------------------------------------
485 #include <wx/quantize.h>
489 wxQUANTIZE_INCLUDE_WINDOWS_COLOURS,
490 // wxQUANTIZE_RETURN_8BIT_DATA,
491 wxQUANTIZE_FILL_DESTINATION_IMAGE
496 "Performs quantization, or colour reduction, on a wxImage.", "");
498 class wxQuantize /*: public wxObject */
505 "Reduce the colours in the source image and put the result into the
506 destination image, setting the palette in the destination if
507 needed. Both images may be the same, to overwrite the source image.", "
508 :todo: Create a version that returns the wx.Palette used.");
510 static bool Quantize(const wxImage& src, wxImage& dest, int desiredNoColours = 236,
511 int flags = wxQUANTIZE_INCLUDE_WINDOWS_COLOURS|wxQUANTIZE_FILL_DESTINATION_IMAGE)
513 return wxQuantize::Quantize(src, dest,
516 NULL, // eightBitData
523 //---------------------------------------------------------------------------