use wxColourDatabase::Find() instead of deprecated FindColour(); some minor code cleanup
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@24228 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
// Name: colour.h
|
// Name: wx/msw/colour.h
|
||||||
// Purpose: wxColour class
|
// Purpose: wxColour class
|
||||||
// Author: Julian Smart
|
// Author: Julian Smart
|
||||||
// Modified by:
|
// Modified by:
|
||||||
@@ -13,82 +13,99 @@
|
|||||||
#define _WX_COLOUR_H_
|
#define _WX_COLOUR_H_
|
||||||
|
|
||||||
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
||||||
#pragma interface "colour.h"
|
#pragma interface "colour.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/object.h"
|
#include "wx/object.h"
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
// Colour
|
// Colour
|
||||||
class WXDLLEXPORT wxColour: public wxObject
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class WXDLLEXPORT wxColour : public wxObject
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// ctors
|
// constructors
|
||||||
|
// ------------
|
||||||
|
|
||||||
// default
|
// default
|
||||||
wxColour();
|
wxColour() { Init(); }
|
||||||
// from RGB
|
|
||||||
wxColour( unsigned char red, unsigned char green, unsigned char blue );
|
// from separate RGB
|
||||||
wxColour( unsigned long colRGB ) { Set(colRGB); }
|
wxColour( unsigned char red, unsigned char green, unsigned char blue )
|
||||||
|
{ Set(red, green, blue); }
|
||||||
|
|
||||||
|
// from packed RGB
|
||||||
|
wxColour( unsigned long colRGB ) { Set(colRGB); }
|
||||||
|
|
||||||
// implicit conversion from the colour name
|
// implicit conversion from the colour name
|
||||||
wxColour( const wxString &colourName ) { InitFromName(colourName); }
|
wxColour(const wxString &colourName) { InitFromName(colourName); }
|
||||||
wxColour( const wxChar *colourName ) { InitFromName(colourName); }
|
wxColour(const wxChar *colourName) { InitFromName(colourName); }
|
||||||
|
|
||||||
|
|
||||||
// copy ctors and assignment operators
|
// copy ctors and assignment operators
|
||||||
wxColour( const wxColour& col );
|
wxColour(const wxColour& col);
|
||||||
wxColour& operator = ( const wxColour& col );
|
wxColour& operator=( const wxColour& col);
|
||||||
|
|
||||||
// dtor
|
// dtor
|
||||||
~wxColour();
|
~wxColour();
|
||||||
|
|
||||||
// to have the matching Create also for this class
|
|
||||||
void Create( unsigned char red, unsigned char green, unsigned char blue )
|
|
||||||
{ Set( red , green , blue ) ; }
|
|
||||||
|
|
||||||
// Set() functions
|
// other methods
|
||||||
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));
|
|
||||||
}
|
|
||||||
|
|
||||||
// accessors
|
// to have the matching Create also for this class
|
||||||
bool Ok() const {return m_isInit; }
|
void Create( unsigned char red, unsigned char green, unsigned char blue )
|
||||||
|
{ Set(red, green, blue); }
|
||||||
|
|
||||||
unsigned char Red() const { return m_red; }
|
// Set() functions
|
||||||
unsigned char Green() const { return m_green; }
|
void Set(unsigned char red, unsigned char green, unsigned char blue);
|
||||||
unsigned char Blue() const { return m_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));
|
||||||
|
}
|
||||||
|
|
||||||
// comparison
|
// accessors
|
||||||
bool operator==(const wxColour& colour) const
|
// ---------
|
||||||
{
|
|
||||||
return m_isInit == colour.m_isInit &&
|
|
||||||
m_red == colour.m_red &&
|
|
||||||
m_green == colour.m_green &&
|
|
||||||
m_blue == colour.m_blue;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator != (const wxColour& colour) const { return !(*this == colour); }
|
bool Ok() const {return m_isInit; }
|
||||||
|
|
||||||
WXCOLORREF GetPixel() const { return m_pixel; };
|
unsigned char Red() const { return m_red; }
|
||||||
|
unsigned char Green() const { return m_green; }
|
||||||
|
unsigned char Blue() const { return m_blue; }
|
||||||
|
|
||||||
|
// comparison
|
||||||
|
bool operator==(const wxColour& colour) const
|
||||||
|
{
|
||||||
|
return m_isInit == colour.m_isInit &&
|
||||||
|
m_red == colour.m_red &&
|
||||||
|
m_green == colour.m_green &&
|
||||||
|
m_blue == colour.m_blue;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool operator != (const wxColour& colour) const { return !(*this == colour); }
|
||||||
|
|
||||||
|
WXCOLORREF GetPixel() const { return m_pixel; };
|
||||||
|
|
||||||
public:
|
public:
|
||||||
WXCOLORREF m_pixel;
|
WXCOLORREF m_pixel;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_isInit;
|
bool m_isInit;
|
||||||
unsigned char m_red;
|
unsigned char m_red;
|
||||||
unsigned char m_blue;
|
unsigned char m_blue;
|
||||||
unsigned char m_green;
|
unsigned char m_green;
|
||||||
|
|
||||||
// helper func
|
// ctors helpers
|
||||||
void InitFromName(const wxString& colourName);
|
void Init();
|
||||||
|
void InitFromName(const wxString& colourName);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxColour)
|
DECLARE_DYNAMIC_CLASS(wxColour)
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -70,59 +70,44 @@ IMPLEMENT_DYNAMIC_CLASS(wxColour, wxObject)
|
|||||||
|
|
||||||
// Colour
|
// Colour
|
||||||
|
|
||||||
wxColour::wxColour ()
|
void wxColour::Init()
|
||||||
{
|
{
|
||||||
m_isInit = FALSE;
|
m_isInit = FALSE;
|
||||||
m_pixel = 0;
|
m_pixel = 0;
|
||||||
m_red = m_blue = m_green = 0;
|
m_red =
|
||||||
}
|
m_blue =
|
||||||
|
m_green = 0;
|
||||||
wxColour::wxColour (unsigned char r, unsigned char g, unsigned char b)
|
|
||||||
{
|
|
||||||
m_red = r;
|
|
||||||
m_green = g;
|
|
||||||
m_blue = b;
|
|
||||||
m_isInit = TRUE;
|
|
||||||
m_pixel = PALETTERGB (m_red, m_green, m_blue);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxColour::wxColour (const wxColour& col)
|
wxColour::wxColour (const wxColour& col)
|
||||||
{
|
{
|
||||||
m_red = col.m_red;
|
*this = col;
|
||||||
m_green = col.m_green;
|
|
||||||
m_blue = col.m_blue;
|
|
||||||
m_isInit = col.m_isInit;
|
|
||||||
m_pixel = col.m_pixel;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxColour& wxColour::operator =(const wxColour& col)
|
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_isInit = col.m_isInit;
|
m_isInit = col.m_isInit;
|
||||||
m_pixel = col.m_pixel;
|
m_pixel = col.m_pixel;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxColour::InitFromName(const wxString& col)
|
void wxColour::InitFromName(const wxString& name)
|
||||||
{
|
{
|
||||||
wxColour *the_colour = wxTheColourDatabase->FindColour (col);
|
if ( wxTheColourDatabase )
|
||||||
if (the_colour)
|
|
||||||
{
|
{
|
||||||
m_red = the_colour->Red ();
|
wxColour col = wxTheColourDatabase->Find(name);
|
||||||
m_green = the_colour->Green ();
|
if ( col.Ok() )
|
||||||
m_blue = the_colour->Blue ();
|
{
|
||||||
m_isInit = TRUE;
|
*this = col;
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
// leave invalid
|
||||||
m_red = 0;
|
Init();
|
||||||
m_green = 0;
|
|
||||||
m_blue = 0;
|
|
||||||
m_isInit = FALSE;
|
|
||||||
}
|
|
||||||
m_pixel = PALETTERGB (m_red, m_green, m_blue);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxColour::~wxColour()
|
wxColour::~wxColour()
|
||||||
@@ -131,9 +116,10 @@ wxColour::~wxColour()
|
|||||||
|
|
||||||
void wxColour::Set (unsigned char r, unsigned char g, unsigned char b)
|
void wxColour::Set (unsigned char r, unsigned char g, unsigned char b)
|
||||||
{
|
{
|
||||||
m_red = r;
|
m_red = r;
|
||||||
m_green = g;
|
m_green = g;
|
||||||
m_blue = b;
|
m_blue = b;
|
||||||
m_isInit = TRUE;
|
m_isInit = TRUE;
|
||||||
m_pixel = PALETTERGB (m_red, m_green, m_blue);
|
m_pixel = PALETTERGB (m_red, m_green, m_blue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user