/////////////////////////////////////////////////////////////////////////////
-// Name: colour.h
+// Name: wx/cocoa/colour.h
// Purpose: wxColour class
// Author: David Elliott
// Modified by:
// ========================================================================
// wxColour
// ========================================================================
-class WXDLLEXPORT wxColour: public wxObject
+
+class WXDLLEXPORT wxColour : public wxColourBase
{
public:
- DECLARE_DYNAMIC_CLASS(wxColour)
-// ------------------------------------------------------------------------
-// initialization
-// ------------------------------------------------------------------------
- wxColour();
- // from RGB
- wxColour( unsigned char red, unsigned char green, unsigned char blue )
- : m_cocoaNSColor(NULL)
- { Set(red,green,blue); }
- wxColour( unsigned long colRGB )
- : m_cocoaNSColor(NULL)
- { Set(colRGB); }
-
- // implicit conversion from the colour name
- wxColour( const wxString &colourName )
- : m_cocoaNSColor(NULL)
- { InitFromName(colourName); }
- wxColour( const char *colourName )
- : m_cocoaNSColor(NULL)
- { InitFromName(wxString::FromAscii(colourName)); }
+ // constructors
+ // ------------
+
+ // default
+ wxColour() { Init(); }
+ DEFINE_STD_WXCOLOUR_CONSTRUCTORS
+
+ // initialization using existing NSColor
+ wxColour( WX_NSColor aColor );
+
// copy ctors and assignment operators
wxColour( const wxColour& col );
wxColour& operator = ( const wxColour& col );
- ~wxColour();
+ virtual ~wxColour();
-// ------------------------------------------------------------------------
-// Implementation
-// ------------------------------------------------------------------------
// accessors
bool Ok() const { return m_cocoaNSColor; }
- inline WX_NSColor GetNSColor() { return m_cocoaNSColor; }
+ WX_NSColor GetNSColor() { return m_cocoaNSColor; }
unsigned char Red() const { return m_red; }
unsigned char Green() const { return m_green; }
// comparison
bool operator == (const wxColour& colour) const
{
- return (m_cocoaNSColor == colour.m_cocoaNSColor &&
- m_red == colour.m_red &&
- m_green == colour.m_green &&
- m_blue == colour.m_blue);
+ // 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));
}
bool operator != (const wxColour& colour) const
{ return !(*this == colour); }
-// const WXCOLORREF& GetPixel() const { return m_pixel; };
-
// Set() functions
- void Set( unsigned char red, unsigned char green, unsigned char blue );
- void Set( unsigned long colRGB )
- {
- // we don't need to know sizeof(long) here because we assume that the three
- // least significant bytes contain the R, G and B values
- Set((unsigned char)colRGB,
- (unsigned char)(colRGB >> 8),
- (unsigned char)(colRGB >> 16));
- }
-
+ 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); }
+
+ // implemented in colourcmn.cpp
+ bool Set(const wxChar *str)
+ { return wxColourBase::Set(str); }
+
+ bool Set(const wxString &str)
+ { return wxColourBase::Set(str); }
+
+ void Set(unsigned long colRGB)
+ { wxColourBase::Set(colRGB); }
+
protected:
- void InitFromName(const wxString& col);
+ // puts the object in an invalid, uninitialized state
+ void Init();
+
+ virtual void InitWith( unsigned char red, unsigned char green, unsigned char blue );
private:
WX_NSColor m_cocoaNSColor;
unsigned char m_red;
unsigned char m_green;
unsigned char m_blue;
+
+ DECLARE_DYNAMIC_CLASS(wxColour)
};
#endif // __WX_COCOA_COLOUR_H__