QCAD
Open Source 2D CAD
Loading...
Searching...
No Matches
RXLineData Class Reference

Stores and manages all data that defines the geometry and appearance of an infinite line (xline) entity. More...

#include <RXLineData.h>

Inheritance diagram for RXLineData:
REntityData RXLine RShape

Public Member Functions

virtual RShapecastToShape ()
 
virtual bool flipHorizontal ()
 
virtual bool flipVertical ()
 
double getAngle () const
 
virtual QList< RVectorgetArcReferencePoints (const RBox &queryBox=RDEFAULT_RBOX) const
 
RVector getBasePoint () const
 
virtual RBox getBoundingBox (bool ignoreEmpty=false) const
 
virtual QList< RVectorgetCenterPoints (const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
 
RVector getDirectionVector () const
 
virtual double getDistanceTo (const RVector &point, bool limited=true, double range=0.0, bool draft=false, double strictRange=RMAXDOUBLE) const
 
virtual QList< RVectorgetEndPoints (const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
 
virtual QList< RVectorgetIntersectionPoints (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
 
virtual QList< RVectorgetIntersectionPoints (const RShape &shape, bool limited=true, const RBox &queryBox=RDEFAULT_RBOX, bool ignoreComplex=true) const
 
virtual QList< RVectorgetMiddlePoints (const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
 
virtual QList< RVectorgetPointsWithDistanceToEnd (double distance, int from=RS::FromAny, const RBox &queryBox=RDEFAULT_RBOX, QList< RObject::Id > *subEntityIds=NULL) const
 
virtual QList< RRefPointgetReferencePoints (RS::ProjectionRenderingHint hint=RS::RenderTop) const
 
virtual QList< QSharedPointer< RShape > > getShapes (const RBox &queryBox=RDEFAULT_RBOX, bool ignoreComplex=false, bool segment=false, QList< RObject::Id > *entityIds=NULL) const
 
RS::Side getSideOfPoint (const RVector &point) const
 
RS::Ending getTrimEnd (const RVector &trimPoint, const RVector &clickPoint)
 
virtual RS::EntityType getType () const
 
virtual RVector getVectorTo (const RVector &point, bool limited=true, double strictRange=RMAXDOUBLE) const
 
RXLine getXLine ()
 
bool hasFixedAngle () const
 
virtual bool intersectsWith (const RShape &shape) const
 
bool isValid () const
 
virtual bool mirror (const RLine &axis)
 
virtual bool mirror (const RVector &axis1, const RVector &axis2)
 
virtual bool move (const RVector &offset)
 Moves this entity by the given offset.
 
virtual bool moveReferencePoint (const RVector &referencePoint, const RVector &targetPoint, Qt::KeyboardModifiers modifiers=Qt::NoModifier)
 Moves the given reference point to the given target point or does nothing if this entity has no reference point as the given location.
 
bool reverse ()
 
virtual bool rotate (double rotation, const RVector &center=RDEFAULT_RVECTOR)
 
 RXLineData ()
 Copyright (c) 2011-2018 by Andrew Mustun.
 
 RXLineData (const RVector &basePoint, const RVector &dir)
 
 RXLineData (const RXLine &line)
 
virtual bool scale (const RVector &scaleFactors, const RVector &center=RDEFAULT_RVECTOR)
 
void setFixedAngle (bool on)
 
virtual void setZ (double z)
 
virtual bool stretch (const RPolyline &area, const RVector &offset)
 Stretches the end points of this entity that are inside area by offset.
 
virtual void to2D ()
 
bool trimEndPoint (const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
 
bool trimStartPoint (const RVector &trimPoint, const RVector &clickPoint=RVector::invalid, bool extend=false)
 
- Public Member Functions inherited from REntityData
virtual const RShapecastToConstShape () const
 
virtual bool clickReferencePoint (const RVector &referencePoint)
 Called when user clicks a reference point.
 
virtual bool cloneOnChange () const
 Reimplement to force clone on change in transactions.
 
void copyAttributesFrom (const REntityData &entityData, bool copyBlockId=true)
 
bool getAutoUpdatesBlocked () const
 
RObject::Id getBlockId () const
 
QString getBlockName () const
 
virtual QList< RBoxgetBoundingBoxes (bool ignoreEmpty=false) const
 
virtual RVector getClosestPointOnEntity (const RVector &point, double range=RNANDOUBLE, bool limited=true, RObject::Id *subEntityId=NULL) const
 
virtual QSharedPointer< RShapegetClosestShape (const RVector &pos, double range=RNANDOUBLE, bool ignoreComplex=false, RObject::Id *subEntityId=NULL) const
 
RObject::Id getClosestSubEntityId (const RVector &pos, double range, bool ignoreComplex) const
 Convenience function for scripts.
 
virtual RColor getColor () const
 
virtual RColor getColor (bool resolve, const QStack< QSharedPointer< REntity > > &blockRefStack) const
 
virtual RColor getColor (const RColor &unresolvedColor, const QStack< QSharedPointer< REntity > > &blockRefStack) const
 
virtual RColor getDisplayColor ()
 
RDocumentgetDocument ()
 
const RDocumentgetDocument () const
 
virtual int getDrawOrder () const
 
virtual RPolyline getHull (double offset) const
 
virtual QList< RRefPointgetInternalReferencePoints (RS::ProjectionRenderingHint hint=RS::RenderTop, QList< RObject::Id > *subEntityIds=NULL) const
 Can be overwritten to return internal, resolved reference points.
 
RObject::Id getLayerId () const
 
QString getLayerName () const
 
virtual RObject::Id getLinetypeId () const
 
virtual RObject::Id getLinetypeId (bool resolve, const QStack< QSharedPointer< REntity > > &blockRefStack) const
 
virtual RLinetypePattern getLinetypePattern () const
 
virtual double getLinetypeScale () const
 
virtual RLineweight::Lineweight getLineweight () const
 
virtual RLineweight::Lineweight getLineweight (bool resolve, const QStack< QSharedPointer< REntity > > &blockRefStack) const
 
double getLineweightInUnits (const QStack< QSharedPointer< REntity > > &blockRefStack) const
 
RObject::Id getParentId () const
 
virtual RVector getPointOnEntity () const
 
virtual bool isInside (const RBox &box) const
 
virtual bool isOnEntity (const RVector &point, bool limited=true, double tolerance=RDEFAULT_TOLERANCE_1E_MIN4) const
 
virtual bool isPointType () const
 
virtual bool isSane () const
 
virtual bool isSelected () const
 
virtual bool isSelectedWorkingSet () const
 
virtual bool isUpdatesEnabled () const
 
 REntityData (RDocument *document=NULL)
 Copyright (c) 2011-2018 by Andrew Mustun.
 
virtual bool scale (double scaleFactor, const RVector &center=RDEFAULT_RVECTOR)
 
virtual void scaleVisualProperties (double scaleFactor)
 
void setAutoUpdatesBlocked (bool on)
 
virtual void setBlockId (RObject::Id blockId)
 
void setColor (const RColor &color)
 
void setDocument (RDocument *document)
 
virtual void setDrawOrder (int drawOrder)
 Sets the draw order of this entity.
 
virtual void setLayerId (RObject::Id layerId)
 
void setLayerName (const QString &layerName)
 
virtual void setLinetypeId (RObject::Id linetypeId)
 Sets the linetype of this entity to the given linetype ID.
 
virtual void setLinetypePattern (const RLinetypePattern &p)
 
virtual void setLinetypeScale (double linetypeScale)
 
void setLineweight (RLineweight::Lineweight lineweight)
 
virtual void setParentId (RObject::Id parentId)
 
virtual void setSelected (bool on)
 Selects or deselects this entity.
 
virtual void setSelectedWorkingSet (bool on)
 Selects or deselects this entity for addition to the current working set.
 
void setUpdatesEnabled (bool on)
 Enables / disables cache updates.
 
virtual void update () const
 Entities can reimplement this function to invalidate any internal cache (mark the entity as dirty).
 
virtual ~REntityData ()
 
- Public Member Functions inherited from RXLine
virtual QSharedPointer< RShapeclone () const
 
QSharedPointer< RXLinecloneToXLine () const
 
double getAngle () const
 
virtual double getAngleAt (double distance, RS::From from=RS::FromStart) const
 
RVector getBasePoint () const
 
RBox getBoundingBox () const
 
virtual QList< RVectorgetCenterPoints () const
 
virtual RLine getClippedLine (const RBox &box) const
 
virtual double getDirection1 () const
 
virtual double getDirection2 () const
 
RVector getDirectionVector () const
 
virtual double getDistanceFromStart (const RVector &p) const
 
virtual RVector getEndPoint () const
 
virtual QList< RVectorgetEndPoints () const
 
double getLength () const
 
RLine getLineShape () const
 
virtual RVector getMiddlePoint () const
 
virtual QList< RVectorgetMiddlePoints () const
 
virtual QList< QSharedPointer< RShape > > getOffsetShapes (double distance, int number, RS::Side side, const RVector &position=RVector::invalid)
 
virtual QList< RVectorgetPointCloud (double segmentLength) const
 
virtual QList< RVectorgetPointsWithDistanceToEnd (double distance, int from=RS::FromAny) const
 
RVector getSecondPoint () const
 
virtual RShape::Type getShapeType () const
 
virtual RVector getStartPoint () const
 
virtual QSharedPointer< RShapegetTransformed (const QTransform &transform) const
 
virtual QList< RVectorgetVectorProperties () const
 
virtual bool isDirected () const
 
 RXLine ()
 Copyright (c) 2011-2018 by Andrew Mustun.
 
 RXLine (const RLine &line)
 
 RXLine (const RVector &basePoint, const RVector &directionVector)
 Creates an xline object with the given base point and direction.
 
 RXLine (const RVector &basePoint, double angle, double distance)
 
void setAngle (double a)
 
void setBasePoint (const RVector &vector)
 
void setDirectionVector (const RVector &vector)
 
void setLength (double l)
 
void setSecondPoint (const RVector &vector)
 
virtual QList< QSharedPointer< RShape > > splitAt (const QList< RVector > &points) const
 
virtual bool trimEndPoint (double trimDist)
 
virtual bool trimStartPoint (double trimDist)
 
virtual ~RXLine ()
 
- Public Member Functions inherited from RShape
void dump () const
 
virtual bool equals (const RShape &other, double tolerance=RS::PointTolerance) const
 
virtual QList< RVectorfilterOnShape (const QList< RVector > &pointList, bool limited=true, double tolerance=RDEFAULT_TOLERANCE_1E_MIN4) const
 
virtual double getAngleAtPercent (double p) const
 
virtual double getAngleAtPoint (const RVector &pos) const
 
virtual QList< RVectorgetArcReferencePoints () const
 
virtual QList< bool > getBoolProperties () const
 
virtual RVector getClosestPointOnShape (const RVector &p, bool limited=true, double strictRange=RMAXDOUBLE) const
 
virtual QList< double > getDistancesFromStart (const RVector &p) const
 
virtual double getDistanceTo (const RVector &point, bool limited=true, double strictRange=RMAXDOUBLE) const
 
virtual QList< double > getDoubleProperties () const
 
QList< RVectorgetIntersectionPoints (const RShape &other, bool limited=true, bool same=false, bool force=false) const
 
virtual QList< int > getIntProperties () const
 
virtual double getMaxDistanceTo (const QList< RVector > &points, bool limited=true, double strictRange=RMAXDOUBLE) const
 
virtual RVector getPointAtPercent (double p) const
 
virtual RVector getPointOnShape () const
 
virtual RVector getPointWithDistanceToEnd (double distance) const
 
virtual RVector getPointWithDistanceToStart (double distance) const
 
virtual QList< RVectorgetSelfIntersectionPoints (double tolerance=RS::PointTolerance) const
 
virtual RVector getVectorFromEndpointTo (const RVector &point) const
 
virtual bool intersectsWith (const RShape &other, bool limited=true) const
 
virtual bool isInterpolated () const
 Reimplement and return true if this shape relies on interpolation for geometrical operations such as finding intersection points.
 
virtual bool isOnShape (const RVector &point, bool limited=true, double tolerance=RDEFAULT_TOLERANCE_1E_MIN4) const
 
 RShape ()
 
virtual bool scale (double scaleFactor, const RVector &center=RVector())
 
virtual bool stretch (const RBox &area, const RVector &offset)
 
virtual ~RShape ()
 

Protected Member Functions

 RXLineData (RDocument *document, const RXLineData &data)
 
- Protected Member Functions inherited from RXLine
virtual void print (QDebug dbg) const
 

Private Attributes

bool fixedAngle
 

Friends

class RXLineEntity
 

Additional Inherited Members

- Public Types inherited from RShape
enum  Type {
  Unknown = -1 , Point = 0 , Line = 1 , Arc = 2 ,
  Circle = 3 , Ellipse = 4 , Polyline = 5 , Spline = 6 ,
  Triangle = 7 , XLine = 8 , Ray = 9
}
 
- Static Public Member Functions inherited from REntityData
static int getDefaultDrawOrder ()
 
- Static Public Member Functions inherited from RShape
static const RExplodablecastToExplodable (const RShape *shape)
 
static QSharedPointer< RShapeellipseToArcCircleEllipse (const REllipse &ellipse)
 
static int getErrorCode ()
 
static QList< RVectorgetIntersectionPoints (const RShape &shape1, const RShape &shape2, bool limited=true, bool same=false, bool force=false)
 
static QList< RVectorgetIntersectionPointsAA (const RArc &arc1, const RArc &arc2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsAC (const RArc &arc1, const RCircle &circle2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsAE (const RArc &arc1, const REllipse &ellipse2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsAS (const RArc &arc1, const RSpline &spline2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsAT (const RArc &arc1, const RTriangle &triangle2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsAX (const RArc &arc1, const RExplodable &explodable2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsCC (const RCircle &circle1, const RCircle &circle2)
 
static QList< RVectorgetIntersectionPointsCE (const RCircle &circle1, const REllipse &ellipse2)
 
static QList< RVectorgetIntersectionPointsCS (const RCircle &circle1, const RSpline &spline2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsCX (const RCircle &circle1, const RExplodable &explodable2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsEE (const REllipse &ellipse1, const REllipse &ellipse2)
 Based on "Hughes and Chraibi (2011-2012), Calculating Ellipse Overlap Areas".
 
static QList< RVectorgetIntersectionPointsEE (const REllipse &ellipse1, const REllipse &ellipse2, bool limited)
 
static QList< RVectorgetIntersectionPointsES (const REllipse &ellipse1, const RSpline &spline2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsEX (const REllipse &ellipse1, const RExplodable &explodable2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLA (const RLine &line1, const RArc &arc2, bool limited1, bool limited2)
 
static QList< RVectorgetIntersectionPointsLA (const RLine &line1, const RArc &arc2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLC (const RLine &line1, const RCircle &circle2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLE (const RLine &line1, const REllipse &ellipse2, bool limited1, bool limited2)
 
static QList< RVectorgetIntersectionPointsLE (const RLine &line1, const REllipse &ellipse2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLL (const RLine &line1, const RLine &line2, bool limited1, bool limited2)
 
static QList< RVectorgetIntersectionPointsLL (const RLine &line1, const RLine &line2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLS (const RLine &line1, const RSpline &spline2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLT (const RLine &line1, const RTriangle &triangle2, bool limited1, bool limited2)
 
static QList< RVectorgetIntersectionPointsLT (const RLine &line1, const RTriangle &triangle2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsLX (const RLine &line1, const RExplodable &explodable2, bool limited=true)
 
static QList< RVectorgetIntersectionPointsSS (const RSpline &spline1, const RSpline &spline2, bool limited=true, bool same=false, double tolerance=RS::PointTolerance)
 
static QList< RVectorgetIntersectionPointsSX (const RSpline &spline1, const RExplodable &explodable2, bool limited)
 
static QList< RVectorgetIntersectionPointsXX (const RExplodable &explodable1, const RExplodable &explodable2, bool limited=true, bool same=false)
 
static QList< QSharedPointer< RShape > > getOffsetArcs (const RShape &shape, double distance, int number, RS::Side side, const RVector &position=RVector::invalid)
 
static QList< QSharedPointer< RShape > > getOffsetLines (const RShape &shape, double distance, int number, RS::Side side, const RVector &position=RVector::invalid)
 
static QList< QSharedPointer< RShape > > getOrderedShapes (const QList< QSharedPointer< RShape > > &shapes)
 
static QList< RPolylinegetPolylines (const QList< QSharedPointer< RShape > > &shapes)
 
static QList< QSharedPointer< RShape > > getReversedShapeList (const QList< QSharedPointer< RShape > > &shapes)
 
static RShapeProxygetShapeProxy ()
 
static bool hasProxy ()
 
static bool isArcShape (const RShape &s)
 
static bool isCircleShape (const RShape &s)
 
static bool isEllipseShape (const RShape &s)
 
static bool isFullEllipseShape (const RShape &s)
 
static bool isLineShape (const RShape &s)
 
static bool isPointShape (const RShape &s)
 
static bool isPolylineShape (const RShape &s)
 
static bool isRayShape (const RShape &s)
 
static bool isSplineShape (const RShape &s)
 
static bool isTriangleShape (const RShape &s)
 
static bool isXLineShape (const RShape &s)
 
static bool order (QList< QList< QSharedPointer< RShape > > > &boundary)
 Orders the given list of loops into a list of closed loops in which all shapes are connected end to start point.
 
static QSharedPointer< RShaperayToLine (QSharedPointer< RShape > shape)
 
static QList< QSharedPointer< RShape > > roundCorners (const QList< QSharedPointer< RShape > > &shapes, double radius)
 Round every corner of the list of given (connected) shapes with the given radius.
 
static QList< QSharedPointer< RShape > > roundShapes (const QSharedPointer< RShape > shape1, const RVector &clickPos1, const QSharedPointer< RShape > shape2, const RVector &clickPos2, bool trim, bool samePolyline, double radius, const RVector &pos)
 Rounds the given shape1 against shape2.
 
static QSharedPointer< RShapescaleArc (const RShape &shape, const RVector &scaleFactors, const RVector &center=RDEFAULT_RVECTOR)
 
static void setShapeProxy (RShapeProxy *p)
 
static QSharedPointer< RShapetransformArc (const RShape &shape, RShapeTransformation &transformation)
 
static QList< QSharedPointer< RShape > > trim (const RShape &trimShape, const RVector &trimClickPos, const RShape &limitingShape, const RVector &limitingClickPos, bool trimBoth, bool samePolyline)
 Trims a shape to another or two shapes to each other.
 
static QSharedPointer< RShapexLineToRay (QSharedPointer< RShape > shape)
 
- Public Attributes inherited from RXLine
RVector basePoint
 
Getter function for this property: getBasePoint

Setter function for this property: setBasePoint

 
RVector directionVector
 
Getter function for this property: getDirectionVector

Setter function for this property: setDirectionVector

 
- Protected Attributes inherited from REntityData
bool autoUpdatesBlocked
 Block auto updates is true during imports, undo and redo.
 
RObject::Id blockId
 
RColor color
 
RDocumentdocument
 
int drawOrder
 
RObject::Id layerId
 
RObject::Id linetypeId
 
double linetypeScale
 
RLineweight::Lineweight lineweight
 
RObject::Id parentId
 
bool selectionStatus
 
bool selectionStatusWorkingSet
 
bool updatesEnabled
 
- Static Protected Attributes inherited from RShape
static int errorCode = 0
 

Detailed Description

Stores and manages all data that defines the geometry and appearance of an infinite line (xline) entity.

Scriptable:\nThis class is available in script environments.\n
Copyable:\nObjects are cleaned up automatically by the garbage collector of the script engine.\n

Constructor & Destructor Documentation

◆ RXLineData() [1/4]

RXLineData::RXLineData ( RDocument * document,
const RXLineData & data )
protected

◆ RXLineData() [2/4]

RXLineData::RXLineData ( )

Copyright (c) 2011-2018 by Andrew Mustun.

All rights reserved.

This file is part of the QCAD project.

QCAD is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

QCAD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with QCAD.

◆ RXLineData() [3/4]

RXLineData::RXLineData ( const RXLine & line)

◆ RXLineData() [4/4]

RXLineData::RXLineData ( const RVector & basePoint,
const RVector & dir )

Member Function Documentation

◆ castToShape()

virtual RShape * RXLineData::castToShape ( )
inlinevirtual

Reimplemented from REntityData.

◆ flipHorizontal()

virtual bool RXLineData::flipHorizontal ( )
inlinevirtual

Reimplemented from REntityData.

◆ flipVertical()

virtual bool RXLineData::flipVertical ( )
inlinevirtual

Reimplemented from REntityData.

◆ getAngle()

double RXLineData::getAngle ( ) const
inline

◆ getArcReferencePoints()

virtual QList< RVector > RXLineData::getArcReferencePoints ( const RBox & queryBox = RDEFAULT_RBOX) const
inlinevirtual
Returns
Vector of reference points of this entity. Used for snap to reference points.

Reimplemented from REntityData.

◆ getBasePoint()

RVector RXLineData::getBasePoint ( ) const
inline

◆ getBoundingBox()

virtual RBox RXLineData::getBoundingBox ( bool ignoreEmpty = false) const
inlinevirtual
Returns
The bounding box that contains this entity.

Reimplemented from REntityData.

◆ getCenterPoints()

virtual QList< RVector > RXLineData::getCenterPoints ( const RBox & queryBox = RDEFAULT_RBOX,
QList< RObject::Id > * subEntityIds = NULL ) const
inlinevirtual
Returns
Vector of center points of this entity. Used for snap to center points.

Reimplemented from REntityData.

◆ getDirectionVector()

RVector RXLineData::getDirectionVector ( ) const
inline

◆ getDistanceTo()

virtual double RXLineData::getDistanceTo ( const RVector & point,
bool limited = true,
double range = 0.0,
bool draft = false,
double strictRange = RMAXDOUBLE ) const
inlinevirtual
Returns
The shortest distance from this entity to the given point.
Parameters
limitedLimit lines, arcs at end points, otherwise the orthogonal distance to the unlimited line / circle is returned.
rangeThis is returned for solid filled entities (solid filled or dense hatches, text entities) if the point is on the entity and the distance would be zero.
draftCalculate based on draft mode representation of the entity.
strictRangeIf limited, this is the maximum range from either end point of the entity. Zero to only return distances that are strictly orthogonal to the entity.

Reimplemented from REntityData.

◆ getEndPoints()

virtual QList< RVector > RXLineData::getEndPoints ( const RBox & queryBox = RDEFAULT_RBOX,
QList< RObject::Id > * subEntityIds = NULL ) const
inlinevirtual
Returns
Vector of end points of this entity. Used for snap to end points.

Reimplemented from REntityData.

◆ getIntersectionPoints() [1/2]

virtual QList< RVector > RXLineData::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
inlinevirtual
Returns
Points on entity which are intersection points with the given other entity. If same is true, the two datas originate from the same entity.

Reimplemented from REntityData.

◆ getIntersectionPoints() [2/2]

virtual QList< RVector > RXLineData::getIntersectionPoints ( const RShape & shape,
bool limited = true,
const RBox & queryBox = RDEFAULT_RBOX,
bool ignoreComplex = true ) const
inlinevirtual
Returns
Points on entity which are intersection points with the given shape.

Reimplemented from REntityData.

◆ getMiddlePoints()

virtual QList< RVector > RXLineData::getMiddlePoints ( const RBox & queryBox = RDEFAULT_RBOX,
QList< RObject::Id > * subEntityIds = NULL ) const
inlinevirtual
Returns
Vector of middle points of this entity. Used for snap to middle points.

Reimplemented from REntityData.

◆ getPointsWithDistanceToEnd()

virtual QList< RVector > RXLineData::getPointsWithDistanceToEnd ( double distance,
int from = RS::FromAny,
const RBox & queryBox = RDEFAULT_RBOX,
QList< RObject::Id > * subEntityIds = NULL ) const
inlinevirtual
Returns
Points on entity with given distance to either endpoint. Used for snap to points with distance on entity.

Reimplemented from REntityData.

◆ getReferencePoints()

QList< RRefPoint > RXLineData::getReferencePoints ( RS::ProjectionRenderingHint hint = RS::RenderTop) const
virtual
Returns
Vector of reference points of this entity. Reference points can usually be moved around by the user to change the geometry of the entity.

Implements REntityData.

◆ getShapes()

virtual QList< QSharedPointer< RShape > > RXLineData::getShapes ( const RBox & queryBox = RDEFAULT_RBOX,
bool ignoreComplex = false,
bool segment = false,
QList< RObject::Id > * entityIds = NULL ) const
inlinevirtual
Returns
Shapes that represent the geometry of this entity.
Parameters
queryBoxLimit returned shapes to query box
ignoreComplexIgnore complex shapes and explode those into simple shapes
segmentSplit up splines into spline segments

Reimplemented from REntityData.

◆ getSideOfPoint()

RS::Side RXLineData::getSideOfPoint ( const RVector & point) const
inlinevirtual

Reimplemented from RXLine.

◆ getTrimEnd()

RS::Ending RXLineData::getTrimEnd ( const RVector & trimPoint,
const RVector & clickPoint )
inlinevirtual
Parameters
trimPointTrim start point or end point to this coordinate.
clickPointPoint that was clicked by user.

Reimplemented from RXLine.

◆ getType()

virtual RS::EntityType RXLineData::getType ( ) const
inlinevirtual

Reimplemented from REntityData.

◆ getVectorTo()

virtual RVector RXLineData::getVectorTo ( const RVector & point,
bool limited = true,
double strictRange = RMAXDOUBLE ) const
inlinevirtual
Returns
The distance vector from this entity to the given point.
Parameters
pointthe point to which the distance was measured
limitedIf true, an invalid vector is returned if the closest point on the entity is outside of the entity (e.g. in the extension line of a line or outside the start / end angle of an arc).

Reimplemented from REntityData.

◆ getXLine()

RXLine RXLineData::getXLine ( )
inline

◆ hasFixedAngle()

bool RXLineData::hasFixedAngle ( ) const
inline

◆ intersectsWith()

virtual bool RXLineData::intersectsWith ( const RShape & shape) const
inlinevirtual
Returns
True if this entity intersects with the given shape, false otherwise.
Todo
better to pass another entity data object?

Reimplemented from REntityData.

◆ isValid()

bool RXLineData::isValid ( ) const
inlinevirtual

Reimplemented from REntityData.

◆ mirror() [1/2]

virtual bool RXLineData::mirror ( const RLine & axis)
inlinevirtual

Reimplemented from REntityData.

◆ mirror() [2/2]

virtual bool RXLineData::mirror ( const RVector & axis1,
const RVector & axis2 )
inlinevirtual

Reimplemented from REntityData.

◆ move()

virtual bool RXLineData::move ( const RVector & offset)
inlinevirtual

Moves this entity by the given offset.

Reimplemented from REntityData.

◆ moveReferencePoint()

bool RXLineData::moveReferencePoint ( const RVector & referencePoint,
const RVector & targetPoint,
Qt::KeyboardModifiers modifiers = Qt::NoModifier )
virtual

Moves the given reference point to the given target point or does nothing if this entity has no reference point as the given location.

Returns
True if a reference point has been moved successfully, false otherwise.

Implements REntityData.

◆ reverse()

bool RXLineData::reverse ( )
inlinevirtual

Reimplemented from RXLine.

◆ rotate()

virtual bool RXLineData::rotate ( double rotation,
const RVector & center = RDEFAULT_RVECTOR )
inlinevirtual

Reimplemented from REntityData.

◆ scale()

virtual bool RXLineData::scale ( const RVector & scaleFactors,
const RVector & center = RDEFAULT_RVECTOR )
inlinevirtual

Reimplemented from REntityData.

◆ setFixedAngle()

void RXLineData::setFixedAngle ( bool on)
inline

◆ setZ()

virtual void RXLineData::setZ ( double z)
inlinevirtual

Reimplemented from REntityData.

◆ stretch()

virtual bool RXLineData::stretch ( const RPolyline & area,
const RVector & offset )
inlinevirtual

Stretches the end points of this entity that are inside area by offset.

Reimplemented from REntityData.

◆ to2D()

virtual void RXLineData::to2D ( )
inlinevirtual

Reimplemented from REntityData.

◆ trimEndPoint()

bool RXLineData::trimEndPoint ( const RVector & trimPoint,
const RVector & clickPoint = RVector::invalid,
bool extend = false )
inlinevirtual
Parameters
trimPointTrim start point or end point to this coordinate.
clickPointPoint that was clicked by user.
extendTrue if the shape is to be extended. Used for polylines to determine that the last segment has to be trimmed even if another segment was clicked.

Reimplemented from RXLine.

◆ trimStartPoint()

bool RXLineData::trimStartPoint ( const RVector & trimPoint,
const RVector & clickPoint = RVector::invalid,
bool extend = false )
inlinevirtual
Parameters
trimPointTrim start point or end point to this coordinate.
clickPointPoint that was clicked by user.
extendTrue if the shape is to be extended. Used for polylines to determine that the first segment has to be trimmed even if another segment was clicked.

Reimplemented from RXLine.

Friends And Related Symbol Documentation

◆ RXLineEntity

friend class RXLineEntity
friend

Member Data Documentation

◆ fixedAngle

bool RXLineData::fixedAngle
private

The documentation for this class was generated from the following files: