2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: palette.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxPalette
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxPalette
|
|
|
|
@wxheader{palette.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A palette is a table that maps pixel values to RGB colours. It allows the
|
|
|
|
colours of a low-depth bitmap, for example, to be mapped to the available
|
|
|
|
colours in a display. The notion of palettes is becoming more and more
|
|
|
|
obsolete nowadays and only the MSW port is still using a native palette.
|
|
|
|
All other ports use generic code which is basically just an array of
|
2008-03-08 14:43:31 +00:00
|
|
|
colours.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
It is likely that in the future the only use for palettes within wxWidgets
|
|
|
|
will be for representing colour indeces from images (such as GIF or PNG).
|
|
|
|
The image handlers for these formats have been modified to create a palette
|
|
|
|
if there is such information in the original image file (usually 256 or less
|
|
|
|
colour images). See wxImage for more information.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{gdi}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@stdobjects
|
2008-03-10 15:24:38 +00:00
|
|
|
::Objects:, ::wxNullPalette,
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxDC::SetPalette, wxBitmap
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPalette : public wxGDIObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Creates a palette from arrays of size @e n, one for each
|
|
|
|
red, blue or green component.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param palette
|
2008-03-09 12:33:59 +00:00
|
|
|
A pointer or reference to the palette to copy.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param n
|
2008-03-09 12:33:59 +00:00
|
|
|
The number of indices in the palette.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param red
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of red values.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param green
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of green values.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param blue
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of blue values.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see Create()
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxPalette();
|
2008-03-08 14:43:31 +00:00
|
|
|
wxPalette(const wxPalette& palette);
|
|
|
|
wxPalette(int n, const unsigned char* red,
|
|
|
|
const unsigned char* green,
|
|
|
|
const unsigned char* blue);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
See @ref overview_refcountdestruct "reference-counted object destruction" for
|
|
|
|
more info.
|
|
|
|
*/
|
|
|
|
~wxPalette();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates a palette from arrays of size @e n, one for each
|
|
|
|
red, blue or green component.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param n
|
2008-03-09 12:33:59 +00:00
|
|
|
The number of indices in the palette.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param red
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of red values.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param green
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of green values.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param blue
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of blue values.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if the creation was successful, @false otherwise.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see wxPalette()
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Create(int n, const unsigned char* red,
|
|
|
|
const unsigned char* green,
|
|
|
|
const unsigned char* blue);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns number of entries in palette.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
int GetColoursCount() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns a pixel value (index into the palette) for the given RGB values.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param red
|
2008-03-09 12:33:59 +00:00
|
|
|
Red value.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param green
|
2008-03-09 12:33:59 +00:00
|
|
|
Green value.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param blue
|
2008-03-09 12:33:59 +00:00
|
|
|
Blue value.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns The nearest palette index or wxNOT_FOUND for unexpected errors.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see GetRGB()
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
int GetPixel(unsigned char red, unsigned char green,
|
2008-03-09 16:24:26 +00:00
|
|
|
unsigned char blue) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns RGB values for a given palette index.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param pixel
|
2008-03-09 12:33:59 +00:00
|
|
|
The palette index.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param red
|
2008-03-09 12:33:59 +00:00
|
|
|
Receives the red value.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param green
|
2008-03-09 12:33:59 +00:00
|
|
|
Receives the green value.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param blue
|
2008-03-09 12:33:59 +00:00
|
|
|
Receives the blue value.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if the operation was successful.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see GetPixel()
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool GetRGB(int pixel, const unsigned char* red,
|
|
|
|
const unsigned char* green,
|
2008-03-09 16:24:26 +00:00
|
|
|
const unsigned char* blue) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if palette data is present.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsOk() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Assignment operator, using @ref overview_trefcount "reference counting".
|
|
|
|
*/
|
|
|
|
wxPalette operator =(const wxPalette& palette);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxPalette Objects:
|
|
|
|
;
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxPalette wxNullPalette;
|
|
|
|
|
|
|
|
|