QCAD
Open Source 2D CAD
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
RDimAngularData Class Reference

Copyright (c) 2011-2013 by Andrew Mustun. More...

#include <RDimAngularData.h>

Inheritance diagram for RDimAngularData:
RDimensionData REntityData

List of all members.

Public Member Functions

double getAngle () const
bool getAngles (double &ang1, double &ang2, bool &reversed, RVector &p1, RVector &p2) const
 Finds out which angles this dimension actually measures.
virtual QString getAutoLabel () const
RVector getCenter () const
RVector getDimArcPosition () const
RVector getExtensionLine1End () const
RVector getExtensionLine1Start () const
RVector getExtensionLine2End () const
RVector getExtensionLine2Start () const
virtual double getMeasuredValue () const
virtual QList< RVectorgetReferencePoints (RS::ProjectionRenderingHint hint=RS::RenderTop) const
virtual QList< QSharedPointer
< RShape > > 
getShapes (const RBox &queryBox=RDEFAULT_RBOX) const
virtual bool isValid () const
virtual bool mirror (const RLine &axis)
virtual bool move (const RVector &offset)
 Moves this entity by the given offset.
virtual bool moveReferencePoint (const RVector &referencePoint, const RVector &targetPoint)
 Moves the given reference point to the given target point or does nothing if this entity has no reference point as the given location.
 RDimAngularData ()
 Copyright (c) 2011-2013 by Andrew Mustun.
 RDimAngularData (const RDimensionData &dimData, const RVector &extensionLine1Start, const RVector &extensionLine1End, const RVector &extensionLine2Start, const RVector &dimArcPosition)
virtual bool rotate (double rotation, const RVector &center)
virtual bool scale (const RVector &scaleFactors, const RVector &center)
void setDimArcPosition (const RVector &p)
void setExtensionLine1End (const RVector &p)
void setExtensionLine1Start (const RVector &p)
void setExtensionLine2End (const RVector &p)
void setExtensionLine2Start (const RVector &p)
- Public Member Functions inherited from RDimensionData
QString formatAngleLabel (double textAngle) const
QString formatLabel (double distance) const
virtual QList< QSharedPointer
< RShape > > 
getArrow (const RVector &position, double direction) const
virtual RBox getBoundingBox () const
RVector getDefinitionPoint () const
double getDimasz () const
QList< QSharedPointer< RShape > > getDimensionLineShapes (const RVector &p1, const RVector &p2, bool arrow1, bool arrow2) const
 Creates a dimensioning line (line with one, two or no arrows).
double getDimexe () const
double getDimexo () const
double getDimgap () const
double getDimtxt () const
virtual double getDistanceTo (const RVector &point, bool limited=true, double range=0.0, bool draft=false) const
QString getFontName () const
double getLinearFactor () const
double getLineSpacingFactor () const
RS::TextLineSpacingStyle getLineSpacingStyle () const
virtual QString getMeasurement (bool resolveAutoMeasurement=true) const
QString getText () const
double getTextAngle () const
RTextDatagetTextData () const
RVector getTextPosition () const
bool hasCustomTextPosition () const
void initTextData () const
 Initializes the text data of the text label of this dimension.
virtual bool intersectsWith (const RShape &shape) const
 RDimensionData (RDocument *document=NULL)
 Copyright (c) 2011-2013 by Andrew Mustun.
 RDimensionData (const RVector &definitionPoint, const RVector &textPositionCenter, RS::VAlign valign, RS::HAlign halign, RS::TextLineSpacingStyle lineSpacingStyle, double lineSpacingFactor, const QString &text, const QString &fontName, double textAngle)
void setCustomTextPosition (bool on)
void setDefinitionPoint (const RVector &p)
void setFontName (const QString &fn)
void setLinearFactor (double f)
void setLowerTolerance (const QString &t)
void setText (const QString &t)
void setTextPosition (const RVector &p)
void setUpperTolerance (const QString &t)
virtual void update () const
 Entities can reimplement this function to invalidate any internal cache (mark the entity as dirty).
virtual void updateTextData () const
bool useArchTick () const
- Public Member Functions inherited from REntityData
virtual const RShapecastToConstShape () const
virtual RShapecastToShape ()
virtual bool flipHorizontal ()
virtual bool flipVertical ()
RBlock::Id getBlockId () const
QString getBlockName () const
virtual QList< RBoxgetBoundingBoxes () const
virtual QList< RVectorgetCenterPoints (const RBox &queryBox=RDEFAULT_RBOX) const
virtual RVector getClosestPointOnEntity (const RVector &point, double range=RNANDOUBLE, bool limited=true) const
virtual QSharedPointer< RShapegetClosestShape (const RVector &pos, double range=RNANDOUBLE) const
RColor getColor () const
RColor getColor (bool resolve, const QStack< RBlockReferenceEntity * > &blockRefStack) const
RDocumentgetDocument ()
const RDocumentgetDocument () const
virtual int getDrawOrder () const
virtual QList< RVectorgetEndPoints (const RBox &queryBox=RDEFAULT_RBOX) const
virtual QList< RVectorgetInternalReferencePoints (RS::ProjectionRenderingHint hint=RS::RenderTop) const
 Can be overwritten to return internal, resolved reference points.
virtual QList< RVectorgetIntersectionPoints (const REntityData &other, bool limited=true, bool same=false, const RBox &queryBox=RDEFAULT_RBOX) const
 Override to disable intersection point.
virtual QList< RVectorgetIntersectionPoints (const RShape &shape, bool limited=true, const RBox &queryBox=RDEFAULT_RBOX) const
RLayer::Id getLayerId () const
QString getLayerName () const
RLinetype::Id getLinetypeId () const
RLinetype::Id getLinetypeId (bool resolve, const QStack< RBlockReferenceEntity * > &blockRefStack) const
RLineweight::Lineweight getLineweight () const
RLineweight::Lineweight getLineweight (bool resolve, const QStack< RBlockReferenceEntity * > &blockRefStack) const
double getLineweightInUnits (const QStack< RBlockReferenceEntity * > &blockRefStack) const
virtual QList< RVectorgetMiddlePoints (const RBox &queryBox=RDEFAULT_RBOX) const
RObject::Id getParentId () const
virtual RVector getPointOnEntity () const
virtual QList< RVectorgetPointsWithDistanceToEnd (double distance, RS::From from=RS::FromAny, const RBox &queryBox=RDEFAULT_RBOX) const
virtual RVector getVectorTo (const RVector &point, bool limited=true) const
virtual bool isInside (const RBox &box) const
virtual bool isOnEntity (const RVector &point, bool limited=true) const
virtual bool isSelected () const
virtual bool mirror (const RVector &axis1, const RVector &axis2)
 REntityData (RDocument *document=NULL)
 Copyright (c) 2011-2013 by Andrew Mustun.
virtual bool scale (double scaleFactor, const RVector &center=RDEFAULT_RVECTOR)
virtual void setBlockId (RBlock::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 (RLayer::Id layerId)
virtual void setLinetype (RLinetype linetype)
virtual void setLinetypeId (RLinetype::Id linetypeId)
void setLineweight (RLineweight::Lineweight lineweight)
virtual void setParentId (RObject::Id parentId)
virtual void setSelected (bool on)
 Selects or deselects this entity.
virtual bool stretch (const RPolyline &area, const RVector &offset)
 Stretches the end points of this entity that are inside area by offset.
virtual ~REntityData ()

Protected Member Functions

 RDimAngularData (RDocument *document, const RDimAngularData &data)
- Protected Member Functions inherited from RDimensionData
 RDimensionData (RDocument *document, const RDimensionData &data)

Private Attributes

RVector dimArcPosition
 Arc position.
RVector extensionLine1End
 End point of first extension line.
RVector extensionLine1Start
 Start point of first extension line.
RVector extensionLine2Start
 Start point of second extension line.

Friends

class RDimAngularEntity

Additional Inherited Members

- Protected Attributes inherited from RDimensionData
bool autoTextPos
 True if the textPosition should be automatically calculated.
RBox boundingBox
double defaultAngle
RVector definitionPoint
 Definition point.
double dimLineLength
bool dirty
QString fontName
 Dimension font name.
RS::HAlign halign
 Horizontal alignment.
double linearFactor
double lineSpacingFactor
 Line spacing factor.
RS::TextLineSpacingStyle lineSpacingStyle
 Line spacing style.
QString lowerTolerance
 Lower tolerance limit.
QString text
 Text string entered explicitly by user or null or "<>" for the actual measurement or " " (one blank space) for supressing the text.
double textAngle
 Rotation angle of dimension text away from default orientation.
RTextData textData
RVector textPositionCenter
 Middle point of dimension text.
RVector textPositionSide
 Middle point of dimension text when automatically moved to the side for lack of space.
QString upperTolerance
 Upper tolerance limit.
RS::VAlign valign
 Vertical alignment.
- Protected Attributes inherited from REntityData
RBlock::Id blockId
RColor color
RDocumentdocument
int drawOrder
RLayer::Id layerId
RLinetype::Id linetypeId
RLineweight::Lineweight lineweight
RObject::Id parentId
bool selectionStatus

Detailed Description

Copyright (c) 2011-2013 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. Angular dimension entity data class.

Scriptable:
This class is wrapped for script environments.

Constructor & Destructor Documentation

RDimAngularData::RDimAngularData ( RDocument document,
const RDimAngularData data 
)
protected
RDimAngularData::RDimAngularData ( )

Copyright (c) 2011-2013 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.

RDimAngularData::RDimAngularData ( const RDimensionData dimData,
const RVector extensionLine1Start,
const RVector extensionLine1End,
const RVector extensionLine2Start,
const RVector dimArcPosition 
)
Parameters:
definitionPointDefinition point is extensionLine2End.

Member Function Documentation

double RDimAngularData::getAngle ( ) const
Returns:
Angle of the measured dimension.
bool RDimAngularData::getAngles ( double &  ang1,
double &  ang2,
bool &  reversed,
RVector p1,
RVector p2 
) const

Finds out which angles this dimension actually measures.

Parameters:
ang1Reference will return the start angle
ang2Reference will return the end angle
reversedReference will return the reversed flag.
Returns:
true: on success
QString RDimAngularData::getAutoLabel ( ) const
virtual

Reimplemented from RDimensionData.

RVector RDimAngularData::getCenter ( ) const
Returns:
Center of the measured dimension.
RVector RDimAngularData::getDimArcPosition ( ) const
inline
RVector RDimAngularData::getExtensionLine1End ( ) const
inline
RVector RDimAngularData::getExtensionLine1Start ( ) const
inline
RVector RDimAngularData::getExtensionLine2End ( ) const
inline
RVector RDimAngularData::getExtensionLine2Start ( ) const
inline
double RDimAngularData::getMeasuredValue ( ) const
virtual

Reimplemented from RDimensionData.

QList< RVector > RDimAngularData::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.

Reimplemented from RDimensionData.

QList< QSharedPointer< RShape > > RDimAngularData::getShapes ( const RBox queryBox = RDEFAULT_RBOX) const
virtual
Returns:
Shapes that represent the geometry of this entity.

Reimplemented from REntityData.

bool RDimAngularData::isValid ( ) const
virtual

Reimplemented from RDimensionData.

bool RDimAngularData::mirror ( const RLine axis)
virtual

Reimplemented from RDimensionData.

bool RDimAngularData::move ( const RVector offset)
virtual

Moves this entity by the given offset.

Reimplemented from RDimensionData.

bool RDimAngularData::moveReferencePoint ( const RVector referencePoint,
const RVector targetPoint 
)
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.

Reimplemented from RDimensionData.

bool RDimAngularData::rotate ( double  rotation,
const RVector center 
)
virtual

Reimplemented from RDimensionData.

bool RDimAngularData::scale ( const RVector scaleFactors,
const RVector center 
)
virtual

Reimplemented from RDimensionData.

void RDimAngularData::setDimArcPosition ( const RVector p)
inline
void RDimAngularData::setExtensionLine1End ( const RVector p)
inline
void RDimAngularData::setExtensionLine1Start ( const RVector p)
inline
void RDimAngularData::setExtensionLine2End ( const RVector p)
inline
void RDimAngularData::setExtensionLine2Start ( const RVector p)
inline

Friends And Related Function Documentation

friend class RDimAngularEntity
friend

Member Data Documentation

RVector RDimAngularData::dimArcPosition
private

Arc position.

RVector RDimAngularData::extensionLine1End
private

End point of first extension line.

RVector RDimAngularData::extensionLine1Start
private

Start point of first extension line.

RVector RDimAngularData::extensionLine2Start
private

Start point of second extension line.

End is definition point.


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