33#include "hurricane/Component.h"
34#include "hurricane/Polygons.h"
42 class Polygon :
public Component {
46 static FastRTTI _fastRTTI;
48 static inline const FastRTTI& fastRTTI ();
49 virtual const FastRTTI& vfastRTTI ()
const;
51 static const uint32_t Above = (1<<0);
52 static const uint32_t YSteps = (1<<1);
53 static const uint32_t XSteps = (1<<2);
54 static const uint32_t XIncrease = (1<<3);
55 static const uint32_t YIncrease = (1<<4);
56 static const uint32_t Horizontal = (1<<5);
57 static const uint32_t Vertical = (1<<6);
58 static const uint32_t Convex = (1<<7);
59 static const uint32_t Polygon45 = (1<<8);
64 Edge (
Point origin,
Point extremity, uint32_t flags );
65 inline size_t getSize ()
const;
66 Point getPoint (
size_t i )
const;
67 inline bool isPositiveSlope ()
const;
68 inline bool isYIncrease ()
const;
69 inline bool isXIncrease ()
const;
70 inline bool isHV ()
const;
71 inline bool isXSteps ()
const;
72 inline bool isYSteps ()
const;
74 string _getTypeName ()
const;
75 string _getString ()
const;
76 Record* _getRecord ()
const;
80 vector<DbU::Unit> _steps;
84 class Points_Manhattan :
public PointHC {
86 class Locator :
public PointHL {
90 virtual Point getElement ()
const;
91 virtual PointHL* getClone ()
const;
92 virtual bool isValid ()
const;
93 virtual void progress ();
94 virtual string _getString ()
const;
101 inline Points_Manhattan (
const Polygon* );
102 inline Points_Manhattan (
const Points_Manhattan& );
103 virtual PointHC* getClone ()
const;
104 virtual PointHL* getLocator ()
const;
105 virtual string _getString ()
const;
107 const Polygon* _polygon;
112 static float getSlope (
const Point&,
const Point& );
113 static void normalize ( std::vector<Point>&, uint32_t& flags );
115 virtual bool isNonRectangle ()
const;
116 virtual bool isManhattanized ()
const;
117 virtual bool isConvex ()
const;
118 virtual bool isPolygon45 ()
const;
121 inline const vector<Point>& getPoints ()
const;
122 inline const vector<Edge*>& getEdges ()
const;
123 virtual size_t getPointsSize ()
const;
124 virtual Point getPoint (
size_t )
const;
125 virtual Box getBoundingBox ()
const;
127 void getSubPolygons ( vector< vector<Point> >& )
const;
128 virtual const Layer* getLayer ()
const;
129 void setLayer (
const Layer* layer );
131 void setPoints (
const vector<Point>& );
132 static float getSign (
const vector<Point>&,
size_t );
133 static bool isEdge45 (
const vector<Point>&,
size_t );
134 float getSlope (
size_t i )
const;
135 void manhattanize ();
136 virtual Points getMContour ()
const;
137 virtual void _toJson ( JsonWriter* )
const;
138 static JsonObject* getJsonObject (
unsigned long flags );
139 virtual string _getTypeName ()
const;
140 virtual string _getString ()
const;
141 virtual Record* _getRecord ()
const;
143 Polygon (
Net*,
const Layer*,
const std::vector<Point>& );
148 std::vector<Point> _points;
149 std::vector<Edge*> _edges;
153 inline const FastRTTI& Polygon::fastRTTI () {
return _fastRTTI; }
155 inline const vector<Polygon::Edge*>& Polygon::getEdges ()
const {
return _edges; }
156 inline const vector<Point>& Polygon::getPoints ()
const {
return _points; }
158 inline bool Polygon::Edge::isYIncrease ()
const {
return (_flags & Polygon::YIncrease); }
159 inline bool Polygon::Edge::isXIncrease ()
const {
return (_flags & Polygon::XIncrease); }
160 inline bool Polygon::Edge::isPositiveSlope ()
const {
return not ( (_flags & Polygon::XIncrease) xor (_flags & Polygon::YIncrease) ); }
161 inline bool Polygon::Edge::isHV ()
const {
return (_flags & (Polygon::Horizontal|Polygon::Vertical)); }
162 inline bool Polygon::Edge::isXSteps ()
const {
return (_flags & Polygon::XSteps); }
163 inline bool Polygon::Edge::isYSteps ()
const {
return (_flags & Polygon::YSteps); }
164 inline size_t Polygon::Edge::getSize ()
const {
if (isHV() or (_steps.size() < 2))
return 1;
return (_steps.size() - 1)*2; }
167 inline Polygon::Points_Manhattan::Locator::Locator (
const Locator &locator )
169 , _polygon(locator._polygon)
170 , _iEdge (locator._iEdge)
171 , _iPoint (locator._iPoint)
175 inline Polygon::Points_Manhattan::Points_Manhattan (
const Polygon* polygon )
181 inline Polygon::Points_Manhattan::Points_Manhattan (
const Points_Manhattan& other )
183 , _polygon(other._polygon)
187 class JsonPolygon :
public JsonComponent {
189 static void initialize ();
190 JsonPolygon (
unsigned long flags );
191 virtual string getTypeName ()
const;
192 virtual JsonPolygon* clone (
unsigned long )
const;
193 virtual void toData ( JsonStack& );
200INSPECTOR_P_SUPPORT(Hurricane::Polygon::Edge);
BasicLayer description (API)
Definition BasicLayer.h:42
Box description (API)
Definition Box.h:30
std::int64_t Unit
Definition DbU.h:67
Support for JSON export.
Definition JsonObject.h:83
Layer description (API)
Definition Layer.h:120
Locator description (API)
Definition Locator.h:33
Net description (API)
Definition Net.h:46
Point description (API)
Definition Point.h:30
Polygon description (API)
Definition Polygon.h:42
static Polygon * create(Net *, const Layer *, const std::vector< Point > &)
Component Super
Definition Polygon.h:44
Contains Almost Everything.
Definition BasicLayer.h:39