added alpha support to wxCocoa, also fixed compilation after alpha changes hopefully

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@40895 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2006-08-28 09:53:33 +00:00
parent df00bdf773
commit 7106497983
2 changed files with 34 additions and 20 deletions

View File

@@ -46,47 +46,54 @@ public:
unsigned char Red() const { return m_red; } unsigned char Red() const { return m_red; }
unsigned char Green() const { return m_green; } unsigned char Green() const { return m_green; }
unsigned char Blue() const { return m_blue; } unsigned char Blue() const { return m_blue; }
unsigned char Alpha() const { return m_alpha; }
// comparison // comparison
bool operator == (const wxColour& colour) const bool operator == (const wxColour& colour) const
{ {
// TODO: Really compare the NSColor return m_cocoaNSColor == colour.m_cocoaNSColor ||
return (m_cocoaNSColor == colour.m_cocoaNSColor (m_red == colour.m_red &&
|| (m_red == colour.m_red m_green == colour.m_green &&
&& m_green == colour.m_green m_blue == colour.m_blue &&
&& m_blue == colour.m_blue)); m_alpha == colour.m_alpha);
} }
bool operator != (const wxColour& colour) const bool operator != (const wxColour& colour) const
{ return !(*this == colour); } { return !(*this == colour); }
// Set() functions // Set() functions
void Set( WX_NSColor aColor ); void Set( WX_NSColor aColor );
// reroute the inherited ones // reroute the inherited ones
void Set(unsigned char red, unsigned char green, unsigned char blue) void Set(unsigned char red,
{ wxColourBase::Set(red,green,blue); } unsigned char green,
unsigned char blue,
// implemented in colourcmn.cpp unsigned char alpha = wxALPHA_OPAQUE)
{ wxColourBase::Set(red, green, blue, alpha); }
bool Set(const wxChar *str) bool Set(const wxChar *str)
{ return wxColourBase::Set(str); } { return wxColourBase::Set(str); }
bool Set(const wxString &str) bool Set(const wxString &str)
{ return wxColourBase::Set(str); } { return wxColourBase::Set(str); }
void Set(unsigned long colRGB) void Set(unsigned long colRGB)
{ wxColourBase::Set(colRGB); } { wxColourBase::Set(colRGB); }
protected: protected:
// puts the object in an invalid, uninitialized state // puts the object in an invalid, uninitialized state
void Init(); void Init();
virtual void InitWith( unsigned char red, unsigned char green, unsigned char blue ); virtual void InitWith(unsigned char red,
unsigned char green,
unsigned char blue,
unsigned char alpha);
private: private:
WX_NSColor m_cocoaNSColor; WX_NSColor m_cocoaNSColor;
unsigned char m_red; unsigned char m_red;
unsigned char m_green; unsigned char m_green;
unsigned char m_blue; unsigned char m_blue;
unsigned char m_alpha;
DECLARE_DYNAMIC_CLASS(wxColour) DECLARE_DYNAMIC_CLASS(wxColour)
}; };

View File

@@ -36,6 +36,7 @@ wxColour::wxColour (const wxColour& col)
, m_red(col.m_red) , m_red(col.m_red)
, m_green(col.m_green) , m_green(col.m_green)
, m_blue(col.m_blue) , m_blue(col.m_blue)
, m_alpha(col.m_alpha)
{ {
[m_cocoaNSColor retain]; [m_cocoaNSColor retain];
} }
@@ -52,6 +53,7 @@ wxColour& wxColour::operator =(const wxColour& col)
m_red = col.m_red; m_red = col.m_red;
m_green = col.m_green; m_green = col.m_green;
m_blue = col.m_blue; m_blue = col.m_blue;
m_alpha = col.m_alpha;
[m_cocoaNSColor retain]; [m_cocoaNSColor retain];
return *this; return *this;
} }
@@ -61,14 +63,18 @@ wxColour::~wxColour ()
[m_cocoaNSColor release]; [m_cocoaNSColor release];
} }
void wxColour::InitWith (unsigned char r, unsigned char g, unsigned char b) void wxColour::InitWith(unsigned char r,
unsigned char g,
unsigned char b,
unsigned char a)
{ {
wxAutoNSAutoreleasePool pool; wxAutoNSAutoreleasePool pool;
[m_cocoaNSColor release]; [m_cocoaNSColor release];
m_cocoaNSColor = [[NSColor colorWithCalibratedRed:r/255.0 green:g/255.0 blue:b/255.0 alpha:1.0] retain]; m_cocoaNSColor = [[NSColor colorWithCalibratedRed:r/255.0 green:g/255.0 blue:b/255.0 alpha:a/255.0] retain];
m_red = r; m_red = r;
m_green = g; m_green = g;
m_blue = b; m_blue = b;
m_alpha = a;
} }
void wxColour::Set( WX_NSColor aColor ) void wxColour::Set( WX_NSColor aColor )
@@ -84,4 +90,5 @@ void wxColour::Set( WX_NSColor aColor )
m_red = (wxUint8) ([rgbColor redComponent] * 255.0); m_red = (wxUint8) ([rgbColor redComponent] * 255.0);
m_green = (wxUint8) ([rgbColor greenComponent] * 255.0); m_green = (wxUint8) ([rgbColor greenComponent] * 255.0);
m_blue = (wxUint8) ([rgbColor blueComponent] * 255.0); m_blue = (wxUint8) ([rgbColor blueComponent] * 255.0);
m_alpha = (wxUint8) ([rgbColor alphaComponent] * 255.0);
} }