~librecad-dev/librecad/librecad

« back to all changes in this revision

Viewing changes to librecad/src/lib/engine/rs_point.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_POINT_H
 
29
#define RS_POINT_H
 
30
 
 
31
#include "rs_atomicentity.h"
 
32
 
 
33
 
 
34
 
 
35
/**
 
36
 * Holds the data that defines a point.
 
37
 */
 
38
class RS_PointData {
 
39
public:
 
40
    RS_PointData(const RS_Vector& pos) {
 
41
        this->pos = pos;
 
42
    }
 
43
 
 
44
    friend std::ostream& operator << (std::ostream& os, const RS_PointData& pd) {
 
45
        os << "(" << pd.pos << ")";
 
46
        return os;
 
47
    }
 
48
 
 
49
    RS_Vector pos;
 
50
};
 
51
 
 
52
 
 
53
 
 
54
/**
 
55
 * Class for a point entity.
 
56
 *
 
57
 * @author Andrew Mustun
 
58
 */
 
59
class RS_Point : public RS_AtomicEntity {
 
60
public:
 
61
    RS_Point(RS_EntityContainer* parent,
 
62
             const RS_PointData& d);
 
63
 
 
64
    virtual RS_Entity* clone() {
 
65
        RS_Point* p = new RS_Point(*this);
 
66
        p->initId();
 
67
        return p;
 
68
    }
 
69
 
 
70
    /** @return RS_ENTITY_POINT */
 
71
    virtual RS2::EntityType rtti() const {
 
72
        return RS2::EntityPoint;
 
73
    }
 
74
 
 
75
    /**
 
76
         * @return Start point of the entity.
 
77
         */
 
78
    virtual RS_Vector getStartpoint() const {
 
79
        return data.pos;
 
80
    }
 
81
    /**
 
82
         * @return End point of the entity.
 
83
         */
 
84
    virtual RS_Vector getEndpoint() const {
 
85
        return data.pos;
 
86
    }
 
87
 
 
88
        virtual void moveStartpoint(const RS_Vector& pos);
 
89
 
 
90
    /** @return Copy of data that defines the point. */
 
91
    RS_PointData getData() const {
 
92
        return data;
 
93
    }
 
94
 
 
95
    virtual RS_VectorSolutions getRefPoints();
 
96
 
 
97
    /** @return Position of the point */
 
98
    RS_Vector getPos() {
 
99
        return data.pos;
 
100
    }
 
101
 
 
102
    /** Sets a new position for this point. */
 
103
    void setPos(const RS_Vector& pos) {
 
104
        data.pos = pos;
 
105
    }
 
106
 
 
107
    virtual RS_Vector getMiddlePoint(void)const;
 
108
    virtual RS_Vector getNearestEndpoint(const RS_Vector& coord,
 
109
                                         double* dist = NULL)const;
 
110
    virtual RS_Vector getNearestPointOnEntity(const RS_Vector& coord,
 
111
            bool onEntity = true, double* dist = NULL, RS_Entity** entity = NULL)const;
 
112
    virtual RS_Vector getNearestCenter(const RS_Vector& coord,
 
113
                                       double* dist = NULL);
 
114
    virtual RS_Vector getNearestMiddle(const RS_Vector& coord,
 
115
                                       double* dist = NULL,
 
116
                                       int middlePoints = 1)const;
 
117
    virtual RS_Vector getNearestDist(double distance,
 
118
                                     const RS_Vector& coord,
 
119
                                     double* dist = NULL);
 
120
    virtual double getDistanceToPoint(const RS_Vector& coord,
 
121
                                      RS_Entity** entity=NULL,
 
122
                                      RS2::ResolveLevel level=RS2::ResolveNone,
 
123
                                                                          double solidDist = RS_MAXDOUBLE)const;
 
124
 
 
125
    virtual void move(const RS_Vector& offset);
 
126
    virtual void rotate(const RS_Vector& center, const double& angle);
 
127
    virtual void rotate(const RS_Vector& center, const RS_Vector& angleVector);
 
128
    virtual void scale(const RS_Vector& center, const RS_Vector& factor);
 
129
    virtual void mirror(const RS_Vector& axisPoint1, const RS_Vector& axisPoint2);
 
130
 
 
131
    virtual void draw(RS_Painter* painter, RS_GraphicView* view, double& patternOffset);
 
132
 
 
133
    friend std::ostream& operator << (std::ostream& os, const RS_Point& p);
 
134
 
 
135
    /** Recalculates the borders of this entity. */
 
136
    virtual void calculateBorders ();
 
137
 
 
138
protected:
 
139
    RS_PointData data;
 
140
    //RS_Vector point;
 
141
}
 
142
;
 
143
 
 
144
#endif