implemented dummy wxPalette for wxGTK, so that it no longer pops up assertion failures and wxImage and image handlers work correctly now.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@9579 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
4178000933
commit
cb332bc6b7
@ -21,6 +21,11 @@
|
||||
// wxPalette
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
struct wxPaletteEntry
|
||||
{
|
||||
unsigned char red, green, blue;
|
||||
};
|
||||
|
||||
class wxPaletteRefData: public wxObjectRefData
|
||||
{
|
||||
public:
|
||||
@ -28,17 +33,28 @@ class wxPaletteRefData: public wxObjectRefData
|
||||
wxPaletteRefData(void);
|
||||
~wxPaletteRefData(void);
|
||||
|
||||
int m_count;
|
||||
wxPaletteEntry *m_entries;
|
||||
#if 0
|
||||
GdkColormap *m_colormap;
|
||||
#endif
|
||||
};
|
||||
|
||||
wxPaletteRefData::wxPaletteRefData()
|
||||
{
|
||||
m_count = 0;
|
||||
m_entries = NULL;
|
||||
#if 0
|
||||
m_colormap = (GdkColormap *) NULL;
|
||||
#endif
|
||||
}
|
||||
|
||||
wxPaletteRefData::~wxPaletteRefData()
|
||||
{
|
||||
delete[] m_entries;
|
||||
#if 0
|
||||
if (m_colormap) gdk_colormap_unref( m_colormap );
|
||||
#endif
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
@ -49,11 +65,11 @@ IMPLEMENT_DYNAMIC_CLASS(wxPalette,wxGDIObject)
|
||||
|
||||
wxPalette::wxPalette()
|
||||
{
|
||||
m_refData = NULL;
|
||||
}
|
||||
|
||||
wxPalette::wxPalette(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue)
|
||||
{
|
||||
m_refData = new wxPaletteRefData();
|
||||
Create(n, red, green, blue);
|
||||
}
|
||||
|
||||
@ -88,32 +104,63 @@ bool wxPalette::Ok(void) const
|
||||
return (m_refData != NULL);
|
||||
}
|
||||
|
||||
bool wxPalette::Create( int WXUNUSED(n),
|
||||
const unsigned char *WXUNUSED(red),
|
||||
const unsigned char *WXUNUSED(green),
|
||||
const unsigned char *WXUNUSED(blue) )
|
||||
bool wxPalette::Create(int n,
|
||||
const unsigned char *red,
|
||||
const unsigned char *green,
|
||||
const unsigned char *blue)
|
||||
{
|
||||
wxFAIL_MSG(wxT("not implemented"));
|
||||
UnRef();
|
||||
m_refData = new wxPaletteRefData();
|
||||
|
||||
return FALSE;
|
||||
M_PALETTEDATA->m_count = n;
|
||||
M_PALETTEDATA->m_entries = new wxPaletteEntry[n];
|
||||
|
||||
wxPaletteEntry *e = M_PALETTEDATA->m_entries;
|
||||
for (int i = 0; i < n; i++, e++)
|
||||
{
|
||||
e->red = red[i];
|
||||
e->green = green[i];
|
||||
e->blue = blue[i];
|
||||
}
|
||||
|
||||
int wxPalette::GetPixel( const unsigned char WXUNUSED(red),
|
||||
const unsigned char WXUNUSED(green),
|
||||
const unsigned char WXUNUSED(blue) ) const
|
||||
{
|
||||
wxFAIL_MSG(wxT("not implemented"));
|
||||
|
||||
return 0;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
bool wxPalette::GetRGB( int WXUNUSED(pixel),
|
||||
unsigned char *WXUNUSED(red),
|
||||
unsigned char *WXUNUSED(green),
|
||||
unsigned char *WXUNUSED(blue) ) const
|
||||
int wxPalette::GetPixel( const unsigned char red,
|
||||
const unsigned char green,
|
||||
const unsigned char blue ) const
|
||||
{
|
||||
wxFAIL_MSG(wxT("not implemented"));
|
||||
if (!m_refData) return FALSE;
|
||||
|
||||
return 0;
|
||||
int closest = 0;
|
||||
double d,distance = 1000.0; // max. dist is 256
|
||||
|
||||
wxPaletteEntry *e = M_PALETTEDATA->m_entries;
|
||||
for (int i = 0; i < M_PALETTEDATA->m_count; i++, e++)
|
||||
{
|
||||
if ((d = 0.299 * abs(red - e->red) +
|
||||
0.587 * abs(green - e->green) +
|
||||
0.114 * abs(blue - e->blue)) < distance) {
|
||||
distance = d;
|
||||
closest = i;
|
||||
}
|
||||
}
|
||||
return closest;
|
||||
}
|
||||
|
||||
bool wxPalette::GetRGB(int pixel,
|
||||
unsigned char *red,
|
||||
unsigned char *green,
|
||||
unsigned char *blue) const
|
||||
{
|
||||
if (!m_refData) return FALSE;
|
||||
if (pixel >= M_PALETTEDATA->m_count) return FALSE;
|
||||
|
||||
wxPaletteEntry& p = M_PALETTEDATA->m_entries[pixel];
|
||||
if (red) *red = p.red;
|
||||
if (green) *green = p.green;
|
||||
if (blue) *blue = p.blue;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
|
@ -21,6 +21,11 @@
|
||||
// wxPalette
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
struct wxPaletteEntry
|
||||
{
|
||||
unsigned char red, green, blue;
|
||||
};
|
||||
|
||||
class wxPaletteRefData: public wxObjectRefData
|
||||
{
|
||||
public:
|
||||
@ -28,17 +33,28 @@ class wxPaletteRefData: public wxObjectRefData
|
||||
wxPaletteRefData(void);
|
||||
~wxPaletteRefData(void);
|
||||
|
||||
int m_count;
|
||||
wxPaletteEntry *m_entries;
|
||||
#if 0
|
||||
GdkColormap *m_colormap;
|
||||
#endif
|
||||
};
|
||||
|
||||
wxPaletteRefData::wxPaletteRefData()
|
||||
{
|
||||
m_count = 0;
|
||||
m_entries = NULL;
|
||||
#if 0
|
||||
m_colormap = (GdkColormap *) NULL;
|
||||
#endif
|
||||
}
|
||||
|
||||
wxPaletteRefData::~wxPaletteRefData()
|
||||
{
|
||||
delete[] m_entries;
|
||||
#if 0
|
||||
if (m_colormap) gdk_colormap_unref( m_colormap );
|
||||
#endif
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
@ -49,11 +65,11 @@ IMPLEMENT_DYNAMIC_CLASS(wxPalette,wxGDIObject)
|
||||
|
||||
wxPalette::wxPalette()
|
||||
{
|
||||
m_refData = NULL;
|
||||
}
|
||||
|
||||
wxPalette::wxPalette(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue)
|
||||
{
|
||||
m_refData = new wxPaletteRefData();
|
||||
Create(n, red, green, blue);
|
||||
}
|
||||
|
||||
@ -88,32 +104,63 @@ bool wxPalette::Ok(void) const
|
||||
return (m_refData != NULL);
|
||||
}
|
||||
|
||||
bool wxPalette::Create( int WXUNUSED(n),
|
||||
const unsigned char *WXUNUSED(red),
|
||||
const unsigned char *WXUNUSED(green),
|
||||
const unsigned char *WXUNUSED(blue) )
|
||||
bool wxPalette::Create(int n,
|
||||
const unsigned char *red,
|
||||
const unsigned char *green,
|
||||
const unsigned char *blue)
|
||||
{
|
||||
wxFAIL_MSG(wxT("not implemented"));
|
||||
UnRef();
|
||||
m_refData = new wxPaletteRefData();
|
||||
|
||||
return FALSE;
|
||||
M_PALETTEDATA->m_count = n;
|
||||
M_PALETTEDATA->m_entries = new wxPaletteEntry[n];
|
||||
|
||||
wxPaletteEntry *e = M_PALETTEDATA->m_entries;
|
||||
for (int i = 0; i < n; i++, e++)
|
||||
{
|
||||
e->red = red[i];
|
||||
e->green = green[i];
|
||||
e->blue = blue[i];
|
||||
}
|
||||
|
||||
int wxPalette::GetPixel( const unsigned char WXUNUSED(red),
|
||||
const unsigned char WXUNUSED(green),
|
||||
const unsigned char WXUNUSED(blue) ) const
|
||||
{
|
||||
wxFAIL_MSG(wxT("not implemented"));
|
||||
|
||||
return 0;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
bool wxPalette::GetRGB( int WXUNUSED(pixel),
|
||||
unsigned char *WXUNUSED(red),
|
||||
unsigned char *WXUNUSED(green),
|
||||
unsigned char *WXUNUSED(blue) ) const
|
||||
int wxPalette::GetPixel( const unsigned char red,
|
||||
const unsigned char green,
|
||||
const unsigned char blue ) const
|
||||
{
|
||||
wxFAIL_MSG(wxT("not implemented"));
|
||||
if (!m_refData) return FALSE;
|
||||
|
||||
return 0;
|
||||
int closest = 0;
|
||||
double d,distance = 1000.0; // max. dist is 256
|
||||
|
||||
wxPaletteEntry *e = M_PALETTEDATA->m_entries;
|
||||
for (int i = 0; i < M_PALETTEDATA->m_count; i++, e++)
|
||||
{
|
||||
if ((d = 0.299 * abs(red - e->red) +
|
||||
0.587 * abs(green - e->green) +
|
||||
0.114 * abs(blue - e->blue)) < distance) {
|
||||
distance = d;
|
||||
closest = i;
|
||||
}
|
||||
}
|
||||
return closest;
|
||||
}
|
||||
|
||||
bool wxPalette::GetRGB(int pixel,
|
||||
unsigned char *red,
|
||||
unsigned char *green,
|
||||
unsigned char *blue) const
|
||||
{
|
||||
if (!m_refData) return FALSE;
|
||||
if (pixel >= M_PALETTEDATA->m_count) return FALSE;
|
||||
|
||||
wxPaletteEntry& p = M_PALETTEDATA->m_entries[pixel];
|
||||
if (red) *red = p.red;
|
||||
if (green) *green = p.green;
|
||||
if (blue) *blue = p.blue;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user