void wxPostScriptDC::Clear()
{
- wxFAIL_MSG( wxT("wxPostScriptDC::Clear not implemented.") );
+ // This should fail silently to avoid unnecessary
+ // asserts
+ // wxFAIL_MSG( wxT("wxPostScriptDC::Clear not implemented.") );
}
bool wxPostScriptDC::DoFloodFill (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), const wxColour &WXUNUSED(col), int WXUNUSED(style))
CalcBoundingBox( x, y );
}
-void wxPostScriptDC::DoDrawPolygon (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset, int WXUNUSED(fillStyle))
+void wxPostScriptDC::DoDrawPolygon (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset, int fillStyle)
{
wxCHECK_RET( m_ok, wxT("invalid postscript dc") );
}
if ( m_pstream )
- fprintf( m_pstream, "fill\n" );
+ fprintf( m_pstream, (fillStyle == wxODDEVEN_RULE ? "eofill\n" : "fill\n"));
}
if (m_pen.GetStyle () != wxTRANSPARENT)
}
}
+void wxPostScriptDC::DoDrawPolyPolygon (int n, int start[], wxPoint points[], wxCoord xoffset, wxCoord yoffset, int fillStyle)
+{
+ wxCHECK_RET( m_ok && m_pstream, wxT("invalid postscript dc") );
+
+ if (n <= 0) return;
+
+ if (m_brush.GetStyle () != wxTRANSPARENT)
+ {
+ SetBrush( m_brush );
+
+ fprintf( m_pstream, "newpath\n" );
+
+ int ofs = 0;
+ for (int i = 0; i < n; ofs += start[i++])
+ {
+ wxCoord xx = LogicalToDeviceX(points[ofs].x + xoffset);
+ wxCoord yy = LogicalToDeviceY(points[ofs].y + yoffset);
+
+ fprintf( m_pstream, "%d %d moveto\n", xx, yy );
+
+ CalcBoundingBox( points[ofs].x + xoffset, points[ofs].y + yoffset );
+
+ for (int j = 1; j < start[i]; j++)
+ {
+ xx = LogicalToDeviceX(points[ofs+j].x + xoffset);
+ yy = LogicalToDeviceY(points[ofs+j].y + yoffset);
+
+ fprintf( m_pstream, "%d %d lineto\n", xx, yy );
+
+ CalcBoundingBox( points[ofs+j].x + xoffset, points[ofs+j].y + yoffset);
+ }
+ }
+ fprintf( m_pstream, (fillStyle == wxODDEVEN_RULE ? "eofill\n" : "fill\n"));
+ }
+
+ if (m_pen.GetStyle () != wxTRANSPARENT)
+ {
+ SetPen( m_pen );
+
+ fprintf( m_pstream, "newpath\n" );
+
+ int ofs = 0;
+ for (int i = 0; i < n; ofs += start[i++])
+ {
+ wxCoord xx = LogicalToDeviceX(points[ofs].x + xoffset);
+ wxCoord yy = LogicalToDeviceY(points[ofs].y + yoffset);
+
+ fprintf( m_pstream, "%d %d moveto\n", xx, yy );
+
+ CalcBoundingBox( points[ofs].x + xoffset, points[ofs].y + yoffset );
+
+ for (int j = 1; j < start[i]; j++)
+ {
+ xx = LogicalToDeviceX(points[ofs+j].x + xoffset);
+ yy = LogicalToDeviceY(points[ofs+j].y + yoffset);
+
+ fprintf( m_pstream, "%d %d lineto\n", xx, yy );
+
+ CalcBoundingBox( points[ofs+j].x + xoffset, points[ofs+j].y + yoffset);
+ }
+ }
+ fprintf( m_pstream, "closepath\n" );
+ fprintf( m_pstream, "stroke\n" );
+ }
+}
+
void wxPostScriptDC::DoDrawLines (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset)
{
wxCHECK_RET( m_ok, wxT("invalid postscript dc") );
{
// Now, a negative radius is interpreted to mean
// 'the proportion of the smallest X or Y dimension'
- double smallest = 0.0;
- if (width < height)
- smallest = width;
- else
- smallest = height;
+ double smallest = width < height ? width : height;
radius = (-radius * smallest);
}
case wxSCRIPT:
{
name = "/ZapfChancery-MediumItalic";
- Style = wxNORMAL;
- Weight = wxNORMAL;
break;
}
case wxSWISS:
static const char *wxCoord_dashed = "[4 8] 2";
static const char *dotted_dashed = "[6 6 2 6] 4";
- const char *psdash = (char *) NULL;
+ const char *psdash;
+
switch (m_pen.GetStyle())
{
case wxDOT: psdash = dotted; break;
CalcBoundingBox( (wxCoord)x1, (wxCoord)y1 );
CalcBoundingBox( (wxCoord)x3, (wxCoord)y3 );
- while ((node = node->GetNext()))
+ node = node->GetNext();
+ while (node)
{
q = (wxPoint *)node->GetData();
CalcBoundingBox( (wxCoord)x1, (wxCoord)y1 );
CalcBoundingBox( (wxCoord)x3, (wxCoord)y3 );
+
+ node = node->GetNext();
}
/*
lastStyle = Style;
lastWeight = Weight;
- const wxChar *name = NULL;
+ const wxChar *name;
switch (Family)
{
case wxSCRIPT:
{
name = wxT("Zapf.afm");
- Style = wxNORMAL;
- Weight = wxNORMAL;
+ break;
}
case wxSWISS:
default: