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,15 +46,16 @@ public:
unsigned char Red() const { return m_red; }
unsigned char Green() const { return m_green; }
unsigned char Blue() const { return m_blue; }
unsigned char Alpha() const { return m_alpha; }
// comparison
bool operator == (const wxColour& colour) const
{
// TODO: Really compare the NSColor
return (m_cocoaNSColor == colour.m_cocoaNSColor
|| (m_red == colour.m_red
&& m_green == colour.m_green
&& m_blue == colour.m_blue));
return m_cocoaNSColor == colour.m_cocoaNSColor ||
(m_red == colour.m_red &&
m_green == colour.m_green &&
m_blue == colour.m_blue &&
m_alpha == colour.m_alpha);
}
bool operator != (const wxColour& colour) const
{ return !(*this == colour); }
@@ -63,10 +64,12 @@ public:
void Set( WX_NSColor aColor );
// reroute the inherited ones
void Set(unsigned char red, unsigned char green, unsigned char blue)
{ wxColourBase::Set(red,green,blue); }
void Set(unsigned char red,
unsigned char green,
unsigned char blue,
unsigned char alpha = wxALPHA_OPAQUE)
{ wxColourBase::Set(red, green, blue, alpha); }
// implemented in colourcmn.cpp
bool Set(const wxChar *str)
{ return wxColourBase::Set(str); }
@@ -80,13 +83,17 @@ protected:
// puts the object in an invalid, uninitialized state
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:
WX_NSColor m_cocoaNSColor;
unsigned char m_red;
unsigned char m_green;
unsigned char m_blue;
unsigned char m_alpha;
DECLARE_DYNAMIC_CLASS(wxColour)
};

View File

@@ -36,6 +36,7 @@ wxColour::wxColour (const wxColour& col)
, m_red(col.m_red)
, m_green(col.m_green)
, m_blue(col.m_blue)
, m_alpha(col.m_alpha)
{
[m_cocoaNSColor retain];
}
@@ -52,6 +53,7 @@ wxColour& wxColour::operator =(const wxColour& col)
m_red = col.m_red;
m_green = col.m_green;
m_blue = col.m_blue;
m_alpha = col.m_alpha;
[m_cocoaNSColor retain];
return *this;
}
@@ -61,14 +63,18 @@ wxColour::~wxColour ()
[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;
[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_green = g;
m_blue = b;
m_alpha = a;
}
void wxColour::Set( WX_NSColor aColor )
@@ -84,4 +90,5 @@ void wxColour::Set( WX_NSColor aColor )
m_red = (wxUint8) ([rgbColor redComponent] * 255.0);
m_green = (wxUint8) ([rgbColor greenComponent] * 255.0);
m_blue = (wxUint8) ([rgbColor blueComponent] * 255.0);
m_alpha = (wxUint8) ([rgbColor alphaComponent] * 255.0);
}