]> Shamusworld >> Repos - architektonas/blob - src/base/rs_dimradial.h
Changed RS_Graphic to Drawing; this is less confusing as a drawing is
[architektonas] / src / base / rs_dimradial.h
1 #ifndef RS_DIMRADIAL_H
2 #define RS_DIMRADIAL_H
3
4 #include "rs_dimension.h"
5
6 /**
7  * Holds the data that defines a radial dimension entity.
8  */
9 class RS_DimRadialData
10 {
11 public:
12     /**
13      * Default constructor. Leaves the data object uninitialized.
14      */
15     RS_DimRadialData() {}
16
17     /**
18      * Constructor with initialisation.
19      *
20      * @param definitionPoint Definition point of the radial dimension.
21      * @param leader Leader length.
22      */
23     RS_DimRadialData(const Vector& definitionPoint,
24                      double leader) {
25         this->definitionPoint = definitionPoint;
26         this->leader = leader;
27     }
28
29     friend class RS_DimRadial;
30     //friend class RS_ActionDimRadial;
31
32     friend std::ostream& operator << (std::ostream& os,
33                                       const RS_DimRadialData& dd) {
34         os << "(" << dd.definitionPoint << "/" << dd.leader << ")";
35         return os;
36     }
37
38 public:
39     /** Definition point. */
40     Vector definitionPoint;
41     /** Leader length. */
42     double leader;
43 };
44
45 /**
46  * Class for radial dimension entities.
47  *
48  * @author Andrew Mustun
49  */
50 class RS_DimRadial: public RS_Dimension
51 {
52         public:
53                 RS_DimRadial(RS_EntityContainer * parent, const RS_DimensionData & d, const RS_DimRadialData & ed);
54                 virtual ~RS_DimRadial();
55
56                 virtual RS_Entity * clone();
57                 virtual RS2::EntityType rtti() const;
58                 RS_DimRadialData getEData() const;
59                 virtual VectorSolutions getRefPoints();
60                 virtual QString getMeasuredLabel();
61                 virtual void update(bool autoText = false);
62                 Vector getDefinitionPoint();
63                 double getLeader();
64                 virtual void move(Vector offset);
65                 virtual void rotate(Vector center, double angle);
66                 virtual void scale(Vector center, Vector factor);
67                 virtual void mirror(Vector axisPoint1, Vector axisPoint2);
68                 virtual void moveRef(const Vector& ref, const Vector& offset);
69
70                 friend std::ostream& operator << (std::ostream& os, const RS_DimRadial& d);
71
72         protected:
73                 /** Extended data. */
74                 RS_DimRadialData edata;
75 };
76
77 #endif