+ wxCoord rad = (wxCoord) radius;
+
+ if (m_brush.GetStyle() != wxTRANSPARENT)
+ {
+ SetBrush(m_brush);
+ gs_lgp->gnome_print_newpath(m_gpc);
+ gs_lgp->gnome_print_moveto(m_gpc,XLOG2DEV(x + rad),YLOG2DEV(y));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x + rad),YLOG2DEV(y),
+ XLOG2DEV(x),YLOG2DEV(y),
+ XLOG2DEV(x),YLOG2DEV(y + rad));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x),YLOG2DEV(y + height - rad));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x),YLOG2DEV(y + height - rad),
+ XLOG2DEV(x),YLOG2DEV(y + height),
+ XLOG2DEV(x + rad),YLOG2DEV(y + height));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x + width - rad),YLOG2DEV(y + height));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x + width - rad),YLOG2DEV(y + height),
+ XLOG2DEV(x + width),YLOG2DEV(y + height),
+ XLOG2DEV(x + width),YLOG2DEV(y + height - rad));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x + width),YLOG2DEV(y + rad));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x + width),YLOG2DEV(y + rad),
+ XLOG2DEV(x + width),YLOG2DEV(y),
+ XLOG2DEV(x + width - rad),YLOG2DEV(y));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x + rad),YLOG2DEV(y));
+ gs_lgp->gnome_print_closepath(m_gpc);
+ gs_lgp->gnome_print_fill(m_gpc);
+
+ CalcBoundingBox(x,y);
+ CalcBoundingBox(x+width,y+height);
+ }
+
+ if (m_pen.GetStyle() != wxTRANSPARENT)
+ {
+ SetPen(m_pen);
+ gs_lgp->gnome_print_newpath(m_gpc);
+ gs_lgp->gnome_print_moveto(m_gpc,XLOG2DEV(x + rad),YLOG2DEV(y));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x + rad),YLOG2DEV(y),
+ XLOG2DEV(x),YLOG2DEV(y),
+ XLOG2DEV(x),YLOG2DEV(y + rad));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x),YLOG2DEV(y + height - rad));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x),YLOG2DEV(y + height - rad),
+ XLOG2DEV(x),YLOG2DEV(y + height),
+ XLOG2DEV(x + rad),YLOG2DEV(y + height));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x + width - rad),YLOG2DEV(y + height));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x + width - rad),YLOG2DEV(y + height),
+ XLOG2DEV(x + width),YLOG2DEV(y + height),
+ XLOG2DEV(x + width),YLOG2DEV(y + height - rad));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x + width),YLOG2DEV(y + rad));
+ gs_lgp->gnome_print_curveto(m_gpc,
+ XLOG2DEV(x + width),YLOG2DEV(y + rad),
+ XLOG2DEV(x + width),YLOG2DEV(y),
+ XLOG2DEV(x + width - rad),YLOG2DEV(y));
+ gs_lgp->gnome_print_lineto(m_gpc,XLOG2DEV(x + rad),YLOG2DEV(y));
+ gs_lgp->gnome_print_closepath(m_gpc);
+ gs_lgp->gnome_print_stroke(m_gpc);
+
+ CalcBoundingBox(x,y);
+ CalcBoundingBox(x+width,y+height);
+ }
+}
+
+void wxGnomePrintDC::makeEllipticalPath(wxCoord x, wxCoord y,
+ wxCoord width, wxCoord height)
+{
+ double r = 4 * (sqrt(2.) - 1) / 3;
+ double halfW = 0.5 * width,
+ halfH = 0.5 * height,
+ halfWR = r * halfW,
+ halfHR = r * halfH;
+ wxCoord halfWI = (wxCoord) halfW,
+ halfHI = (wxCoord) halfH;
+
+ gs_lgp->gnome_print_newpath( m_gpc );
+
+ // Approximate an ellipse using four cubic splines, clockwise from 0 deg */
+ gs_lgp->gnome_print_moveto( m_gpc,
+ XLOG2DEV(x + width),
+ YLOG2DEV(y + halfHI) );
+ gs_lgp->gnome_print_curveto( m_gpc,
+ XLOG2DEV(x + width),
+ YLOG2DEV(y + (wxCoord) rint (halfH + halfHR)),
+ XLOG2DEV(x + (wxCoord) rint(halfW + halfWR)),
+ YLOG2DEV(y + height),
+ XLOG2DEV(x + halfWI),
+ YLOG2DEV(y + height) );
+ gs_lgp->gnome_print_curveto( m_gpc,
+ XLOG2DEV(x + (wxCoord) rint(halfW - halfWR)),
+ YLOG2DEV(y + height),
+ XLOG2DEV(x),
+ YLOG2DEV(y + (wxCoord) rint (halfH + halfHR)),
+ XLOG2DEV(x), YLOG2DEV(y+halfHI) );
+ gs_lgp->gnome_print_curveto( m_gpc,
+ XLOG2DEV(x),
+ YLOG2DEV(y + (wxCoord) rint (halfH - halfHR)),
+ XLOG2DEV(x + (wxCoord) rint (halfW - halfWR)),
+ YLOG2DEV(y),
+ XLOG2DEV(x+halfWI), YLOG2DEV(y) );
+ gs_lgp->gnome_print_curveto( m_gpc,
+ XLOG2DEV(x + (wxCoord) rint(halfW + halfWR)),
+ YLOG2DEV(y),
+ XLOG2DEV(x + width),
+ YLOG2DEV(y + (wxCoord) rint(halfH - halfHR)),
+ XLOG2DEV(x + width), YLOG2DEV(y + halfHI) );
+
+ gs_lgp->gnome_print_closepath(m_gpc);