~librecad-dev/librecad/librecad

« back to all changes in this revision

Viewing changes to librecad/src/lib/engine/rs_dimdiametric.h

  • Committer: Scott Howard
  • Date: 2014-02-21 19:07:55 UTC
  • Revision ID: showard@debian.org-20140221190755-csjax9wb146hgdq4
first commit

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** This file is part of the LibreCAD project, a 2D CAD program
 
4
**
 
5
** Copyright (C) 2010 R. van Twisk (librecad@rvt.dds.nl)
 
6
** Copyright (C) 2001-2003 RibbonSoft. All rights reserved.
 
7
**
 
8
**
 
9
** This file may be distributed and/or modified under the terms of the
 
10
** GNU General Public License version 2 as published by the Free Software
 
11
** Foundation and appearing in the file gpl-2.0.txt included in the
 
12
** packaging of this file.
 
13
**
 
14
** This program is distributed in the hope that it will be useful,
 
15
** but WITHOUT ANY WARRANTY; without even the implied warranty of
 
16
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
17
** GNU General Public License for more details.
 
18
**
 
19
** You should have received a copy of the GNU General Public License
 
20
** along with this program; if not, write to the Free Software
 
21
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 
22
**
 
23
** This copyright notice MUST APPEAR in all copies of the script!
 
24
**
 
25
**********************************************************************/
 
26
 
 
27
 
 
28
#ifndef RS_DIMDIAMETER_H
 
29
#define RS_DIMDIAMETER_H
 
30
 
 
31
#include "rs_dimension.h"
 
32
 
 
33
/**
 
34
 * Holds the data that defines a diametric dimension entity.
 
35
 */
 
36
class RS_DimDiametricData {
 
37
public:
 
38
    /**
 
39
         * Default constructor
 
40
     */
 
41
        RS_DimDiametricData():
 
42
                definitionPoint(false),
 
43
                leader(0.0)
 
44
        {}
 
45
 
 
46
    /**
 
47
     * Constructor with initialisation.
 
48
     *
 
49
     * @param definitionPoint Definition point of the diametric dimension.
 
50
     * @param leader Leader length.
 
51
     */
 
52
    RS_DimDiametricData(const RS_Vector& definitionPoint,
 
53
                     double leader) {
 
54
        this->definitionPoint = definitionPoint;
 
55
        this->leader = leader;
 
56
    }
 
57
 
 
58
    friend class RS_DimDiametric;
 
59
    //friend class RS_ActionDimDiametric;
 
60
 
 
61
    friend std::ostream& operator << (std::ostream& os,
 
62
                                      const RS_DimDiametricData& dd) {
 
63
        os << "(" << dd.definitionPoint << "/" << dd.leader << ")";
 
64
        return os;
 
65
    }
 
66
 
 
67
public:
 
68
    /** Definition point. */
 
69
    RS_Vector definitionPoint;
 
70
    /** Leader length. */
 
71
    double leader;
 
72
};
 
73
 
 
74
 
 
75
 
 
76
/**
 
77
 * Class for diametric dimension entities.
 
78
 *
 
79
 * @author Andrew Mustun
 
80
 */
 
81
class RS_DimDiametric : public RS_Dimension {
 
82
public:
 
83
    RS_DimDiametric(RS_EntityContainer* parent,
 
84
                 const RS_DimensionData& d,
 
85
                 const RS_DimDiametricData& ed);
 
86
    virtual ~RS_DimDiametric() {}
 
87
 
 
88
    virtual RS_Entity* clone() {
 
89
        RS_DimDiametric* d = new RS_DimDiametric(*this);
 
90
        d->setOwner(isOwner());
 
91
        d->initId();
 
92
        d->detach();
 
93
        return d;
 
94
    }
 
95
 
 
96
    /** @return RS2::EntityDimDiametric */
 
97
    virtual RS2::EntityType rtti() const {
 
98
        return RS2::EntityDimDiametric;
 
99
    }
 
100
 
 
101
    /**
 
102
     * @return Copy of data that defines the diametric dimension.
 
103
     * @see getData()
 
104
     */
 
105
    RS_DimDiametricData getEData() const {
 
106
        return edata;
 
107
    }
 
108
 
 
109
        virtual RS_VectorSolutions getRefPoints();
 
110
 
 
111
    virtual QString getMeasuredLabel();
 
112
 
 
113
    virtual void updateDim(bool autoText=false);
 
114
 
 
115
    RS_Vector getDefinitionPoint() {
 
116
        return edata.definitionPoint;
 
117
    }
 
118
    double getLeader() {
 
119
        return edata.leader;
 
120
    }
 
121
    virtual void move(const RS_Vector& offset);
 
122
    virtual void rotate(const RS_Vector& center, const double& angle);
 
123
    virtual void rotate(const RS_Vector& center, const RS_Vector& angleVector);
 
124
    virtual void scale(const RS_Vector& center, const RS_Vector& factor);
 
125
    virtual void mirror(const RS_Vector& axisPoint1, const RS_Vector& axisPoint2);
 
126
 
 
127
    virtual void moveRef(const RS_Vector& ref, const RS_Vector& offset);
 
128
 
 
129
    friend std::ostream& operator << (std::ostream& os,
 
130
                                      const RS_DimDiametric& d);
 
131
 
 
132
protected:
 
133
    /** Extended data. */
 
134
    RS_DimDiametricData edata;
 
135
};
 
136
 
 
137
#endif