Updated wxPallete information.

Added GetColourCount() implementation to Carbon (I wonder
    why it doesnt just use the generic implementation).


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@41405 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robert Roebling 2006-09-24 10:27:12 +00:00
parent b9d880d638
commit df816ad92f
4 changed files with 38 additions and 20 deletions

View File

@ -579,9 +579,9 @@ used as a mask colour. Returns {\tt true} if the image currently has a mask.
\constfunc{const wxPalette\&}{GetPalette}{\void} \constfunc{const wxPalette\&}{GetPalette}{\void}
Returns the palette associated with the image. Currently the palette is only Returns the palette associated with the image. Currently the palette is only
used when converting to wxBitmap under Windows. used when converting to wxBitmap under Windows. Some of the wxImage handlers
have been modified to set the palette if one exists in the image file (usually
Eventually wxImage handlers will set the palette if one exists in the image file. 256 or less colour images in GIF or PNG format).
\membersection{wxImage::GetRed}\label{wximagegetred} \membersection{wxImage::GetRed}\label{wximagegetred}

View File

@ -11,8 +11,18 @@
\section{\class{wxPalette}}\label{wxpalette} \section{\class{wxPalette}}\label{wxpalette}
A palette is a table that maps pixel values to RGB colours. It allows the colours A palette is a table that maps pixel values to RGB colours. It allows the
of a low-depth bitmap, for example, to be mapped to the available colours in a display. 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
colours.
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 \helpref{wxImage}{wximage} for more information.
%TODO: topic overview for wxPalette. %TODO: topic overview for wxPalette.
\wxheading{Derived from} \wxheading{Derived from}

View File

@ -34,26 +34,25 @@ protected:
class WXDLLEXPORT wxPalette: public wxPaletteBase class WXDLLEXPORT wxPalette: public wxPaletteBase
{ {
DECLARE_DYNAMIC_CLASS(wxPalette)
public: public:
wxPalette(); wxPalette();
wxPalette(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue); wxPalette(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue);
virtual ~wxPalette(); virtual ~wxPalette();
bool Create(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue); bool Create(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue);
int GetPixel(unsigned char red, unsigned char green, unsigned char blue) const;
bool GetRGB(int pixel, unsigned char *red, unsigned char *green, unsigned char *blue) const; int GetPixel(unsigned char red, unsigned char green, unsigned char blue) const;
bool GetRGB(int pixel, unsigned char *red, unsigned char *green, unsigned char *blue) const;
virtual bool Ok() const { return (m_refData != NULL) ; } virtual bool Ok() const { return (m_refData != NULL) ; }
inline bool operator == (const wxPalette& palette) const { return m_refData == palette.m_refData; } inline bool operator == (const wxPalette& palette) const { return m_refData == palette.m_refData; }
inline bool operator != (const wxPalette& palette) const { return m_refData != palette.m_refData; } inline bool operator != (const wxPalette& palette) const { return m_refData != palette.m_refData; }
/* TODO: implementation virtual int GetColoursCount() const;
inline WXHPALETTE GetHPALETTE() const { return (M_PALETTEDATA ? M_PALETTEDATA->m_hPalette : 0); }
void SetHPALETTE(WXHPALETTE pal); private:
*/ DECLARE_DYNAMIC_CLASS(wxPalette)
}; };
#endif #endif

View File

@ -107,5 +107,14 @@ bool wxPalette::GetRGB(int index, unsigned char *red, unsigned char *green, unsi
return true; return true;
} }
int wxPalette::GetColoursCount() const
{
if (m_refData)
return M_PALETTEDATA->m_count;
return 0;
}
#endif #endif
// wxUSE_PALETTE // wxUSE_PALETTE