X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1de8d512b7c844d67b2dab36addc89868e68c9b6..18caa1e963269d02499b327bb4e7cc2ac48fd67e:/src/os2/pen.cpp?ds=sidebyside diff --git a/src/os2/pen.cpp b/src/os2/pen.cpp index b0523de111..318daf514d 100644 --- a/src/os2/pen.cpp +++ b/src/os2/pen.cpp @@ -12,12 +12,13 @@ // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" +#include "wx/pen.h" + #ifndef WX_PRECOMP #include #include "wx/list.h" #include "wx/utils.h" #include "wx/app.h" - #include "wx/pen.h" #include "wx/log.h" #endif @@ -192,6 +193,8 @@ bool wxPen::RealizeResource() } m_vLineBundle.lColor = (LONG)vPmColour; m_vLineBundle.usMixMode = FM_OVERPAINT; + if (M_PENDATA->m_nWidth < 1) + M_PENDATA->m_nWidth = 1; m_vLineBundle.fxWidth = M_PENDATA->m_nWidth; m_vLineBundle.lGeomWidth = M_PENDATA->m_nWidth; m_vLineBundle.usType = uLineType; @@ -301,7 +304,7 @@ bool wxPen::RealizeResource() return false; } // end of wxPen::RealizeResource -WXHANDLE wxPen::GetResourceHandle() +WXHANDLE wxPen::GetResourceHandle() const { if (!M_PENDATA) return 0; @@ -324,38 +327,33 @@ bool wxPen::IsFree() const return (M_PENDATA && M_PENDATA->m_hPen == 0); } -void wxPen::Unshare() +wxGDIRefData* wxPen::CreateGDIRefData() const { - // Don't change shared data - if (!m_refData) - { - m_refData = new wxPenRefData(); - } - else - { - wxPenRefData* ref = new wxPenRefData(*(wxPenRefData*)m_refData); - UnRef(); - m_refData = ref; - } -} // end of wxPen::Unshare + return new wxPenRefData; +} + +wxGDIRefData* wxPen::CloneGDIRefData(const wxGDIRefData* data) const +{ + return new wxPenRefData(*wx_static_cast(const wxPenRefData*, data)); +} void wxPen::SetColour( const wxColour& rColour ) { - Unshare(); + AllocExclusive(); M_PENDATA->m_vColour = rColour; RealizeResource(); } // end of wxPen::SetColour void wxPen::SetColour( unsigned char cRed, unsigned char cGreen, unsigned char cBlue) { - Unshare(); + AllocExclusive(); M_PENDATA->m_vColour.Set(cRed, cGreen, cBlue); RealizeResource(); } // end of wxPen::SetColour void wxPen::SetPS( HPS hPS ) { - Unshare(); + AllocExclusive(); if (M_PENDATA->m_hPen) ::GpiDestroyPS(M_PENDATA->m_hPen); M_PENDATA->m_hPen = hPS; @@ -366,7 +364,7 @@ void wxPen::SetWidth( int nWidth ) { - Unshare(); + AllocExclusive(); M_PENDATA->m_nWidth = nWidth; RealizeResource(); } // end of wxPen::SetWidth @@ -375,7 +373,7 @@ void wxPen::SetStyle( int nStyle ) { - Unshare(); + AllocExclusive(); M_PENDATA->m_nStyle = nStyle; RealizeResource(); } // end of wxPen::SetStyle @@ -384,7 +382,7 @@ void wxPen::SetStipple( const wxBitmap& rStipple ) { - Unshare(); + AllocExclusive(); M_PENDATA->m_vStipple = rStipple; M_PENDATA->m_nStyle = wxSTIPPLE; RealizeResource(); @@ -402,7 +400,7 @@ void wxPen::SetJoin( int nJoin ) { - Unshare(); + AllocExclusive(); M_PENDATA->m_nJoin = nJoin; RealizeResource(); } // end of wxPen::SetJoin @@ -411,7 +409,7 @@ void wxPen::SetCap( int nCap ) { - Unshare(); + AllocExclusive(); M_PENDATA->m_nCap = nCap; RealizeResource(); } // end of wxPen::SetCap