1 //----------------------------------------------------------------------------
2 // Anti-Grain Geometry - Version 2.3
3 // Copyright (C) 2002-2005 Maxim Shemanarev (http://www.antigrain.com)
5 // Permission to copy, use, modify, sell and distribute this software
6 // is granted provided this copyright notice appears in all copies.
7 // This software is provided "as is" without express or implied
8 // warranty, and with no claim as to its suitability for any purpose.
10 //----------------------------------------------------------------------------
11 // Contact: mcseem@antigrain.com
12 // mcseemagg@yahoo.com
13 // http://www.antigrain.com
14 //----------------------------------------------------------------------------
16 #ifndef AGG_VPGEN_CLIP_POLYLINE_INCLUDED
17 #define AGG_VPGEN_CLIP_POLYLINE_INCLUDED
19 #include "agg_basics.h"
24 //======================================================vpgen_clip_polyline
26 // See Implementation agg_vpgen_clip_polyline.cpp
28 class vpgen_clip_polyline
31 vpgen_clip_polyline() :
32 m_clip_box(0, 0, 1, 1),
44 void clip_box(double _x1
, double _y1
, double _x2
, double _y2
)
50 m_clip_box
.normalize();
54 double x1() const { return m_clip_box
.x1
; }
55 double y1() const { return m_clip_box
.y1
; }
56 double x2() const { return m_clip_box
.x2
; }
57 double y2() const { return m_clip_box
.y2
; }
59 static bool auto_close() { return false; }
60 static bool auto_unclose() { return true; }
63 void move_to(double x
, double y
);
64 void line_to(double x
, double y
);
65 unsigned vertex(double* x
, double* y
);
68 enum clipping_flags_def
76 // Determine the clipping code of the vertex according to the
77 // Cyrus-Beck line clipping algorithm
78 //--------------------------------------------------------------------
79 unsigned clipping_flags_x(double x
)
82 if(x
< m_clip_box
.x1
) f
|= clip_x1
;
83 if(x
> m_clip_box
.x2
) f
|= clip_x2
;
87 unsigned clipping_flags_y(double y
)
90 if(y
< m_clip_box
.y1
) f
|= clip_y1
;
91 if(y
> m_clip_box
.y2
) f
|= clip_y2
;
95 unsigned clipping_flags(double x
, double y
)
97 return clipping_flags_x(x
) | clipping_flags_y(y
);
100 bool move_point(double& x
, double& y
, unsigned& flags
);
101 void clip_line_segment();
114 unsigned m_num_vertices
;