///////////////////////////////////////////////////////////////////////////// // Name: src/mgl/pen.cpp // Purpose: // Author: Vaclav Slavik // Id: $Id: pen.cpp 43002 2006-11-03 23:34:24Z VZ $ // Copyright: (c) 2001-2002 SciTech Software, Inc. (www.scitechsoft.com) // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" #ifdef __BORLANDC__ #pragma hdrstop #endif #include "wx/pen.h" #ifndef WX_PRECOMP #include "wx/bitmap.h" #include "wx/colour.h" #endif #include "wx/mgl/private.h" //----------------------------------------------------------------------------- // wxPen //----------------------------------------------------------------------------- class wxPenRefData: public wxObjectRefData { public: wxPenRefData(); wxPenRefData(const wxPenRefData& data); bool operator==(const wxPenRefData& data) const { // we intentionally don't compare m_hPen fields here return m_style == data.m_style && m_width == data.m_width && memcmp(&m_pixPattern, &data.m_pixPattern, sizeof(m_pixPattern)) == 0 && m_capStyle == data.m_capStyle && m_joinStyle == data.m_joinStyle && m_colour == data.m_colour && (m_style != wxSTIPPLE || m_stipple.IsSameAs(data.m_stipple)) && (m_style != wxUSER_DASH || (m_dash == data.m_dash && memcmp(m_dash, data.m_dash, m_countDashes*sizeof(wxDash)) == 0)); } int m_width; int m_style; wxColour m_colour; wxBitmap m_stipple; pixpattern24_t m_pixPattern; // not used by wxMGL, but we want to preserve values int m_joinStyle; int m_capStyle; int m_countDashes; wxDash *m_dash; }; wxPenRefData::wxPenRefData() { m_width = 1; m_style = wxSOLID; m_joinStyle = wxJOIN_ROUND; m_capStyle = wxCAP_ROUND; m_dash = (wxDash*) NULL; m_countDashes = 0; int x, y, c; for (y = 0; y < 8; y++) for (x = 0; x < 8; x++) for (c = 0; c < 3; c++) m_pixPattern.p[x][y][c] = 0; } wxPenRefData::wxPenRefData(const wxPenRefData& data) { m_style = data.m_style; m_width = data.m_width; m_joinStyle = data.m_joinStyle; m_capStyle = data.m_capStyle; m_colour = data.m_colour; m_countDashes = data.m_countDashes; m_dash = data.m_dash; m_stipple = data.m_stipple; int x, y, c; for (y = 0; y < 8; y++) for (x = 0; x < 8; x++) for (c = 0; c < 3; c++) m_pixPattern.p[x][y][c] = data.m_pixPattern.p[x][y][c]; } //----------------------------------------------------------------------------- #define M_PENDATA ((wxPenRefData *)m_refData) IMPLEMENT_DYNAMIC_CLASS(wxPen,wxGDIObject) wxPen::wxPen(const wxColour &colour, int width, int style) { m_refData = new wxPenRefData(); M_PENDATA->m_width = width; M_PENDATA->m_style = style; M_PENDATA->m_colour = colour; } wxPen::wxPen(const wxBitmap& stipple, int width) { wxCHECK_RET( stipple.Ok(), _T("invalid bitmap") ); wxCHECK_RET( stipple.GetWidth() == 8 && stipple.GetHeight() == 8, _T("stipple bitmap must be 8x8") ); m_refData = new wxPenRefData(); M_PENDATA->m_width = width; M_PENDATA->m_style = wxSTIPPLE; M_PENDATA->m_stipple = stipple; wxBitmapToPixPattern(stipple, &(M_PENDATA->m_pixPattern), NULL); } bool wxPen::operator == (const wxPen& pen) const { if (m_refData == pen.m_refData) return true; if (!m_refData || !pen.m_refData) return false; return ( *(wxPenRefData*)m_refData == *(wxPenRefData*)pen.m_refData ); } bool wxPen::operator != (const wxPen& pen) const { return m_refData != pen.m_refData; } void wxPen::SetColour(const wxColour &colour) { AllocExclusive(); M_PENDATA->m_colour = colour; } void wxPen::SetDashes(int number_of_dashes, const wxDash *dash) { AllocExclusive(); M_PENDATA->m_countDashes = number_of_dashes; M_PENDATA->m_dash = (wxDash *)dash; /* TODO */ } void wxPen::SetColour(unsigned char red, unsigned char green, unsigned char blue) { AllocExclusive(); M_PENDATA->m_colour.Set(red, green, blue); } void wxPen::SetCap(int capStyle) { AllocExclusive(); M_PENDATA->m_capStyle = capStyle; } void wxPen::SetJoin(int joinStyle) { AllocExclusive(); M_PENDATA->m_joinStyle = joinStyle; } void wxPen::SetStyle(int style) { AllocExclusive(); M_PENDATA->m_style = style; } void wxPen::SetStipple(const wxBitmap& stipple) { wxCHECK_RET( stipple.Ok(), _T("invalid bitmap") ); wxCHECK_RET( stipple.GetWidth() == 8 && stipple.GetHeight() == 8, _T("stipple bitmap must be 8x8") ); AllocExclusive(); M_PENDATA->m_stipple = stipple; wxBitmapToPixPattern(stipple, &(M_PENDATA->m_pixPattern), NULL); } void wxPen::SetWidth(int width) { AllocExclusive(); M_PENDATA->m_width = width; } int wxPen::GetDashes(wxDash **ptr) const { *ptr = (M_PENDATA ? (wxDash*)M_PENDATA->m_dash : (wxDash*) NULL); return (M_PENDATA ? M_PENDATA->m_countDashes : 0); } int wxPen::GetDashCount() const { return (M_PENDATA->m_countDashes); } wxDash* wxPen::GetDash() const { return (wxDash*)M_PENDATA->m_dash; } int wxPen::GetCap() const { wxCHECK_MSG( Ok(), -1, wxT("invalid pen") ); return M_PENDATA->m_capStyle; } int wxPen::GetJoin() const { wxCHECK_MSG( Ok(), -1, wxT("invalid pen") ); return M_PENDATA->m_joinStyle; } int wxPen::GetStyle() const { wxCHECK_MSG( Ok(), -1, wxT("invalid pen") ); return M_PENDATA->m_style; } int wxPen::GetWidth() const { wxCHECK_MSG( Ok(), -1, wxT("invalid pen") ); return M_PENDATA->m_width; } wxColour &wxPen::GetColour() const { wxCHECK_MSG( Ok(), wxNullColour, wxT("invalid pen") ); return M_PENDATA->m_colour; } wxBitmap *wxPen::GetStipple() const { wxCHECK_MSG( Ok(), NULL, wxT("invalid pen") ); return &(M_PENDATA->m_stipple); } void* wxPen::GetPixPattern() const { wxCHECK_MSG( Ok(), NULL, wxT("invalid pen") ); return (void*)&(M_PENDATA->m_pixPattern); } bool wxPen::IsOk() const { return (m_refData != NULL); } wxObjectRefData *wxPen::CreateRefData() const { return new wxPenRefData; } wxObjectRefData *wxPen::CloneRefData(const wxObjectRefData *data) const { return new wxPenRefData(*(wxPenRefData *)data); }