QCAD
Open Source 2D CAD
Loading...
Searching...
No Matches
RXLine.h
Go to the documentation of this file.
1
20#ifndef RXLINE_H
21#define RXLINE_H
22
23#include "../core_global.h"
24
25#include "RLine.h"
26#include "RS.h"
27#include "RShape.h"
28#include "RVector.h"
29
30class RBox;
31class RPolyline;
32
43public:
44 RXLine();
45 RXLine(const RLine& line);
46 RXLine(const RVector& basePoint, const RVector& directionVector);
47 RXLine(const RVector& basePoint, double angle, double distance);
48 virtual ~RXLine();
49
50 virtual RShape::Type getShapeType() const {
51 return XLine;
52 }
53
55 return RLine(basePoint, basePoint + directionVector);
56 }
57
58 virtual QSharedPointer<RShape> clone() const {
59 return QSharedPointer<RShape>(new RXLine(*this));
60 }
61
62 QSharedPointer<RXLine> cloneToXLine() const {
63 return QSharedPointer<RXLine>(new RXLine(*this));
64 }
65
66 virtual bool isDirected() const {
67 return true;
68 }
69
70 RBox getBoundingBox() const;
71
72 virtual void setZ(double z);
73
74 virtual QList<RVector> getVectorProperties() const;
75
76 virtual QList<RVector> getEndPoints() const;
77 virtual QList<RVector> getMiddlePoints() const;
78 virtual QList<RVector> getCenterPoints() const;
79 virtual QList<RVector> getPointsWithDistanceToEnd(
80 double distance, int from = RS::FromAny) const;
81 virtual QList<RVector> getPointCloud(double segmentLength) const;
82
83 virtual double getAngleAt(double distance, RS::From from = RS::FromStart) const;
84
85 virtual RVector getVectorTo(const RVector& point, bool limited = true, double strictRange = RMAXDOUBLE) const;
86
87 RVector getBasePoint() const;
88 void setBasePoint(const RVector& vector);
89 RVector getSecondPoint() const;
90 void setSecondPoint(const RVector& vector);
91 RVector getDirectionVector() const;
92 void setDirectionVector(const RVector& vector);
93
94 virtual RVector getMiddlePoint() const;
95
96 double getLength() const;
97 void setLength(double l);
98 double getAngle() const;
99 void setAngle(double a);
100
101 virtual double getDirection1() const;
102 virtual double getDirection2() const;
103
104 virtual RS::Side getSideOfPoint(const RVector& point) const;
105
106 virtual RVector getStartPoint() const;
107 virtual RVector getEndPoint() const;
108
109 virtual bool trimStartPoint(const RVector& trimPoint, const RVector& clickPoint = RVector::invalid, bool extend = false);
110 virtual bool trimEndPoint(const RVector& trimPoint, const RVector& clickPoint = RVector::invalid, bool extend = false);
111 virtual bool trimStartPoint(double trimDist) {
112 return RShape::trimStartPoint(trimDist);
113 }
114 virtual bool trimEndPoint(double trimDist) {
115 return RShape::trimEndPoint(trimDist);
116 }
117 virtual RS::Ending getTrimEnd(const RVector& trimPoint, const RVector& clickPoint);
118 virtual double getDistanceFromStart(const RVector& p) const;
119
120 virtual RLine getClippedLine(const RBox& box) const;
121
122 virtual bool move(const RVector& offset);
123 virtual bool rotate(double rotation, const RVector& center = RDEFAULT_RVECTOR);
124 virtual bool scale(const RVector& scaleFactors, const RVector& center = RDEFAULT_RVECTOR);
125 virtual bool mirror(const RLine& axis);
126 virtual bool reverse();
127 virtual bool stretch(const RPolyline& area, const RVector& offset);
128
129 virtual QSharedPointer<RShape> getTransformed(const QTransform& transform) const;
130
131 virtual QList<QSharedPointer<RShape> > getOffsetShapes(double distance, int number, RS::Side side, const RVector& position = RVector::invalid) {
132 return RShape::getOffsetLines(*this, distance, number, side, position);
133 }
134
135 virtual QList<QSharedPointer<RShape> > splitAt(const QList<RVector>& points) const;
136
137#if QT_VERSION >= 0x060000
142 RXLine copy() const {
143 return *this;
144 }
145#endif
146
147protected:
148 virtual void print(QDebug dbg) const;
149
150public:
161};
162
166Q_DECLARE_METATYPE(QSharedPointer<RXLine>)
167Q_DECLARE_METATYPE(QSharedPointer<RXLine>*)
168
169#endif
Q_DECLARE_METATYPE(RMath *)
#define RMAXDOUBLE
Definition RMath.h:66
#define RDEFAULT_RVECTOR
Definition RVector.h:38
Represents a box e.g.
Definition RBox.h:46
Low-level mathematical representation of a line.
Definition RLine.h:41
Low-level mathematical representation of an open polyline or closed polyline (= polygon).
Definition RPolyline.h:50
From
End used to specify from which end of a shape to measure a distance.
Definition RS.h:371
@ FromStart
Definition RS.h:372
@ FromAny
Start or end.
Definition RS.h:374
Side
Side used for side of a point relative to an entity (right hand or left hand side)
Definition RS.h:313
Ending
Entity ending.
Definition RS.h:323
Interface for geometrical shape classes.
Definition RShape.h:72
virtual double getDistanceFromStart(const RVector &p) const
Definition RShape.h:356
virtual RVector getVectorTo(const RVector &point, bool limited=true, double strictRange=RMAXDOUBLE) const =0
virtual QList< RVector > getPointCloud(double segmentLength) const =0
virtual bool trimStartPoint(const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
Definition RShape.h:309
virtual RVector getStartPoint() const
Definition RShape.h:289
virtual bool stretch(const RBox &area, const RVector &offset)
Definition RShape.cpp:1741
virtual QList< RVector > getPointsWithDistanceToEnd(double distance, int from=RS::FromAny) const =0
virtual RVector getEndPoint() const
Definition RShape.h:292
virtual bool trimEndPoint(const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
Definition RShape.h:328
Type
Definition RShape.h:74
@ XLine
Definition RShape.h:84
virtual QList< RVector > getCenterPoints() const =0
virtual bool move(const RVector &offset)=0
virtual double getAngleAt(double distance, RS::From from=RS::FromStart) const
Definition RShape.h:249
virtual bool rotate(double rotation, const RVector &center=RDEFAULT_RVECTOR)=0
virtual void print(QDebug dbg) const
Definition RShape.cpp:1760
virtual QList< QSharedPointer< RShape > > splitAt(const QList< RVector > &points) const
Definition RShape.cpp:2234
virtual bool mirror(const RLine &axis)=0
virtual double getDirection1() const
Definition RShape.h:277
virtual QList< RVector > getEndPoints() const =0
virtual RVector getMiddlePoint() const
Definition RShape.h:295
virtual double getDirection2() const
Definition RShape.h:280
virtual RS::Side getSideOfPoint(const RVector &point) const
Definition RShape.h:284
virtual QList< RVector > getVectorProperties() const
Definition RShape.h:170
static QList< QSharedPointer< RShape > > getOffsetLines(const RShape &shape, double distance, int number, RS::Side side, const RVector &position=RVector::invalid)
Definition RShape.cpp:2070
virtual QList< RVector > getMiddlePoints() const =0
virtual bool reverse()
Definition RShape.h:299
virtual void setZ(double z)=0
virtual QSharedPointer< RShape > getTransformed(const QTransform &transform) const =0
virtual RBox getBoundingBox() const =0
virtual RS::Ending getTrimEnd(const RVector &trimPoint, const RVector &clickPoint)
Definition RShape.h:345
virtual bool scale(double scaleFactor, const RVector &center=RVector())
Definition RShape.cpp:1756
virtual double getLength() const =0
Represents a 3d vector (x/y/z).
Definition RVector.h:47
static const RVector invalid
invalid vector
Definition RVector.h:335
Low-level mathematical representation of an infinite line.
Definition RXLine.h:42
RVector directionVector
Getter function for this property: getDirectionVector Setter function for this property: setDirect...
Definition RXLine.h:160
RVector basePoint
Getter function for this property: getBasePoint Setter function for this property: setBasePoint
Definition RXLine.h:155
virtual RShape::Type getShapeType() const
Definition RXLine.h:50
virtual bool trimEndPoint(double trimDist)
Definition RXLine.h:114
virtual QSharedPointer< RShape > clone() const
Definition RXLine.h:58
RLine getLineShape() const
Definition RXLine.h:54
QSharedPointer< RXLine > cloneToXLine() const
Definition RXLine.h:62
virtual QList< QSharedPointer< RShape > > getOffsetShapes(double distance, int number, RS::Side side, const RVector &position=RVector::invalid)
Definition RXLine.h:131
virtual bool trimStartPoint(double trimDist)
Definition RXLine.h:111
virtual bool isDirected() const
Definition RXLine.h:66
#define QCADCORE_EXPORT
Definition core_global.h:10