summaryrefslogtreecommitdiff
path: root/src/fl_arci.cxx
diff options
context:
space:
mode:
authorMatthias Melcher <fltk@matthiasm.com>2016-01-23 21:02:49 +0000
committerMatthias Melcher <fltk@matthiasm.com>2016-01-23 21:02:49 +0000
commit474de78ac17f4bcf205766ea0393059fbf2ace1e (patch)
tree2c87d1bb8f86ca2418459fdc8924f50ae8aeb8ae /src/fl_arci.cxx
parentde12eddb59bea9ba529230d14cccf3dbef5518e4 (diff)
OpenGL arc and pie drawing (Mmmmh, pie!)
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3-porting@11036 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
Diffstat (limited to 'src/fl_arci.cxx')
-rw-r--r--src/fl_arci.cxx115
1 files changed, 30 insertions, 85 deletions
diff --git a/src/fl_arci.cxx b/src/fl_arci.cxx
index 90ec5010d..7cc3c0690 100644
--- a/src/fl_arci.cxx
+++ b/src/fl_arci.cxx
@@ -32,95 +32,40 @@
// 3/10/98: created
#include <FL/fl_draw.H>
-#include <FL/x.H>
-#ifdef WIN32
-# include <FL/math.h>
-#endif
#include <config.h>
+#include "config_lib.h"
+
+// -----------------------------------------------------------------------------
+
+
+#ifdef FL_CFG_GFX_QUARTZ
+
+# include "cfg_gfx/quartz_arci.cxx"
+
+#endif
+
+
+// -----------------------------------------------------------------------------
+
+
+#ifdef FL_CFG_GFX_GDI
+
+# include "cfg_gfx/gdi_arci.cxx"
-void Fl_Graphics_Driver::arc(int x,int y,int w,int h,double a1,double a2) {
- if (w <= 0 || h <= 0) return;
-
-#if defined(USE_X11)
- XDrawArc(fl_display, fl_window, fl_gc, x,y,w-1,h-1, int(a1*64),int((a2-a1)*64));
-#elif defined(WIN32)
- int xa = x+w/2+int(w*cos(a1/180.0*M_PI));
- int ya = y+h/2-int(h*sin(a1/180.0*M_PI));
- int xb = x+w/2+int(w*cos(a2/180.0*M_PI));
- int yb = y+h/2-int(h*sin(a2/180.0*M_PI));
- if (fabs(a1 - a2) < 90) {
- if (xa == xb && ya == yb) SetPixel(fl_gc, xa, ya, fl_RGB());
- else Arc(fl_gc, x, y, x+w, y+h, xa, ya, xb, yb);
- } else Arc(fl_gc, x, y, x+w, y+h, xa, ya, xb, yb);
-#elif defined(__APPLE_QUARTZ__)
- a1 = (-a1)/180.0f*M_PI; a2 = (-a2)/180.0f*M_PI;
- float cx = x + 0.5f*w - 0.5f, cy = y + 0.5f*h - 0.5f;
- CGContextSetShouldAntialias(fl_gc, true);
- if (w!=h) {
- CGContextSaveGState(fl_gc);
- CGContextTranslateCTM(fl_gc, cx, cy);
- CGContextScaleCTM(fl_gc, w-1.0f, h-1.0f);
- CGContextAddArc(fl_gc, 0, 0, 0.5, a1, a2, 1);
- CGContextRestoreGState(fl_gc);
- } else {
- float r = (w+h)*0.25f-0.5f;
- CGContextAddArc(fl_gc, cx, cy, r, a1, a2, 1);
- }
- CGContextStrokePath(fl_gc);
- CGContextSetShouldAntialias(fl_gc, false);
-#elif defined(FL_PORTING)
-# pragma message "FL_PORTING: implement arc drawing"
-#else
-# error unsupported platform
#endif
-}
-
-void Fl_Graphics_Driver::pie(int x,int y,int w,int h,double a1,double a2) {
- if (w <= 0 || h <= 0) return;
-
-#if defined(USE_X11)
- XDrawArc(fl_display, fl_window, fl_gc, x,y,w-1,h-1, int(a1*64),int((a2-a1)*64));
- XFillArc(fl_display, fl_window, fl_gc, x,y,w-1,h-1, int(a1*64),int((a2-a1)*64));
-#elif defined(WIN32)
- if (a1 == a2) return;
- int xa = x+w/2+int(w*cos(a1/180.0*M_PI));
- int ya = y+h/2-int(h*sin(a1/180.0*M_PI));
- int xb = x+w/2+int(w*cos(a2/180.0*M_PI));
- int yb = y+h/2-int(h*sin(a2/180.0*M_PI));
- SelectObject(fl_gc, fl_brush());
- if (fabs(a1 - a2) < 90) {
- if (xa == xb && ya == yb) {
- MoveToEx(fl_gc, x+w/2, y+h/2, 0L);
- LineTo(fl_gc, xa, ya);
- SetPixel(fl_gc, xa, ya, fl_RGB());
- } else Pie(fl_gc, x, y, x+w, y+h, xa, ya, xb, yb);
- } else Pie(fl_gc, x, y, x+w, y+h, xa, ya, xb, yb);
-#elif defined(__APPLE_QUARTZ__)
- a1 = (-a1)/180.0f*M_PI; a2 = (-a2)/180.0f*M_PI;
- float cx = x + 0.5f*w - 0.5f, cy = y + 0.5f*h - 0.5f;
- CGContextSetShouldAntialias(fl_gc, true);
- if (w!=h) {
- CGContextSaveGState(fl_gc);
- CGContextTranslateCTM(fl_gc, cx, cy);
- CGContextScaleCTM(fl_gc, w, h);
- CGContextAddArc(fl_gc, 0, 0, 0.5, a1, a2, 1);
- CGContextAddLineToPoint(fl_gc, 0, 0);
- CGContextClosePath(fl_gc);
- CGContextRestoreGState(fl_gc);
- } else {
- float r = (w+h)*0.25f;
- CGContextAddArc(fl_gc, cx, cy, r, a1, a2, 1);
- CGContextAddLineToPoint(fl_gc, cx, cy);
- CGContextClosePath(fl_gc);
- }
- CGContextFillPath(fl_gc);
- CGContextSetShouldAntialias(fl_gc, false);
-#elif defined(FL_PORTING)
-# pragma message "FL_PORTING: implement pie drawing (mmmh, apple pie)"
-#else
-# error unsupported platform
+
+
+// -----------------------------------------------------------------------------
+
+
+#ifdef FL_CFG_GFX_XLIB
+
+# include "cfg_gfx/xlib_arci.cxx"
+
#endif
-}
+
+
+// -----------------------------------------------------------------------------
//
// End of "$Id$".