// Modified by:
// Created: 01/02/97
// RCS-ID: $Id$
-// Copyright: (c) Julian Smart and Markus Holzem
+// Copyright: (c) Julian Smart
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
-#pragma implementation "colour.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
// Colour
-wxColour::wxColour()
+void wxColour::Init()
{
- m_red = m_blue = m_green = 0;
- m_isInit = FALSE;
+ m_red =
+ m_blue =
+ m_green = 0;
+ m_isInit = false;
}
-wxColour::wxColour(unsigned char r, unsigned char g, unsigned char b)
+wxColour::wxColour()
{
- m_red = r;
- m_green = g;
- m_blue = b;
- m_isInit = TRUE;
+ Init();
}
wxColour::wxColour(const wxColour& col)
{
- m_red = col.m_red;
- m_green = col.m_green;
- m_blue = col.m_blue;
- m_isInit = col.m_isInit;
+ *this = col;
}
wxColour& wxColour::operator =(const wxColour& col)
{
- m_red = col.m_red;
- m_green = col.m_green;
- m_blue = col.m_blue;
- m_isInit = col.m_isInit;
- return *this;
+ m_red = col.m_red;
+ m_green = col.m_green;
+ m_blue = col.m_blue;
+ m_isInit = col.m_isInit;
+ return *this;
}
-void wxColour::InitFromName(const wxString& col)
+void wxColour::InitFromName(const wxString& name)
{
- wxColour *the_colour = wxTheColourDatabase->FindColour (col);
- if (the_colour)
- {
- m_red = the_colour->Red();
- m_green = the_colour->Green();
- m_blue = the_colour->Blue();
- m_isInit = TRUE;
- }
- else
+ if ( wxTheColourDatabase )
{
- m_red = 0;
- m_green = 0;
- m_blue = 0;
- m_isInit = FALSE;
+ wxColour col = wxTheColourDatabase->Find(name);
+ if ( col.Ok() )
+ {
+ *this = col;
+ return;
+ }
}
+
+ // leave invalid
+ Init();
}
wxColour::~wxColour()
void wxColour::Set(unsigned char r, unsigned char g, unsigned char b)
{
- m_red = r;
- m_green = g;
- m_blue = b;
- m_isInit = TRUE;
-}
-
-// Obsolete
-#if WXWIN_COMPATIBILITY
-void wxColour::Get(unsigned char *r, unsigned char *g, unsigned char *b) const
-{
- *r = m_red;
- *g = m_green;
- *b = m_blue;
+ m_red = r;
+ m_green = g;
+ m_blue = b;
+ m_isInit = true;
}
-#endif
-