X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/276a125640f6b921a475284bdba4391c19b25aac..eb537cfb1cc0066c0d53a2415972afa6e303c4b5:/src/cocoa/dc.mm diff --git a/src/cocoa/dc.mm b/src/cocoa/dc.mm index 8ba136926e..44762feba2 100644 --- a/src/cocoa/dc.mm +++ b/src/cocoa/dc.mm @@ -9,8 +9,11 @@ // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// -#include "wx/dc.h" -#include "wx/log.h" +#include "wx/wxprec.h" +#ifndef WX_PRECOMP + #include "wx/log.h" + #include "wx/dc.h" +#endif //WX_PRECOMP #include "wx/cocoa/autorelease.h" @@ -33,6 +36,38 @@ WX_NSLayoutManager wxDC::sm_cocoaNSLayoutManager = nil; WX_NSTextContainer wxDC::sm_cocoaNSTextContainer = nil; wxCocoaDCStack wxDC::sm_cocoaDCStack; +inline void CocoaSetPenForNSBezierPath(wxPen &pen, NSBezierPath *bezpath) +{ + [pen.GetNSColor() set]; + const float *pattern; + [bezpath setLineDash:pattern count:pen.GetCocoaLineDash(&pattern) phase:0.0]; + [bezpath setLineWidth:pen.GetWidth()]; + switch(pen.GetJoin()) + { + case wxJOIN_BEVEL: + [bezpath setLineJoinStyle:NSBevelLineJoinStyle]; + break; + case wxJOIN_ROUND: + [bezpath setLineJoinStyle:NSRoundLineJoinStyle]; + break; + case wxJOIN_MITER: + [bezpath setLineJoinStyle:NSMiterLineJoinStyle]; + break; + } + switch(pen.GetCap()) + { + case wxCAP_ROUND: + [bezpath setLineCapStyle:NSRoundLineCapStyle]; + break; + case wxCAP_PROJECTING: + [bezpath setLineCapStyle:NSSquareLineCapStyle]; + break; + case wxCAP_BUTT: + [bezpath setLineCapStyle:NSButtLineCapStyle]; + break; + } +} + void wxDC::CocoaInitializeTextSystem() { wxASSERT_MSG(!sm_cocoaNSTextStorage && !sm_cocoaNSLayoutManager && !sm_cocoaNSTextContainer,"Text system already initalized! BAD PROGRAMMER!"); @@ -106,6 +141,7 @@ wxDC::wxDC(void) { m_cocoaFlipped = false; m_cocoaHeight = 0.0; + m_pen = *wxBLACK_PEN; } wxDC::~wxDC(void) @@ -148,7 +184,7 @@ void wxDC::DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height) { if(!CocoaTakeFocus()) return; NSBezierPath *bezpath = [NSBezierPath bezierPathWithRect:NSMakeRect(x,y,width,height)]; - [m_textForegroundColour.GetNSColor() set]; + CocoaSetPenForNSBezierPath(m_pen,bezpath); [bezpath stroke]; [m_brush.GetNSColor() set]; [bezpath fill]; @@ -161,7 +197,7 @@ void wxDC::DoDrawLine(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2) [bezpath moveToPoint:NSMakePoint(x1,y1)]; [bezpath lineToPoint:NSMakePoint(x2,y2)]; - [m_textForegroundColour.GetNSColor() set]; + CocoaSetPenForNSBezierPath(m_pen,bezpath); [bezpath stroke]; } @@ -374,6 +410,7 @@ void wxDC::DoDrawArc(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2, wxCoord xc, void wxDC::SetPen(const wxPen& pen) { + m_pen = pen; } void wxDC::SetBrush(const wxBrush& brush)