#include "wx/region.h"
#endif
+#ifdef __WXMAC__
+#include "wx/mac/private.h"
+#endif
//-----------------------------------------------------------------------------
// constants
//-----------------------------------------------------------------------------
m_graphicContext->DrawIcon( icon , x, y, w, h );
}
+bool wxGCDC::StartDoc( const wxString& WXUNUSED(message) )
+{
+ return false;
+}
+
+void wxGCDC::EndDoc()
+{
+}
+
+void wxGCDC::StartPage()
+{
+}
+
+void wxGCDC::EndPage()
+{
+}
+
+void wxGCDC::Flush()
+{
+#ifdef __WXMAC__
+ CGContextFlush( (CGContextRef) m_graphicContext->GetNativeContext() );
+#endif
+}
+
void wxGCDC::DoSetClippingRegion( wxCoord x, wxCoord y, wxCoord w, wxCoord h )
{
wxCHECK_RET( Ok(), wxT("wxGCDC(cg)::DoSetClippingRegion - invalid DC") );
if (region.Empty())
{
- DestroyClippingRegion();
+ //DestroyClippingRegion();
return;
}
// so we must explicitely make sure it only covers the area we want it to draw
int width, height ;
GetSize( &width , &height ) ;
- m_graphicContext->Clip( DeviceToLogicalX(0) , DeviceToLogicalY(0) , width, height );
+ m_graphicContext->Clip( DeviceToLogicalX(0) , DeviceToLogicalY(0) , DeviceToLogicalXRel(width), DeviceToLogicalYRel(height) );
m_graphicContext->SetPen( m_pen );
m_graphicContext->SetBrush( m_brush );
if ( !m_logicalFunctionSupported )
return;
- wxGraphicsPath path = m_graphicContext->CreatePath();
m_graphicContext->PushState();
m_graphicContext->Translate(x+w/2.0,y+h/2.0);
wxDouble factor = ((wxDouble) w) / h;
// since these angles (ea,sa) are measured counter-clockwise, we invert them to
// get clockwise angles
+ if ( m_brush.GetStyle() != wxTRANSPARENT )
+ {
+ wxGraphicsPath path = m_graphicContext->CreatePath();
+ path.MoveToPoint( 0, 0 );
+ path.AddLineToPoint( h / 2.0 * cos(DegToRad(sa)) , h / 2.0 * sin(DegToRad(-sa)) );
+ path.AddLineToPoint( h / 2.0 * cos(DegToRad(ea)) , h / 2.0 * sin(DegToRad(-ea)) );
+ path.AddLineToPoint( 0, 0 );
+ m_graphicContext->FillPath( path );
+
+ path = m_graphicContext->CreatePath();
+ path.AddArc( 0, 0, h/2.0 , DegToRad(-sa) , DegToRad(-ea), sa > ea );
+ m_graphicContext->FillPath( path );
+ m_graphicContext->StrokePath( path );
+ }
+ else
+ {
+ wxGraphicsPath path = m_graphicContext->CreatePath();
path.AddArc( 0, 0, h/2.0 , DegToRad(-sa) , DegToRad(-ea), sa > ea );
m_graphicContext->DrawPath( path );
+ }
+
m_graphicContext->PopState();
}
}
#if wxUSE_SPLINES
-void wxGCDC::DoDrawSpline(wxList *points)
+void wxGCDC::DoDrawSpline(const wxPointList *points)
{
wxCHECK_RET( Ok(), wxT("wxGCDC(cg)::DoDrawSpline - invalid DC") );
wxGraphicsPath path = m_graphicContext->CreatePath();
- wxList::compatibility_iterator node = points->GetFirst();
- if (node == wxList::compatibility_iterator())
+ wxPointList::compatibility_iterator node = points->GetFirst();
+ if (node == wxPointList::compatibility_iterator())
// empty list
return;
- wxPoint *p = (wxPoint *)node->GetData();
+ wxPoint *p = node->GetData();
wxCoord x1 = p->x;
wxCoord y1 = p->y;
node = node->GetNext();
- p = (wxPoint *)node->GetData();
+ p = node->GetData();
wxCoord x2 = p->x;
wxCoord y2 = p->y;
#endif // !wxUSE_STL
{
- p = (wxPoint *)node->GetData();
+ p = node->GetData();
x1 = x2;
y1 = y2;
x2 = p->x;
if ( logical_func == wxNO_OP )
return true;
- else if ( logical_func != wxCOPY )
+ else if ( !m_graphicContext->SetLogicalFunction( logical_func ) )
+
{
wxFAIL_MSG( wxT("Blitting is only supported with wxCOPY logical operation.") );
return false;
return false;
}
+ // reset logical function
+ m_graphicContext->SetLogicalFunction( m_logicalFunction );
+
return true;
}
m_graphicContext->GetTextExtent( str, &w, &h, &d, &e );
if ( height )
- *height = (wxCoord)h;
+ *height = (wxCoord)(h+0.5);
if ( descent )
- *descent = (wxCoord)d;
+ *descent = (wxCoord)(d+0.5);
if ( externalLeading )
- *externalLeading = (wxCoord)e;
+ *externalLeading = (wxCoord)(e+0.5);
if ( width )
- *width = (wxCoord)w;
+ *width = (wxCoord)(w+0.5);
if ( theFont )
{
void wxGCDC::DoGetSize(int *width, int *height) const
{
- *width = 1000;
- *height = 1000;
+ *width = 10000;
+ *height = 10000;
}
void wxGCDC::DoGradientFillLinear(const wxRect& rect,