some things that were changed/removed from my patch I submitted to them.) Since it is now possible easily and simply share the SWIG type tables across modules I reverted to always using the stock SWIG runtime instead of my slightly hacked up version of it exported via the wxPython C API. The %name directive is now deprecated so replaced most uses of it with a custom %Rename macro that uses %rename internally. These will evetually need to be replaced with a DocDecl macro when docstrings are added. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@31128 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
566 lines
18 KiB
OpenEdge ABL
566 lines
18 KiB
OpenEdge ABL
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: _image.i
|
|
// Purpose: SWIG definitions for wxImage and such
|
|
//
|
|
// Author: Robin Dunn
|
|
//
|
|
// Created: 25-Sept-2000
|
|
// RCS-ID: $Id$
|
|
// Copyright: (c) 2003 by Total Control Software
|
|
// Licence: wxWindows license
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Not a %module
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
%{
|
|
#include "wx/wxPython/pyistream.h"
|
|
%}
|
|
|
|
//---------------------------------------------------------------------------
|
|
%newgroup
|
|
|
|
|
|
class wxImageHandler : public wxObject {
|
|
public:
|
|
// wxImageHandler(); Abstract Base Class
|
|
wxString GetName();
|
|
wxString GetExtension();
|
|
long GetType();
|
|
wxString GetMimeType();
|
|
|
|
//bool LoadFile(wxImage* image, wxInputStream& stream);
|
|
//bool SaveFile(wxImage* image, wxOutputStream& stream);
|
|
//virtual int GetImageCount( wxInputStream& stream );
|
|
//bool CanRead( wxInputStream& stream );
|
|
|
|
bool CanRead( const wxString& name );
|
|
|
|
void SetName(const wxString& name);
|
|
void SetExtension(const wxString& extension);
|
|
void SetType(long type);
|
|
void SetMimeType(const wxString& mimetype);
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
class wxImageHistogram /* : public wxImageHistogramBase */
|
|
{
|
|
public:
|
|
wxImageHistogram();
|
|
|
|
DocStr(MakeKey, "Get the key in the histogram for the given RGB values", "");
|
|
static unsigned long MakeKey(unsigned char r,
|
|
unsigned char g,
|
|
unsigned char b);
|
|
|
|
DocDeclAStr(
|
|
bool, FindFirstUnusedColour(unsigned char *OUTPUT,
|
|
unsigned char *OUTPUT,
|
|
unsigned char *OUTPUT,
|
|
unsigned char startR = 1,
|
|
unsigned char startG = 0,
|
|
unsigned char startB = 0 ) const,
|
|
"FindFirstUnusedColour(int startR=1, int startG=0, int startB=0) -> (success, r, g, b)",
|
|
"Find first colour that is not used in the image and has higher RGB
|
|
values than startR, startG, startB. Returns a tuple consisting of a
|
|
success flag and rgb values.", "");
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
class wxImage : public wxObject {
|
|
public:
|
|
DocCtorStr(
|
|
wxImage( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 ),
|
|
"", "");
|
|
|
|
~wxImage();
|
|
|
|
// Alternate constructors
|
|
DocCtorStrName(
|
|
wxImage(const wxString& name, const wxString& mimetype, int index = -1),
|
|
"", "",
|
|
ImageFromMime);
|
|
|
|
DocCtorStrName(
|
|
wxImage(wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1),
|
|
"", "",
|
|
ImageFromStream);
|
|
|
|
DocCtorStrName(
|
|
wxImage(wxInputStream& stream, const wxString& mimetype, int index = -1 ),
|
|
"", "",
|
|
ImageFromStreamMime);
|
|
|
|
%extend {
|
|
%rename(EmptyImage) wxImage(int width=0, int height=0, bool clear = true);
|
|
wxImage(int width=0, int height=0, bool clear = true)
|
|
{
|
|
if (width > 0 && height > 0)
|
|
return new wxImage(width, height, clear);
|
|
else
|
|
return new wxImage;
|
|
}
|
|
|
|
MustHaveApp(wxImage(const wxBitmap &bitmap));
|
|
%rename(ImageFromBitmap) wxImage(const wxBitmap &bitmap);
|
|
wxImage(const wxBitmap &bitmap)
|
|
{
|
|
return new wxImage(bitmap.ConvertToImage());
|
|
}
|
|
|
|
%rename(ImageFromData) wxImage(int width, int height, unsigned char* data);
|
|
wxImage(int width, int height, unsigned char* data)
|
|
{
|
|
// Copy the source data so the wxImage can clean it up later
|
|
unsigned char* copy = (unsigned char*)malloc(width*height*3);
|
|
if (copy == NULL) {
|
|
PyErr_NoMemory();
|
|
return NULL;
|
|
}
|
|
memcpy(copy, data, width*height*3);
|
|
return new wxImage(width, height, copy, false);
|
|
}
|
|
|
|
|
|
%rename(ImageFromDataWithAlpha) wxImage(int width, int height, unsigned char* data, unsigned char* alpha);
|
|
wxImage(int width, int height, unsigned char* data, unsigned char* alpha)
|
|
{
|
|
// Copy the source data so the wxImage can clean it up later
|
|
unsigned char* dcopy = (unsigned char*)malloc(width*height*3);
|
|
if (dcopy == NULL) {
|
|
PyErr_NoMemory();
|
|
return NULL;
|
|
}
|
|
memcpy(dcopy, data, width*height*3);
|
|
unsigned char* acopy = (unsigned char*)malloc(width*height);
|
|
if (acopy == NULL) {
|
|
PyErr_NoMemory();
|
|
return NULL;
|
|
}
|
|
memcpy(acopy, alpha, width*height);
|
|
|
|
return new wxImage(width, height, dcopy, acopy, false);
|
|
}
|
|
}
|
|
|
|
void Create( int width, int height );
|
|
void Destroy();
|
|
|
|
wxImage Scale( int width, int height );
|
|
wxImage ShrinkBy( int xFactor , int yFactor ) const ;
|
|
wxImage& Rescale(int width, int height);
|
|
|
|
void SetRGB( int x, int y, unsigned char r, unsigned char g, unsigned char b );
|
|
unsigned char GetRed( int x, int y );
|
|
unsigned char GetGreen( int x, int y );
|
|
unsigned char GetBlue( int x, int y );
|
|
|
|
void SetAlpha(int x, int y, unsigned char alpha);
|
|
unsigned char GetAlpha(int x, int y);
|
|
bool HasAlpha();
|
|
|
|
// find first colour that is not used in the image and has higher
|
|
// RGB values than <startR,startG,startB>
|
|
DocDeclAStr(
|
|
bool, FindFirstUnusedColour( byte *OUTPUT, byte *OUTPUT, byte *OUTPUT,
|
|
byte startR = 0, byte startG = 0, byte startB = 0 ) const,
|
|
"FindFirstUnusedColour(int startR=1, int startG=0, int startB=0) -> (success, r, g, b)",
|
|
"Find first colour that is not used in the image and has higher RGB
|
|
values than startR, startG, startB. Returns a tuple consisting of a
|
|
success flag and rgb values.", "");
|
|
|
|
|
|
DocDeclStr(
|
|
bool , ConvertAlphaToMask(byte threshold = 128),
|
|
"If the image has alpha channel, this method converts it to mask. All pixels
|
|
with alpha value less than ``threshold`` are replaced with mask colour and the
|
|
alpha channel is removed. Mask colour is chosen automatically using
|
|
`FindFirstUnusedColour`.
|
|
|
|
If the image image doesn't have alpha channel, ConvertAlphaToMask does
|
|
nothing.", "");
|
|
|
|
|
|
DocDeclStr(
|
|
bool , ConvertColourToAlpha( unsigned char r, unsigned char g, unsigned char b ),
|
|
"This method converts an image where the original alpha information is
|
|
only available as a shades of a colour (actually shades of grey)
|
|
typically when you draw anti-aliased text into a bitmap. The DC
|
|
drawing routines draw grey values on the black background although
|
|
they actually mean to draw white with differnt alpha values. This
|
|
method reverses it, assuming a black (!) background and white text.
|
|
The method will then fill up the whole image with the colour given.", "");
|
|
|
|
|
|
|
|
// Set image's mask to the area of 'mask' that has <mr,mg,mb> colour
|
|
bool SetMaskFromImage(const wxImage & mask,
|
|
byte mr, byte mg, byte mb);
|
|
|
|
// void DoFloodFill (wxCoord x, wxCoord y,
|
|
// const wxBrush & fillBrush,
|
|
// const wxColour& testColour,
|
|
// int style = wxFLOOD_SURFACE,
|
|
// int LogicalFunction = wxCOPY /* currently unused */ ) ;
|
|
|
|
static bool CanRead( const wxString& name );
|
|
static int GetImageCount( const wxString& name, long type = wxBITMAP_TYPE_ANY );
|
|
|
|
bool LoadFile( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
|
|
%Rename(LoadMimeFile, bool, LoadFile( const wxString& name, const wxString& mimetype, int index = -1 ));
|
|
|
|
bool SaveFile( const wxString& name, int type );
|
|
%Rename(SaveMimeFile, bool, SaveFile( const wxString& name, const wxString& mimetype ));
|
|
|
|
%Rename(CanReadStream, static bool, CanRead( wxInputStream& stream ));
|
|
%Rename(LoadStream, bool, LoadFile( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1 ));
|
|
%Rename(LoadMimeStream, bool, LoadFile( wxInputStream& stream, const wxString& mimetype, int index = -1 ));
|
|
|
|
bool Ok();
|
|
int GetWidth();
|
|
int GetHeight();
|
|
|
|
%extend {
|
|
wxSize GetSize() {
|
|
wxSize size(self->GetWidth(), self->GetHeight());
|
|
return size;
|
|
}
|
|
}
|
|
|
|
wxImage GetSubImage(const wxRect& rect);
|
|
wxImage Copy();
|
|
void Paste( const wxImage &image, int x, int y );
|
|
|
|
//unsigned char *GetData();
|
|
//void SetData( unsigned char *data );
|
|
|
|
%extend {
|
|
PyObject* GetData() {
|
|
unsigned char* data = self->GetData();
|
|
int len = self->GetWidth() * self->GetHeight() * 3;
|
|
PyObject* rv;
|
|
wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len));
|
|
return rv;
|
|
}
|
|
void SetData(PyObject* data) {
|
|
unsigned char* dataPtr;
|
|
|
|
if (! PyString_Check(data)) {
|
|
wxPyBLOCK_THREADS(PyErr_SetString(PyExc_TypeError,
|
|
"Expected string object"));
|
|
return /* NULL */ ;
|
|
}
|
|
|
|
size_t len = self->GetWidth() * self->GetHeight() * 3;
|
|
dataPtr = (unsigned char*) malloc(len);
|
|
wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
|
|
self->SetData(dataPtr);
|
|
// wxImage takes ownership of dataPtr...
|
|
}
|
|
|
|
|
|
|
|
PyObject* GetDataBuffer() {
|
|
unsigned char* data = self->GetData();
|
|
int len = self->GetWidth() * self->GetHeight() * 3;
|
|
PyObject* rv;
|
|
wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
|
|
return rv;
|
|
}
|
|
void SetDataBuffer(PyObject* data) {
|
|
unsigned char* buffer;
|
|
int size;
|
|
|
|
bool blocked = wxPyBeginBlockThreads();
|
|
if (!PyArg_Parse(data, "t#", &buffer, &size))
|
|
goto done;
|
|
|
|
if (size != self->GetWidth() * self->GetHeight() * 3) {
|
|
PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
|
|
goto done;
|
|
}
|
|
self->SetData(buffer);
|
|
done:
|
|
wxPyEndBlockThreads(blocked);
|
|
}
|
|
|
|
|
|
|
|
PyObject* GetAlphaData() {
|
|
unsigned char* data = self->GetAlpha();
|
|
if (! data) {
|
|
RETURN_NONE();
|
|
} else {
|
|
int len = self->GetWidth() * self->GetHeight();
|
|
PyObject* rv;
|
|
wxPyBLOCK_THREADS( rv = PyString_FromStringAndSize((char*)data, len) );
|
|
return rv;
|
|
}
|
|
}
|
|
void SetAlphaData(PyObject* data) {
|
|
unsigned char* dataPtr;
|
|
|
|
if (! PyString_Check(data)) {
|
|
PyErr_SetString(PyExc_TypeError, "Expected string object");
|
|
return /* NULL */ ;
|
|
}
|
|
|
|
size_t len = self->GetWidth() * self->GetHeight();
|
|
dataPtr = (unsigned char*) malloc(len);
|
|
wxPyBLOCK_THREADS( memcpy(dataPtr, PyString_AsString(data), len) );
|
|
self->SetAlpha(dataPtr);
|
|
// wxImage takes ownership of dataPtr...
|
|
}
|
|
|
|
|
|
|
|
PyObject* GetAlphaBuffer() {
|
|
unsigned char* data = self->GetAlpha();
|
|
int len = self->GetWidth() * self->GetHeight();
|
|
PyObject* rv;
|
|
wxPyBLOCK_THREADS( rv = PyBuffer_FromReadWriteMemory(data, len) );
|
|
return rv;
|
|
}
|
|
void SetAlphaBuffer(PyObject* data) {
|
|
unsigned char* buffer;
|
|
int size;
|
|
|
|
bool blocked = wxPyBeginBlockThreads();
|
|
if (!PyArg_Parse(data, "t#", &buffer, &size))
|
|
goto done;
|
|
|
|
if (size != self->GetWidth() * self->GetHeight()) {
|
|
PyErr_SetString(PyExc_TypeError, "Incorrect buffer size");
|
|
goto done;
|
|
}
|
|
self->SetAlpha(buffer);
|
|
done:
|
|
wxPyEndBlockThreads(blocked);
|
|
}
|
|
}
|
|
|
|
void SetMaskColour( unsigned char r, unsigned char g, unsigned char b );
|
|
unsigned char GetMaskRed();
|
|
unsigned char GetMaskGreen();
|
|
unsigned char GetMaskBlue();
|
|
void SetMask( bool mask = true );
|
|
bool HasMask();
|
|
|
|
wxImage Rotate(double angle, const wxPoint & centre_of_rotation,
|
|
bool interpolating = true, wxPoint * offset_after_rotation = NULL) const ;
|
|
wxImage Rotate90( bool clockwise = true ) ;
|
|
wxImage Mirror( bool horizontally = true ) ;
|
|
|
|
void Replace( unsigned char r1, unsigned char g1, unsigned char b1,
|
|
unsigned char r2, unsigned char g2, unsigned char b2 );
|
|
|
|
// convert to monochrome image (<r,g,b> will be replaced by white, everything else by black)
|
|
wxImage ConvertToMono( unsigned char r, unsigned char g, unsigned char b ) const;
|
|
|
|
void SetOption(const wxString& name, const wxString& value);
|
|
%Rename(SetOptionInt, void, SetOption(const wxString& name, int value));
|
|
wxString GetOption(const wxString& name) const;
|
|
int GetOptionInt(const wxString& name) const;
|
|
bool HasOption(const wxString& name) const;
|
|
|
|
unsigned long CountColours( unsigned long stopafter = (unsigned long) -1 );
|
|
unsigned long ComputeHistogram( wxImageHistogram& h );
|
|
|
|
static void AddHandler( wxImageHandler *handler );
|
|
static void InsertHandler( wxImageHandler *handler );
|
|
static bool RemoveHandler( const wxString& name );
|
|
static wxString GetImageExtWildcard();
|
|
|
|
|
|
MustHaveApp(ConvertToBitmap);
|
|
MustHaveApp(ConvertToMonoBitmap);
|
|
|
|
%extend {
|
|
wxBitmap ConvertToBitmap(int depth=-1) {
|
|
wxBitmap bitmap(*self, depth);
|
|
return bitmap;
|
|
}
|
|
|
|
wxBitmap ConvertToMonoBitmap( unsigned char red,
|
|
unsigned char green,
|
|
unsigned char blue ) {
|
|
wxImage mono = self->ConvertToMono( red, green, blue );
|
|
wxBitmap bitmap( mono, 1 );
|
|
return bitmap;
|
|
}
|
|
}
|
|
|
|
%pythoncode { def __nonzero__(self): return self.Ok() }
|
|
};
|
|
|
|
|
|
|
|
///void wxInitAllImageHandlers();
|
|
|
|
%pythoncode {
|
|
def InitAllImageHandlers():
|
|
"""
|
|
The former functionality of InitAllImageHanders is now done internal to
|
|
the _core_ extension module and so this function has become a simple NOP.
|
|
"""
|
|
pass
|
|
}
|
|
|
|
|
|
|
|
// See also wxPy_ReinitStockObjects in helpers.cpp
|
|
%immutable;
|
|
const wxImage wxNullImage;
|
|
%mutable;
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
MAKE_CONST_WXSTRING(IMAGE_OPTION_BMP_FORMAT);
|
|
MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_X);
|
|
MAKE_CONST_WXSTRING(IMAGE_OPTION_CUR_HOTSPOT_Y);
|
|
MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTION);
|
|
MAKE_CONST_WXSTRING(IMAGE_OPTION_RESOLUTIONUNIT);
|
|
|
|
enum
|
|
{
|
|
wxIMAGE_RESOLUTION_INCHES = 1,
|
|
wxIMAGE_RESOLUTION_CM = 2
|
|
};
|
|
|
|
|
|
enum
|
|
{
|
|
wxBMP_24BPP = 24, // default, do not need to set
|
|
//wxBMP_16BPP = 16, // wxQuantize can only do 236 colors?
|
|
wxBMP_8BPP = 8, // 8bpp, quantized colors
|
|
wxBMP_8BPP_GREY = 9, // 8bpp, rgb averaged to greys
|
|
wxBMP_8BPP_GRAY = wxBMP_8BPP_GREY,
|
|
wxBMP_8BPP_RED = 10, // 8bpp, red used as greyscale
|
|
wxBMP_8BPP_PALETTE = 11, // 8bpp, use the wxImage's palette
|
|
wxBMP_4BPP = 4, // 4bpp, quantized colors
|
|
wxBMP_1BPP = 1, // 1bpp, quantized "colors"
|
|
wxBMP_1BPP_BW = 2 // 1bpp, black & white from red
|
|
};
|
|
|
|
|
|
class wxBMPHandler : public wxImageHandler {
|
|
public:
|
|
wxBMPHandler();
|
|
};
|
|
|
|
class wxICOHandler : public wxBMPHandler {
|
|
public:
|
|
wxICOHandler();
|
|
};
|
|
|
|
class wxCURHandler : public wxICOHandler {
|
|
public:
|
|
wxCURHandler();
|
|
};
|
|
|
|
class wxANIHandler : public wxCURHandler {
|
|
public:
|
|
wxANIHandler();
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
class wxPNGHandler : public wxImageHandler {
|
|
public:
|
|
wxPNGHandler();
|
|
};
|
|
|
|
|
|
class wxGIFHandler : public wxImageHandler {
|
|
public:
|
|
wxGIFHandler();
|
|
};
|
|
|
|
|
|
class wxPCXHandler : public wxImageHandler {
|
|
public:
|
|
wxPCXHandler();
|
|
};
|
|
|
|
|
|
class wxJPEGHandler : public wxImageHandler {
|
|
public:
|
|
wxJPEGHandler();
|
|
};
|
|
|
|
|
|
class wxPNMHandler : public wxImageHandler {
|
|
public:
|
|
wxPNMHandler();
|
|
};
|
|
|
|
class wxXPMHandler : public wxImageHandler {
|
|
public:
|
|
wxXPMHandler();
|
|
};
|
|
|
|
class wxTIFFHandler : public wxImageHandler {
|
|
public:
|
|
wxTIFFHandler();
|
|
};
|
|
|
|
|
|
#if wxUSE_IFF
|
|
class wxIFFHandler : public wxImageHandler {
|
|
public:
|
|
wxIFFHandler();
|
|
};
|
|
#endif
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
%{
|
|
#include <wx/quantize.h>
|
|
%}
|
|
|
|
enum {
|
|
wxQUANTIZE_INCLUDE_WINDOWS_COLOURS,
|
|
// wxQUANTIZE_RETURN_8BIT_DATA,
|
|
wxQUANTIZE_FILL_DESTINATION_IMAGE
|
|
};
|
|
|
|
|
|
DocStr(wxQuantize,
|
|
"Performs quantization, or colour reduction, on a wxImage.", "");
|
|
|
|
class wxQuantize /*: public wxObject */
|
|
{
|
|
public:
|
|
|
|
%extend {
|
|
DocStr(
|
|
Quantize,
|
|
"Reduce the colours in the source image and put the result into the
|
|
destination image, setting the palette in the destination if
|
|
needed. Both images may be the same, to overwrite the source image.", "
|
|
:todo: Create a version that returns the wx.Palette used.");
|
|
|
|
static bool Quantize(const wxImage& src, wxImage& dest, int desiredNoColours = 236,
|
|
int flags = wxQUANTIZE_INCLUDE_WINDOWS_COLOURS|wxQUANTIZE_FILL_DESTINATION_IMAGE)
|
|
{
|
|
return wxQuantize::Quantize(src, dest,
|
|
//NULL, // palette
|
|
desiredNoColours,
|
|
NULL, // eightBitData
|
|
flags);
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|