Patch level : 12.0 no-patch

Files correlati     : 
Commento            : Aggiornamento codice per passaggio a Visual Studio 2017

git-svn-id: svn://10.65.10.50/branches/R_10_00@24259 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
mtollari 2018-01-09 16:45:05 +00:00
parent 425522aebc
commit 841a2a0d04

View File

@ -71,14 +71,14 @@ class WXDLLIMPEXP_FWD_CORE wxPalette;
#if wxUSE_VARIANT
#include "wx/variant.h"
DECLARE_VARIANT_OBJECT_EXPORTED(wxImage,WXDLLEXPORT)
DECLARE_VARIANT_OBJECT_EXPORTED(wxImage, WXDLLEXPORT)
#endif
//-----------------------------------------------------------------------------
// wxImageHandler
//-----------------------------------------------------------------------------
class WXDLLEXPORT wxImageHandler: public wxObject
class WXDLLEXPORT wxImageHandler : public wxObject
{
public:
wxImageHandler()
@ -86,13 +86,13 @@ public:
{ }
#if wxUSE_STREAMS
virtual bool LoadFile( wxImage *image, wxInputStream& stream, bool verbose=true, int index=-1 );
virtual bool SaveFile( wxImage *image, wxOutputStream& stream, bool verbose=true );
virtual bool LoadFile(wxImage *image, wxInputStream& stream, bool verbose = true, int index = -1);
virtual bool SaveFile(wxImage *image, wxOutputStream& stream, bool verbose = true);
virtual int GetImageCount( wxInputStream& stream );
virtual int GetImageCount(wxInputStream& stream);
bool CanRead( wxInputStream& stream ) { return CallDoCanRead(stream); }
bool CanRead( const wxString& name );
bool CanRead(wxInputStream& stream) { return CallDoCanRead(stream); }
bool CanRead(const wxString& name);
#endif // wxUSE_STREAMS
void SetName(const wxString& name) { m_name = name; }
@ -106,7 +106,7 @@ public:
protected:
#if wxUSE_STREAMS
virtual bool DoCanRead( wxInputStream& stream ) = 0;
virtual bool DoCanRead(wxInputStream& stream) = 0;
// save the stream position, call DoCanRead() and restore the position
bool CallDoCanRead(wxInputStream& stream);
@ -160,14 +160,14 @@ public:
unsigned char *b,
unsigned char startR = 1,
unsigned char startG = 0,
unsigned char startB = 0 ) const;
unsigned char startB = 0) const;
};
//-----------------------------------------------------------------------------
// wxImage
//-----------------------------------------------------------------------------
class WXDLLEXPORT wxImage: public wxObject
class WXDLLEXPORT wxImage : public wxObject
{
public:
// red, green and blue are 8 bit unsigned integers in the range of 0..255
@ -175,7 +175,7 @@ public:
class RGBValue
{
public:
RGBValue(unsigned char r=0, unsigned char g=0, unsigned char b=0)
RGBValue(unsigned char r = 0, unsigned char g = 0, unsigned char b = 0)
: red(r), green(g), blue(b) {}
unsigned char red;
unsigned char green;
@ -186,34 +186,34 @@ public:
class HSVValue
{
public:
HSVValue(double h=0.0, double s=0.0, double v=0.0)
HSVValue(double h = 0.0, double s = 0.0, double v = 0.0)
: hue(h), saturation(s), value(v) {}
double hue;
double saturation;
double value;
};
wxImage(){}
wxImage( int width, int height, bool clear = true );
wxImage( int width, int height, unsigned char* data, bool static_data = false );
wxImage( int width, int height, unsigned char* data, unsigned char* alpha, bool static_data = false );
wxImage( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
wxImage( const wxString& name, const wxString& mimetype, int index = -1 );
wxImage( const char* const* xpmData );
wxImage() {}
wxImage(int width, int height, bool clear = true);
wxImage(int width, int height, unsigned char* data, bool static_data = false);
wxImage(int width, int height, unsigned char* data, unsigned char* alpha, bool static_data = false);
wxImage(const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1);
wxImage(const wxString& name, const wxString& mimetype, int index = -1);
wxImage(const char* const* xpmData);
#if wxUSE_STREAMS
wxImage( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1 );
wxImage( wxInputStream& stream, const wxString& mimetype, int index = -1 );
wxImage(wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1);
wxImage(wxInputStream& stream, const wxString& mimetype, int index = -1);
#endif // wxUSE_STREAMS
bool Create( int width, int height, bool clear = true );
bool Create( int width, int height, unsigned char* data, bool static_data = false );
bool Create( int width, int height, unsigned char* data, unsigned char* alpha, bool static_data = false );
bool Create( const char* const* xpmData );
bool Create(int width, int height, bool clear = true);
bool Create(int width, int height, unsigned char* data, bool static_data = false);
bool Create(int width, int height, unsigned char* data, unsigned char* alpha, bool static_data = false);
bool Create(const char* const* xpmData);
#ifdef __BORLANDC__
// needed for Borland 5.5
wxImage( char** xpmData ) { Create(wx_const_cast(const char* const*, xpmData)); }
bool Create( char** xpmData ) { return Create(wx_const_cast(const char* const*, xpmData)); }
wxImage(char** xpmData) { Create(wx_const_cast(const char* const*, xpmData)); }
bool Create(char** xpmData) { return Create(wx_const_cast(const char* const*, xpmData)); }
#endif
void Destroy();
@ -222,21 +222,21 @@ public:
wxImage Copy() const;
// return the new image with size width*height
wxImage GetSubImage( const wxRect& rect) const;
wxImage GetSubImage(const wxRect& rect) const;
// Paste the image or part of this image into an image of the given size at the pos
// any newly exposed areas will be filled with the rgb colour
// by default if r = g = b = -1 then fill with this image's mask colour or find and
// set a suitable mask colour
wxImage Size( const wxSize& size, const wxPoint& pos,
int r = -1, int g = -1, int b = -1 ) const;
wxImage Size(const wxSize& size, const wxPoint& pos,
int r = -1, int g = -1, int b = -1) const;
// pastes image into this instance and takes care of
// the mask colour and out of bounds problems
void Paste( const wxImage &image, int x, int y );
void Paste(const wxImage &image, int x, int y);
// return the new image with size width*height
wxImage Scale( int width, int height, int quality = wxIMAGE_QUALITY_NORMAL ) const;
wxImage Scale(int width, int height, int quality = wxIMAGE_QUALITY_NORMAL) const;
// box averager and bicubic filters for up/down sampling
wxImage ResampleBox(int width, int height) const;
@ -247,50 +247,52 @@ public:
wxImage BlurHorizontal(int radius);
wxImage BlurVertical(int radius);
wxImage ShrinkBy( int xFactor , int yFactor ) const ;
wxImage ShrinkBy(int xFactor, int yFactor) const;
// rescales the image in place
wxImage& Rescale( int width, int height, int quality = wxIMAGE_QUALITY_NORMAL ) { return *this = Scale(width, height, quality); }
wxImage& Rescale(int width, int height, int quality = wxIMAGE_QUALITY_NORMAL) { return *this = Scale(width, height, quality); }
// resizes the image in place
wxImage& Resize( const wxSize& size, const wxPoint& pos,
int r = -1, int g = -1, int b = -1 ) { return *this = Size(size, pos, r, g, b); }
wxImage& Resize(const wxSize& size, const wxPoint& pos,
int r = -1, int g = -1, int b = -1) {
return *this = Size(size, pos, r, g, b);
}
// Rotates the image about the given point, 'angle' radians.
// Returns the rotated image, leaving this image intact.
wxImage Rotate(double angle, const wxPoint & centre_of_rotation,
bool interpolating = true, wxPoint * offset_after_rotation = (wxPoint*) NULL) const;
bool interpolating = true, wxPoint * offset_after_rotation = (wxPoint*)NULL) const;
wxImage Rotate90( bool clockwise = true ) const;
wxImage Mirror( bool horizontally = true ) const;
wxImage Rotate90(bool clockwise = true) const;
wxImage Mirror(bool horizontally = true) const;
// replace one colour with another
void Replace( unsigned char r1, unsigned char g1, unsigned char b1,
unsigned char r2, unsigned char g2, unsigned char b2 );
void Replace(unsigned char r1, unsigned char g1, unsigned char b1,
unsigned char r2, unsigned char g2, unsigned char b2);
// Convert to greyscale image. Uses the luminance component (Y) of the image.
// The luma value (YUV) is calculated using (R * lr) + (G * lg) + (B * lb), defaults to ITU-T BT.601
wxImage ConvertToGreyscale( double lr = 0.299, double lg = 0.587, double lb = 0.114 ) const;
wxImage ConvertToGreyscale(double lr = 0.299, double lg = 0.587, double lb = 0.114) const;
// 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;
wxImage ConvertToMono(unsigned char r, unsigned char g, unsigned char b) const;
// these routines are slow but safe
void SetRGB( int x, int y, unsigned char r, unsigned char g, unsigned char b );
void SetRGB( const wxRect& rect, unsigned char r, unsigned char g, unsigned char b );
unsigned char GetRed( int x, int y ) const;
unsigned char GetGreen( int x, int y ) const;
unsigned char GetBlue( int x, int y ) const;
void SetRGB(int x, int y, unsigned char r, unsigned char g, unsigned char b);
void SetRGB(const wxRect& rect, unsigned char r, unsigned char g, unsigned char b);
unsigned char GetRed(int x, int y) const;
unsigned char GetGreen(int x, int y) const;
unsigned char GetBlue(int x, int y) const;
void SetAlpha(int x, int y, unsigned char alpha);
unsigned char GetAlpha(int x, int y) const;
// find first colour that is not used in the image and has higher
// RGB values than <startR,startG,startB>
bool FindFirstUnusedColour( unsigned char *r, unsigned char *g, unsigned char *b,
bool FindFirstUnusedColour(unsigned char *r, unsigned char *g, unsigned char *b,
unsigned char startR = 1, unsigned char startG = 0,
unsigned char startB = 0 ) const;
unsigned char startB = 0) const;
// Set image's mask to the area of 'mask' that has <r,g,b> colour
bool SetMaskFromImage(const wxImage & mask,
unsigned char mr, unsigned char mg, unsigned char mb);
@ -309,27 +311,27 @@ public:
// and white text (actually only the red channel is read).
// The method will then fill up the whole image with the
// colour given.
bool ConvertColourToAlpha( unsigned char r, unsigned char g, unsigned char b );
bool ConvertColourToAlpha(unsigned char r, unsigned char g, unsigned char b);
static bool CanRead( const wxString& name );
static int GetImageCount( const wxString& name, long type = wxBITMAP_TYPE_ANY );
virtual bool LoadFile( const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1 );
virtual bool LoadFile( const wxString& name, const wxString& mimetype, int index = -1 );
static bool CanRead(const wxString& name);
static int GetImageCount(const wxString& name, long type = wxBITMAP_TYPE_ANY);
virtual bool LoadFile(const wxString& name, long type = wxBITMAP_TYPE_ANY, int index = -1);
virtual bool LoadFile(const wxString& name, const wxString& mimetype, int index = -1);
#if wxUSE_STREAMS
static bool CanRead( wxInputStream& stream );
static int GetImageCount( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY );
virtual bool LoadFile( wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1 );
virtual bool LoadFile( wxInputStream& stream, const wxString& mimetype, int index = -1 );
static bool CanRead(wxInputStream& stream);
static int GetImageCount(wxInputStream& stream, long type = wxBITMAP_TYPE_ANY);
virtual bool LoadFile(wxInputStream& stream, long type = wxBITMAP_TYPE_ANY, int index = -1);
virtual bool LoadFile(wxInputStream& stream, const wxString& mimetype, int index = -1);
#endif
virtual bool SaveFile( const wxString& name ) const;
virtual bool SaveFile( const wxString& name, int type ) const;
virtual bool SaveFile( const wxString& name, const wxString& mimetype ) const;
virtual bool SaveFile(const wxString& name) const;
virtual bool SaveFile(const wxString& name, int type) const;
virtual bool SaveFile(const wxString& name, const wxString& mimetype) const;
#if wxUSE_STREAMS
virtual bool SaveFile( wxOutputStream& stream, int type ) const;
virtual bool SaveFile( wxOutputStream& stream, const wxString& mimetype ) const;
virtual bool SaveFile(wxOutputStream& stream, int type) const;
virtual bool SaveFile(wxOutputStream& stream, const wxString& mimetype) const;
#endif
bool Ok() const { return IsOk(); }
@ -340,12 +342,12 @@ public:
// these functions provide fastest access to wxImage data but should be
// used carefully as no checks are done
unsigned char *GetData() const;
void SetData( unsigned char *data, bool static_data=false );
void SetData( unsigned char *data, int new_width, int new_height, bool static_data=false );
void SetData(unsigned char *data, bool static_data = false);
void SetData(unsigned char *data, int new_width, int new_height, bool static_data = false);
unsigned char *GetAlpha() const; // may return NULL!
bool HasAlpha() const { return GetAlpha() != NULL; }
void SetAlpha(unsigned char *alpha = NULL, bool static_data=false);
void SetAlpha(unsigned char *alpha = NULL, bool static_data = false);
void InitAlpha();
// return true if this pixel is masked or has alpha less than specified
@ -354,14 +356,14 @@ public:
unsigned char threshold = wxIMAGE_ALPHA_THRESHOLD) const;
// Mask functions
void SetMaskColour( unsigned char r, unsigned char g, unsigned char b );
void SetMaskColour(unsigned char r, unsigned char g, unsigned char b);
// Get the current mask colour or find a suitable colour
// returns true if using current mask colour
bool GetOrFindMaskColour( unsigned char *r, unsigned char *g, unsigned char *b ) const;
bool GetOrFindMaskColour(unsigned char *r, unsigned char *g, unsigned char *b) const;
unsigned char GetMaskRed() const;
unsigned char GetMaskGreen() const;
unsigned char GetMaskBlue() const;
void SetMask( bool mask = true );
void SetMask(bool mask = true);
bool HasMask() const;
#if wxUSE_PALETTE
@ -378,7 +380,7 @@ public:
int GetOptionInt(const wxString& name) const;
bool HasOption(const wxString& name) const;
unsigned long CountColours( unsigned long stopafter = (unsigned long) -1 ) const;
unsigned long CountColours(unsigned long stopafter = (unsigned long)-1) const;
// Computes the histogram of the image and fills a hash table, indexed
// with integer keys built as 0xRRGGBB, containing wxImageHistogramEntry
@ -386,20 +388,20 @@ public:
// with the image colours) and a 'value', which is the number of pixels
// in the image with that colour.
// Returned value: # of entries in the histogram
unsigned long ComputeHistogram( wxImageHistogram &h ) const;
unsigned long ComputeHistogram(wxImageHistogram &h) const;
// Rotates the hue of each pixel of the image. angle is a double in the range
// -1.0..1.0 where -1.0 is -360 degrees and 1.0 is 360 degrees
void RotateHue(double angle);
static wxList& GetHandlers() { return sm_handlers; }
static void AddHandler( wxImageHandler *handler );
static void InsertHandler( wxImageHandler *handler );
static bool RemoveHandler( const wxString& name );
static wxImageHandler *FindHandler( const wxString& name );
static wxImageHandler *FindHandler( const wxString& extension, long imageType );
static wxImageHandler *FindHandler( long imageType );
static wxImageHandler *FindHandlerMime( const wxString& mimetype );
static void AddHandler(wxImageHandler *handler);
static void InsertHandler(wxImageHandler *handler);
static bool RemoveHandler(const wxString& name);
static wxImageHandler *FindHandler(const wxString& name);
static wxImageHandler *FindHandler(const wxString& extension, long imageType);
static wxImageHandler *FindHandler(long imageType);
static wxImageHandler *FindHandlerMime(const wxString& mimetype);
static wxString GetImageExtWildcard();
@ -409,6 +411,15 @@ public:
static HSVValue RGBtoHSV(const RGBValue& rgb);
static RGBValue HSVtoRGB(const HSVValue& hsv);
// Ridefinito causa problemi con VS2017
wxImage& operator=(const wxImage& other)
{
if (this != &other)
{
Ref(other);
}
return *this;
}
protected:
static wxList sm_handlers;
@ -451,4 +462,4 @@ extern WXDLLEXPORT_DATA(wxImage) wxNullImage;
#endif // wxUSE_IMAGE
#endif
// _WX_IMAGE_H_
// _WX_IMAGE_H_