56 double endAngle,
bool reversed =
false);
72 virtual void setZ(
double z) {
191 virtual QList<QSharedPointer<RShape> >
getShapes(
const RBox& queryBox =
RDEFAULT_RBOX,
bool ignoreComplex =
false,
bool segment =
false, QList<RObject::Id>* entityIds =
NULL)
const {
193 Q_UNUSED(ignoreComplex)
197 return QList<QSharedPointer<RShape> >() <<
198 QSharedPointer<RShape>(
new RArc(*
this));
#define RDEFAULT_RBOX
Definition RBox.h:35
Q_DECLARE_METATYPE(RMath *)
#define RMAXDOUBLE
Definition RMath.h:66
#define RDEFAULT_RVECTOR
Definition RVector.h:38
Stores and manages all data that defines the geometry and appearance of an arc entity.
Definition RArcData.h:45
virtual RBox getBoundingBox(bool ignoreEmpty=false) const
Definition RArcData.h:78
virtual bool rotate(double rotation, const RVector ¢er=RDEFAULT_RVECTOR)
Definition RArcData.h:111
bool trimStartPoint(const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
Definition RArcData.h:165
virtual QList< RVector > getArcReferencePoints(const RBox &queryBox=RDEFAULT_RBOX) const
Definition RArcData.h:87
virtual bool flipVertical()
Definition RArcData.h:126
double getRadius() const
Definition RArcData.h:137
virtual QList< RVector > getIntersectionPoints(const RShape &shape, bool limited=true, const RBox &queryBox=RDEFAULT_RBOX, bool ignoreComplex=true) const
Definition RArcData.h:96
virtual QList< RVector > getIntersectionPoints(const REntityData &other, bool limited=true, bool same=false, const RBox &queryBox=RDEFAULT_RBOX, bool ignoreComplex=true, QList< QPair< RObject::Id, RObject::Id > > *entityIds=NULL) const
Definition RArcData.h:93
virtual RVector getVectorTo(const RVector &point, bool limited=true, double strictRange=RMAXDOUBLE) const
Definition RArcData.h:99
bool isValid() const
Definition RArcData.h:66
RVector getCenter() const
Definition RArcData.h:134
virtual QList< RVector > getEndPoints(const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition RArcData.h:69
virtual double getDistanceTo(const RVector &point, bool limited=true, double range=0.0, bool draft=false, double strictRange=RMAXDOUBLE) const
Definition RArcData.h:102
bool trimEndPoint(const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
Definition RArcData.h:168
double getBulge() const
Definition RArcData.h:140
virtual bool scale(const RVector &scaleFactors, const RVector ¢er=RDEFAULT_RVECTOR)
Definition RArcData.h:114
RArc getArc()
Definition RArcData.h:61
double getLength() const
Definition RArcData.h:172
virtual bool mirror(const RLine &axis)
Definition RArcData.h:117
double getAngleLength(bool allowForZeroLength=false) const
Definition RArcData.h:175
virtual bool move(const RVector &offset)
Moves this entity by the given offset.
Definition RArcData.h:108
virtual bool mirror(const RVector &axis1, const RVector &axis2)
Definition RArcData.h:120
double getDirection2() const
Definition RArcData.h:155
RPolyline approximateWithLines(double segmentLength)
Definition RArcData.h:183
virtual RShape * castToShape()
Definition RArcData.h:187
virtual RS::EntityType getType() const
Definition RArcData.h:58
virtual bool stretch(const RPolyline &area, const RVector &offset)
Stretches the end points of this entity that are inside area by offset.
Definition RArcData.h:129
virtual QList< RVector > getPointsWithDistanceToEnd(double distance, int from=RS::FromAny, const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition RArcData.h:90
virtual void to2D()
Definition RArcData.h:75
virtual bool flipHorizontal()
Definition RArcData.h:123
virtual QList< RVector > getCenterPoints(const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition RArcData.h:84
bool isReversed() const
Definition RArcData.h:149
double getEndAngle() const
Definition RArcData.h:146
RS::Ending getTrimEnd(const RVector &trimPoint, const RVector &clickPoint)
Definition RArcData.h:162
virtual bool intersectsWith(const RShape &shape) const
Definition RArcData.h:105
virtual void setZ(double z)
Definition RArcData.h:72
double getStartAngle() const
Definition RArcData.h:143
virtual QList< RVector > getMiddlePoints(const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition RArcData.h:81
bool reverse()
Definition RArcData.h:158
virtual QList< QSharedPointer< RShape > > getShapes(const RBox &queryBox=RDEFAULT_RBOX, bool ignoreComplex=false, bool segment=false, QList< RObject::Id > *entityIds=NULL) const
Definition RArcData.h:191
double getDirection1() const
Definition RArcData.h:152
Arc entity.
Definition RArcEntity.h:38
Low-level mathematical representation of an arc.
Definition RArc.h:42
RArc()
Creates an arc shape with an invalid center.
Definition RArc.cpp:35
double getRadius() const
Definition RArc.cpp:474
virtual bool trimStartPoint(const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
Definition RArc.cpp:827
double getLength() const
Definition RArc.cpp:343
virtual bool scale(const RVector &scaleFactors, const RVector ¢er=RDEFAULT_RVECTOR)
Definition RArc.cpp:715
virtual double getDirection2() const
Definition RArc.cpp:260
virtual bool move(const RVector &offset)
Definition RArc.cpp:691
virtual bool stretch(const RPolyline &area, const RVector &offset)
Definition RArc.cpp:762
virtual RS::Ending getTrimEnd(const RVector &trimPoint, const RVector &clickPoint)
Definition RArc.cpp:808
virtual bool mirror(const RLine &axis)
Definition RArc.cpp:733
virtual bool reverse()
Definition RArc.cpp:754
double getStartAngle() const
Definition RArc.cpp:482
bool isReversed() const
Definition RArc.cpp:526
virtual bool rotate(double rotation, const RVector ¢er=RDEFAULT_RVECTOR)
Definition RArc.cpp:699
double getAngleLength(bool allowForZeroLength=false) const
Definition RArc.cpp:414
RVector getCenter() const
Definition RArc.cpp:466
virtual double getDirection1() const
Definition RArc.cpp:251
double getBulge() const
Definition RArc.cpp:334
double getEndAngle() const
Definition RArc.cpp:490
virtual bool isValid() const
Definition RArc.cpp:77
RPolyline approximateWithLines(double segmentLength, double angle=0.0) const
Definition RArc.cpp:856
virtual void setZ(double z)
Definition RArc.cpp:61
virtual bool trimEndPoint(const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
Definition RArc.cpp:834
Represents a box e.g.
Definition RBox.h:46
A graphics document contains and owns entities, layers, user coordinate systems, variables,...
Definition RDocument.h:78
Base class for all entity data classes.
Definition REntityData.h:65
virtual QList< RVector > getCenterPoints(const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition REntityData.cpp:443
virtual QList< RVector > getMiddlePoints(const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition REntityData.cpp:413
virtual bool flipHorizontal()
Definition REntityData.cpp:729
virtual double getDistanceTo(const RVector &point, bool limited=true, double range=0.0, bool draft=false, double strictRange=RMAXDOUBLE) const
Definition REntityData.cpp:299
virtual QList< RVector > getIntersectionPoints(const REntityData &other, bool limited=true, bool same=false, const RBox &queryBox=RDEFAULT_RBOX, bool ignoreComplex=true, QList< QPair< RObject::Id, RObject::Id > > *entityIds=NULL) const
Definition REntityData.cpp:601
virtual bool moveReferencePoint(const RVector &referencePoint, const RVector &targetPoint, Qt::KeyboardModifiers modifiers=Qt::NoModifier)=0
Moves the given reference point to the given target point or does nothing if this entity has no refer...
virtual bool intersectsWith(const RShape &shape) const
Definition REntityData.cpp:582
virtual QList< RVector > getPointsWithDistanceToEnd(double distance, int from=RS::FromAny, const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition REntityData.cpp:487
virtual bool flipVertical()
Definition REntityData.cpp:733
virtual bool mirror(const RLine &axis)
Definition REntityData.cpp:715
virtual QList< RVector > getArcReferencePoints(const RBox &queryBox=RDEFAULT_RBOX) const
Definition REntityData.cpp:474
virtual QList< RRefPoint > getReferencePoints(RS::ProjectionRenderingHint hint=RS::RenderTop) const =0
virtual RBox getBoundingBox(bool ignoreEmpty=false) const
Definition REntityData.cpp:313
virtual QList< RVector > getEndPoints(const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
Definition REntityData.cpp:383
virtual RVector getVectorTo(const RVector &point, bool limited=true, double strictRange=RMAXDOUBLE) const
Definition REntityData.cpp:551
Base class for all entity classes.
Definition REntity.h:63
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
Represents a reference point of an entity.
Definition RRefPoint.h:18
@ FromAny
Start or end.
Definition RS.h:374
EntityType
Entity types used for property handling / filtering.
Definition RS.h:227
@ EntityArc
Arc.
Definition RS.h:253
ProjectionRenderingHint
Sets the current rendering hint for exports.
Definition RS.h:293
@ RenderTop
Definition RS.h:294
Ending
Entity ending.
Definition RS.h:323
Interface for geometrical shape classes.
Definition RShape.h:72
virtual void to2D()
Flattens this shape to the X/Y plane.
Definition RShape.h:158
Represents a 3d vector (x/y/z).
Definition RVector.h:47
static const RVector invalid
invalid vector
Definition RVector.h:335
#define QCADENTITY_EXPORT
Definition entity_global.h:10
#define NULL
Definition opennurbs_system.h:256