X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d3c7fc996a73e9f6a83067bc28a3c5581a3fee65..cd7d36c065d638f48cff0845a43e35b9ed1e25f6:/include/wx/mac/carbon/dc.h?ds=sidebyside diff --git a/include/wx/mac/carbon/dc.h b/include/wx/mac/carbon/dc.h index b3217d919f..c0e60d151d 100644 --- a/include/wx/mac/carbon/dc.h +++ b/include/wx/mac/carbon/dc.h @@ -36,6 +36,12 @@ class wxMacPortStateHelper; +#if wxUSE_GRAPHICS_CONTEXT + +#include "wx/graphics.h" + +#else + class WXDLLEXPORT wxGraphicPath { public : @@ -48,8 +54,13 @@ public : virtual void AddQuadCurveToPoint( wxCoord cx1, wxCoord cy1, wxCoord x1, wxCoord y1 ) = 0; virtual void AddRectangle( wxCoord x, wxCoord y, wxCoord w, wxCoord h ) = 0; - + virtual void AddCircle( wxCoord x, wxCoord y, wxCoord r ) = 0; + + // draws a an arc to two tangents connecting (current) to (x1,y1) and (x1,y1) to (x2,y2), also a straight line from (current) to (x1,y1) + virtual void AddArcToPoint( wxCoord x1, wxCoord y1 , wxCoord x2, wxCoord y2, wxCoord r ) = 0 ; + + virtual void AddArc( wxCoord x, wxCoord y, wxCoord r, double startAngle, double endAngle, bool clockwise ) = 0 ; virtual void CloseSubpath() = 0; }; @@ -59,19 +70,42 @@ class WXDLLEXPORT wxGraphicContext public: virtual ~wxGraphicContext() {} + virtual wxGraphicPath * CreatePath() = 0; + + virtual void PushState() = 0 ; + + virtual void PopState() = 0 ; + virtual void Clip( const wxRegion ®ion ) = 0; + virtual void SetPen( const wxPen &pen ) = 0; + + virtual void SetBrush( const wxBrush &brush ) = 0; + + virtual void SetFont( const wxFont &font ) = 0 ; + + virtual void SetTextColor( const wxColour &col ) = 0 ; + virtual void StrokePath( const wxGraphicPath *path ) = 0; virtual void DrawPath( const wxGraphicPath *path, int fillStyle = wxWINDING_RULE ) = 0; virtual void FillPath( const wxGraphicPath *path, const wxColor &fillColor, int fillStyle = wxWINDING_RULE ) = 0; - virtual void SetPen( const wxPen &pen ) = 0; - - virtual void SetBrush( const wxBrush &brush ) = 0; - - virtual wxGraphicPath * CreatePath() = 0; + virtual void DrawBitmap( const wxBitmap &bmp, wxCoord x, wxCoord y, wxCoord w, wxCoord h ) = 0 ; + + virtual void DrawIcon( const wxIcon &icon, wxCoord x, wxCoord y, wxCoord w, wxCoord h ) = 0 ; + + virtual void DrawText( const wxString &str, wxCoord x, wxCoord y, double angle ) = 0 ; + + virtual void GetTextExtent( const wxString &text, wxCoord *width, wxCoord *height, + wxCoord *descent, wxCoord *externalLeading ) const = 0 ; + + virtual void GetPartialTextExtents(const wxString& text, wxArrayInt& widths) const = 0 ; + + virtual void Translate( wxCoord dx , wxCoord dy ) = 0 ; + + virtual void Scale( wxCoord xScale , wxCoord yScale ) = 0 ; }; class WXDLLEXPORT wxDC: public wxDCBase @@ -315,7 +349,6 @@ public: #if wxMAC_USE_CORE_GRAPHICS wxGraphicContext *m_graphicContext; - wxPoint m_macLocalOriginInPort; #else void MacInstallPen() const; void MacInstallBrush() const; @@ -339,4 +372,6 @@ public: #endif }; +#endif + #endif // _WX_DC_H_