This keyword is not expanded by Git which means it's not replaced with the correct revision value in the releases made using git-based scripts and it's confusing to have lines with unexpanded "$Id$" in the released files. As expanding them with Git is not that simple (it could be done with git archive and export-subst attribute) and there are not many benefits in having them in the first place, just remove all these lines. If nothing else, this will make an eventual transition to Git simpler. Closes #14487. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@74602 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
262 lines
6.9 KiB
C++
262 lines
6.9 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: src/x11/colour.cpp
|
|
// Purpose: wxColour class
|
|
// Author: Julian Smart, Robert Roebling
|
|
// Modified by:
|
|
// Created: 17/09/98
|
|
// Copyright: (c) Julian Smart, Robert Roebling
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// For compilers that support precompilation, includes "wx.h".
|
|
#include "wx/wxprec.h"
|
|
|
|
#include "wx/colour.h"
|
|
|
|
#ifndef WX_PRECOMP
|
|
#include "wx/app.h"
|
|
#include "wx/gdicmn.h"
|
|
#endif
|
|
|
|
#include "wx/x11/private.h"
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// wxColour
|
|
//-----------------------------------------------------------------------------
|
|
|
|
class wxColourRefData : public wxGDIRefData
|
|
{
|
|
public:
|
|
wxColourRefData()
|
|
{
|
|
m_color.red = 0;
|
|
m_color.green = 0;
|
|
m_color.blue = 0;
|
|
m_color.pixel = 0;
|
|
m_colormap = NULL;
|
|
m_hasPixel = false;
|
|
}
|
|
|
|
wxColourRefData(const wxColourRefData& data)
|
|
{
|
|
m_color = data.m_color;
|
|
m_colormap = data.m_colormap;
|
|
m_hasPixel = data.m_hasPixel;
|
|
}
|
|
|
|
virtual ~wxColourRefData()
|
|
{
|
|
FreeColour();
|
|
}
|
|
|
|
bool operator==(const wxColourRefData& data) const
|
|
{
|
|
return (m_colormap == data.m_colormap &&
|
|
m_hasPixel == data.m_hasPixel &&
|
|
m_color.red == data.m_color.red &&
|
|
m_color.green == data.m_color.green &&
|
|
m_color.blue == data.m_color.blue &&
|
|
m_color.pixel == data.m_color.pixel);
|
|
}
|
|
|
|
void FreeColour();
|
|
void AllocColour( WXColormap cmap );
|
|
|
|
XColor m_color;
|
|
WXColormap m_colormap;
|
|
bool m_hasPixel;
|
|
|
|
friend class wxColour;
|
|
|
|
// reference counter for systems with <= 8-Bit display
|
|
static unsigned short colMapAllocCounter[ 256 ];
|
|
};
|
|
|
|
unsigned short wxColourRefData::colMapAllocCounter[ 256 ] =
|
|
{
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
|
|
};
|
|
|
|
void wxColourRefData::FreeColour()
|
|
{
|
|
if (!m_colormap)
|
|
return;
|
|
#if !wxUSE_NANOX
|
|
if ( wxTheApp &&
|
|
(wxTheApp->m_visualInfo->m_visualType == GrayScale ||
|
|
wxTheApp->m_visualInfo->m_visualType == PseudoColor) )
|
|
{
|
|
int idx = m_color.pixel;
|
|
colMapAllocCounter[ idx ] = colMapAllocCounter[ idx ] - 1;
|
|
|
|
if (colMapAllocCounter[ idx ] == 0)
|
|
{
|
|
unsigned long pixel = m_color.pixel;
|
|
XFreeColors( wxGlobalDisplay(), (Colormap) m_colormap, &pixel, 1, 0 );
|
|
}
|
|
}
|
|
#endif
|
|
}
|
|
|
|
void wxColourRefData::AllocColour( WXColormap cmap )
|
|
{
|
|
if (m_hasPixel && (m_colormap == cmap))
|
|
return;
|
|
|
|
FreeColour();
|
|
|
|
#if !wxUSE_NANOX
|
|
if ((wxTheApp->m_visualInfo->m_visualType == GrayScale) ||
|
|
(wxTheApp->m_visualInfo->m_visualType == PseudoColor))
|
|
{
|
|
m_hasPixel = XAllocColor( wxGlobalDisplay(), (Colormap) cmap, &m_color );
|
|
int idx = m_color.pixel;
|
|
colMapAllocCounter[ idx ] = colMapAllocCounter[ idx ] + 1;
|
|
}
|
|
else
|
|
#endif
|
|
{
|
|
m_hasPixel = XAllocColor( wxGlobalDisplay(), (Colormap) cmap, &m_color );
|
|
}
|
|
|
|
m_colormap = cmap;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#define M_COLDATA ((wxColourRefData *)m_refData)
|
|
|
|
#define SHIFT (8*(sizeof(short int)-sizeof(char)))
|
|
|
|
wxColour::~wxColour()
|
|
{
|
|
}
|
|
|
|
bool wxColour::operator == ( const wxColour& col ) const
|
|
{
|
|
if (m_refData == col.m_refData) return true;
|
|
|
|
if (!m_refData || !col.m_refData) return false;
|
|
|
|
XColor *own = &(((wxColourRefData*)m_refData)->m_color);
|
|
XColor *other = &(((wxColourRefData*)col.m_refData)->m_color);
|
|
|
|
return (own->red == other->red)
|
|
&& (own->green == other->green)
|
|
&& (own->blue == other->blue) ;
|
|
|
|
}
|
|
|
|
wxGDIRefData *wxColour::CreateGDIRefData() const
|
|
{
|
|
return new wxColourRefData;
|
|
}
|
|
|
|
wxGDIRefData *wxColour::CloneGDIRefData(const wxGDIRefData *data) const
|
|
{
|
|
return new wxColourRefData(*(wxColourRefData *)data);
|
|
}
|
|
|
|
void wxColour::InitRGBA(unsigned char red, unsigned char green, unsigned char blue,
|
|
unsigned char WXUNUSED(alpha))
|
|
{
|
|
AllocExclusive();
|
|
|
|
#if wxUSE_NANOX
|
|
M_COLDATA->m_color.red = ((unsigned short)red) ;
|
|
M_COLDATA->m_color.green = ((unsigned short)green) ;
|
|
M_COLDATA->m_color.blue = ((unsigned short)blue) ;
|
|
#else
|
|
M_COLDATA->m_color.red = ((unsigned short)red) << SHIFT;
|
|
M_COLDATA->m_color.green = ((unsigned short)green) << SHIFT;
|
|
M_COLDATA->m_color.blue = ((unsigned short)blue) << SHIFT;
|
|
#endif
|
|
M_COLDATA->m_color.pixel = 0;
|
|
}
|
|
|
|
unsigned char wxColour::Red() const
|
|
{
|
|
wxCHECK_MSG( IsOk(), 0, wxT("invalid colour") );
|
|
|
|
#if wxUSE_NANOX
|
|
return (unsigned char) M_COLDATA->m_color.red ;
|
|
#else
|
|
return (unsigned char)(M_COLDATA->m_color.red >> SHIFT);
|
|
#endif
|
|
}
|
|
|
|
unsigned char wxColour::Green() const
|
|
{
|
|
wxCHECK_MSG( IsOk(), 0, wxT("invalid colour") );
|
|
|
|
#if wxUSE_NANOX
|
|
return (unsigned char) M_COLDATA->m_color.green ;
|
|
#else
|
|
return (unsigned char)(M_COLDATA->m_color.green >> SHIFT);
|
|
#endif
|
|
}
|
|
|
|
unsigned char wxColour::Blue() const
|
|
{
|
|
wxCHECK_MSG( IsOk(), 0, wxT("invalid colour") );
|
|
|
|
#if wxUSE_NANOX
|
|
return (unsigned char) M_COLDATA->m_color.blue ;
|
|
#else
|
|
return (unsigned char)(M_COLDATA->m_color.blue >> SHIFT);
|
|
#endif
|
|
}
|
|
|
|
void wxColour::CalcPixel( WXColormap cmap )
|
|
{
|
|
wxCHECK_RET( IsOk(), wxT("invalid colour") );
|
|
|
|
wxCHECK_RET( cmap, wxT("invalid colormap") );
|
|
|
|
M_COLDATA->AllocColour( cmap );
|
|
}
|
|
|
|
unsigned long wxColour::GetPixel() const
|
|
{
|
|
wxCHECK_MSG( IsOk(), 0, wxT("invalid colour") );
|
|
|
|
return M_COLDATA->m_color.pixel;
|
|
}
|
|
|
|
WXColor *wxColour::GetColor() const
|
|
{
|
|
wxCHECK_MSG( IsOk(), NULL, wxT("invalid colour") );
|
|
|
|
return (WXColor*) &M_COLDATA->m_color;
|
|
}
|
|
|
|
bool wxColour::FromString(const wxString& name)
|
|
{
|
|
Display *dpy = wxGlobalDisplay();
|
|
WXColormap colormap = wxTheApp->GetMainColormap( dpy );
|
|
XColor xcol;
|
|
if ( XParseColor( dpy, (Colormap)colormap, name.mbc_str(), &xcol ) )
|
|
{
|
|
UnRef();
|
|
|
|
m_refData = new wxColourRefData;
|
|
M_COLDATA->m_colormap = colormap;
|
|
M_COLDATA->m_color = xcol;
|
|
return true;
|
|
}
|
|
|
|
return wxColourBase::FromString(name);
|
|
}
|