d662a2223e
This method can be used to return the perceived brightness of the colour. Closes https://github.com/wxWidgets/wxWidgets/pull/1300
236 lines
7.8 KiB
C++
236 lines
7.8 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: wx/colour.h
|
|
// Purpose: wxColourBase definition
|
|
// Author: Julian Smart
|
|
// Modified by: Francesco Montorsi
|
|
// Created:
|
|
// Copyright: Julian Smart
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef _WX_COLOUR_H_BASE_
|
|
#define _WX_COLOUR_H_BASE_
|
|
|
|
#include "wx/defs.h"
|
|
#include "wx/gdiobj.h"
|
|
|
|
class WXDLLIMPEXP_FWD_CORE wxColour;
|
|
|
|
// A macro to define the standard wxColour constructors:
|
|
//
|
|
// It avoids the need to repeat these lines across all colour.h files, since
|
|
// Set() is a virtual function and thus cannot be called by wxColourBase ctors
|
|
#define DEFINE_STD_WXCOLOUR_CONSTRUCTORS \
|
|
wxColour() { Init(); } \
|
|
wxColour(ChannelType red, \
|
|
ChannelType green, \
|
|
ChannelType blue, \
|
|
ChannelType alpha = wxALPHA_OPAQUE) \
|
|
{ Init(); Set(red, green, blue, alpha); } \
|
|
wxColour(unsigned long colRGB) { Init(); Set(colRGB ); } \
|
|
wxColour(const wxString& colourName) { Init(); Set(colourName); } \
|
|
wxColour(const char *colourName) { Init(); Set(colourName); } \
|
|
wxColour(const wchar_t *colourName) { Init(); Set(colourName); }
|
|
|
|
|
|
// flags for wxColour -> wxString conversion (see wxColour::GetAsString)
|
|
enum {
|
|
wxC2S_NAME = 1, // return colour name, when possible
|
|
wxC2S_CSS_SYNTAX = 2, // return colour in rgb(r,g,b) syntax
|
|
wxC2S_HTML_SYNTAX = 4 // return colour in #rrggbb syntax
|
|
};
|
|
|
|
const unsigned char wxALPHA_TRANSPARENT = 0;
|
|
const unsigned char wxALPHA_OPAQUE = 0xff;
|
|
|
|
// a valid but fully transparent colour
|
|
#define wxTransparentColour wxColour(0, 0, 0, wxALPHA_TRANSPARENT)
|
|
#define wxTransparentColor wxTransparentColour
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// wxVariant support
|
|
// ----------------------------------------------------------------------------
|
|
|
|
#if wxUSE_VARIANT
|
|
#include "wx/variant.h"
|
|
DECLARE_VARIANT_OBJECT_EXPORTED(wxColour,WXDLLIMPEXP_CORE)
|
|
#endif
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// wxColourBase: this class has no data members, just some functions to avoid
|
|
// code redundancy in all native wxColour implementations
|
|
//-----------------------------------------------------------------------------
|
|
|
|
/* Transition from wxGDIObject to wxObject is incomplete. If your port does
|
|
not need the wxGDIObject machinery to handle colors, please add it to the
|
|
list of ports which do not need it.
|
|
*/
|
|
#if defined( __WXMSW__ ) || defined( __WXQT__ )
|
|
#define wxCOLOUR_IS_GDIOBJECT 0
|
|
#else
|
|
#define wxCOLOUR_IS_GDIOBJECT 1
|
|
#endif
|
|
|
|
class WXDLLIMPEXP_CORE wxColourBase : public
|
|
#if wxCOLOUR_IS_GDIOBJECT
|
|
wxGDIObject
|
|
#else
|
|
wxObject
|
|
#endif
|
|
{
|
|
public:
|
|
// type of a single colour component
|
|
typedef unsigned char ChannelType;
|
|
|
|
wxColourBase() {}
|
|
virtual ~wxColourBase() {}
|
|
|
|
|
|
// Set() functions
|
|
// ---------------
|
|
|
|
void Set(ChannelType red,
|
|
ChannelType green,
|
|
ChannelType blue,
|
|
ChannelType alpha = wxALPHA_OPAQUE)
|
|
{ InitRGBA(red, green, blue, alpha); }
|
|
|
|
// implemented in colourcmn.cpp
|
|
bool Set(const wxString &str)
|
|
{ return FromString(str); }
|
|
|
|
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((ChannelType)(0xFF & colRGB),
|
|
(ChannelType)(0xFF & (colRGB >> 8)),
|
|
(ChannelType)(0xFF & (colRGB >> 16)));
|
|
}
|
|
|
|
|
|
|
|
// accessors
|
|
// ---------
|
|
|
|
virtual ChannelType Red() const = 0;
|
|
virtual ChannelType Green() const = 0;
|
|
virtual ChannelType Blue() const = 0;
|
|
virtual ChannelType Alpha() const
|
|
{ return wxALPHA_OPAQUE ; }
|
|
|
|
virtual bool IsSolid() const
|
|
{ return true; }
|
|
|
|
// implemented in colourcmn.cpp
|
|
virtual wxString GetAsString(long flags = wxC2S_NAME | wxC2S_CSS_SYNTAX) const;
|
|
|
|
void SetRGB(wxUint32 colRGB)
|
|
{
|
|
Set((ChannelType)(0xFF & colRGB),
|
|
(ChannelType)(0xFF & (colRGB >> 8)),
|
|
(ChannelType)(0xFF & (colRGB >> 16)));
|
|
}
|
|
|
|
void SetRGBA(wxUint32 colRGBA)
|
|
{
|
|
Set((ChannelType)(0xFF & colRGBA),
|
|
(ChannelType)(0xFF & (colRGBA >> 8)),
|
|
(ChannelType)(0xFF & (colRGBA >> 16)),
|
|
(ChannelType)(0xFF & (colRGBA >> 24)));
|
|
}
|
|
|
|
wxUint32 GetRGB() const
|
|
{ return Red() | (Green() << 8) | (Blue() << 16); }
|
|
|
|
wxUint32 GetRGBA() const
|
|
{ return Red() | (Green() << 8) | (Blue() << 16) | (Alpha() << 24); }
|
|
|
|
#if !wxCOLOUR_IS_GDIOBJECT
|
|
virtual bool IsOk() const= 0;
|
|
|
|
// older version, for backwards compatibility only (but not deprecated
|
|
// because it's still widely used)
|
|
bool Ok() const { return IsOk(); }
|
|
#endif
|
|
|
|
// Return the perceived brightness of the colour, with 0 for black and 1
|
|
// for white.
|
|
double GetLuminance() const;
|
|
|
|
// manipulation
|
|
// ------------
|
|
|
|
// These methods are static because they are mostly used
|
|
// within tight loops (where we don't want to instantiate wxColour's)
|
|
|
|
static void MakeMono (unsigned char* r, unsigned char* g, unsigned char* b, bool on);
|
|
static void MakeDisabled(unsigned char* r, unsigned char* g, unsigned char* b, unsigned char brightness = 255);
|
|
static void MakeGrey (unsigned char* r, unsigned char* g, unsigned char* b); // integer version
|
|
static void MakeGrey (unsigned char* r, unsigned char* g, unsigned char* b,
|
|
double weight_r, double weight_g, double weight_b); // floating point version
|
|
static unsigned char AlphaBlend (unsigned char fg, unsigned char bg, double alpha);
|
|
static void ChangeLightness(unsigned char* r, unsigned char* g, unsigned char* b, int ialpha);
|
|
|
|
wxColour ChangeLightness(int ialpha) const;
|
|
wxColour& MakeDisabled(unsigned char brightness = 255);
|
|
|
|
protected:
|
|
// Some ports need Init() and while we don't, provide a stub so that the
|
|
// ports which don't need it are not forced to define it
|
|
void Init() { }
|
|
|
|
virtual void
|
|
InitRGBA(ChannelType r, ChannelType g, ChannelType b, ChannelType a) = 0;
|
|
|
|
virtual bool FromString(const wxString& s);
|
|
|
|
#if wxCOLOUR_IS_GDIOBJECT
|
|
// wxColour doesn't use reference counted data (at least not in all ports)
|
|
// so provide stubs for the functions which need to be defined if we do use
|
|
// them
|
|
virtual wxGDIRefData *CreateGDIRefData() const wxOVERRIDE
|
|
{
|
|
wxFAIL_MSG( "must be overridden if used" );
|
|
|
|
return NULL;
|
|
}
|
|
|
|
virtual wxGDIRefData *CloneGDIRefData(const wxGDIRefData *WXUNUSED(data)) const wxOVERRIDE
|
|
{
|
|
wxFAIL_MSG( "must be overridden if used" );
|
|
|
|
return NULL;
|
|
}
|
|
#endif
|
|
};
|
|
|
|
|
|
// wxColour <-> wxString utilities, used by wxConfig, defined in colourcmn.cpp
|
|
WXDLLIMPEXP_CORE wxString wxToString(const wxColourBase& col);
|
|
WXDLLIMPEXP_CORE bool wxFromString(const wxString& str, wxColourBase* col);
|
|
|
|
|
|
|
|
#if defined(__WXMSW__)
|
|
#include "wx/msw/colour.h"
|
|
#elif defined(__WXMOTIF__)
|
|
#include "wx/motif/colour.h"
|
|
#elif defined(__WXGTK20__)
|
|
#include "wx/gtk/colour.h"
|
|
#elif defined(__WXGTK__)
|
|
#include "wx/gtk1/colour.h"
|
|
#elif defined(__WXDFB__)
|
|
#include "wx/generic/colour.h"
|
|
#elif defined(__WXX11__)
|
|
#include "wx/x11/colour.h"
|
|
#elif defined(__WXMAC__)
|
|
#include "wx/osx/colour.h"
|
|
#elif defined(__WXQT__)
|
|
#include "wx/qt/colour.h"
|
|
#endif
|
|
|
|
#define wxColor wxColour
|
|
|
|
#endif // _WX_COLOUR_H_BASE_
|