| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | #include <iostream> |
| | #include "rs_dimradial.h" |
| |
|
| | #include "rs_debug.h" |
| | #include "rs_graphic.h" |
| | #include "rs_units.h" |
| |
|
| | RS_DimRadialData::RS_DimRadialData(): |
| | definitionPoint(false), |
| | leader(0.0) { |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | RS_DimRadialData::RS_DimRadialData(const RS_Vector& _definitionPoint, double _leader): |
| | definitionPoint(_definitionPoint) |
| | , leader(_leader) { |
| | } |
| |
|
| | std::ostream& operator <<(std::ostream& os,const RS_DimRadialData& dd) { |
| | os << "(" << dd.definitionPoint << "/" << dd.leader << ")"; |
| | return os; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | RS_DimRadial::RS_DimRadial(RS_EntityContainer* parent, const RS_DimensionData& d, const RS_DimRadialData& ed) |
| | : RS_Dimension(parent, d), m_dimRadialData(ed) { |
| | } |
| |
|
| | RS_DimRadial::RS_DimRadial(const RS_DimRadial& other) |
| | :RS_Dimension(other), m_dimRadialData{other.m_dimRadialData} { |
| | } |
| |
|
| | RS_Entity* RS_DimRadial::clone() const { |
| | auto* d = new RS_DimRadial(*this); |
| | return d; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | QString RS_DimRadial::getMeasuredLabel() { |
| | |
| | double distance = m_dimGenericData.definitionPoint.distanceTo(m_dimRadialData.definitionPoint); |
| |
|
| | double dist = prepareLabelLinearDistance(distance); |
| | QString measuredLabel = createLinearMeasuredLabel(dist); |
| | return measuredLabel; |
| | } |
| |
|
| | RS_VectorSolutions RS_DimRadial::getRefPoints() const { |
| | return RS_VectorSolutions({ |
| | m_dimRadialData.definitionPoint, |
| | m_dimGenericData.definitionPoint, m_dimGenericData.middleOfText |
| | }); |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | void RS_DimRadial::doUpdateDim() { |
| | RS_DEBUG->print("RS_DimRadial::update"); |
| |
|
| | const RS_Vector p1 = m_dimGenericData.definitionPoint; |
| | const RS_Vector p2 = m_dimRadialData.definitionPoint; |
| |
|
| | |
| | auto textData = createDimTextData({0,0},getTextHeight() * getGeneralScale(), 0.0); |
| | RS_MText text(this, textData); |
| |
|
| | const double textWidth = text.getUsedTextWidth(); |
| |
|
| | const double arrow_size = getArrowSize() * getGeneralScale(); |
| | const double line_length = p1.distanceTo(p2); |
| | const double line_angle = p1.angleTo(p2); |
| | double doubleArrowSize = arrow_size * 2.0; |
| | if (line_length < (doubleArrowSize + textWidth)) { |
| | const RS_Vector p1b = p1 + RS_Vector::polar(line_length, line_angle); |
| |
|
| | |
| | addDimDimensionLine(p1, p1b); |
| |
|
| | const double extended_line_length = line_length + doubleArrowSize + textWidth; |
| | const RS_Vector p3 = p1 + RS_Vector::polar(extended_line_length, line_angle); |
| | createDimensionLine(p1b, p3, true, false, true, false, m_dimGenericData.autoText); |
| | } |
| | else { |
| | const RS_Vector p3 = p1 + RS_Vector::polar(line_length, line_angle); |
| | createDimensionLine(p1, p3, false, true, false, true, m_dimGenericData.autoText); |
| | } |
| | } |
| |
|
| | void RS_DimRadial::move(const RS_Vector& offset) { |
| | RS_Dimension::move(offset); |
| |
|
| | m_dimRadialData.definitionPoint.move(offset); |
| | update(); |
| | } |
| |
|
| | void RS_DimRadial::rotate(const RS_Vector& center, double angle) { |
| | rotate(center,RS_Vector(angle)); |
| | } |
| |
|
| | void RS_DimRadial::rotate(const RS_Vector& center, const RS_Vector& angleVector) { |
| | RS_Dimension::rotate(center, angleVector); |
| | m_dimRadialData.definitionPoint.rotate(center, angleVector); |
| | update(); |
| | } |
| |
|
| | void RS_DimRadial::scale(const RS_Vector& center, const RS_Vector& factor) { |
| | RS_Dimension::scale(center, factor); |
| |
|
| | m_dimRadialData.definitionPoint.scale(center, factor); |
| | m_dimRadialData.leader*=factor.x; |
| | update(); |
| | } |
| |
|
| | void RS_DimRadial::mirror(const RS_Vector& axisPoint1, const RS_Vector& axisPoint2) { |
| | RS_Dimension::mirror(axisPoint1, axisPoint2); |
| |
|
| | m_dimRadialData.definitionPoint.mirror(axisPoint1, axisPoint2); |
| | update(); |
| | } |
| |
|
| | void RS_DimRadial::moveRef(const RS_Vector& ref, const RS_Vector& offset) { |
| | if (ref.distanceTo(m_dimRadialData.definitionPoint) < 1.0e-4) { |
| | double d = m_dimGenericData.definitionPoint.distanceTo(m_dimRadialData.definitionPoint); |
| | double a = m_dimGenericData.definitionPoint.angleTo(m_dimRadialData.definitionPoint + offset); |
| |
|
| | RS_Vector v = RS_Vector::polar(d, a); |
| | m_dimRadialData.definitionPoint = m_dimGenericData.definitionPoint + v; |
| | updateDim(true); |
| | } |
| | else if (ref.distanceTo(m_dimGenericData.middleOfText) < 1.0e-4) { |
| | m_dimGenericData.middleOfText.move(offset); |
| | updateDim(false); |
| | } |
| | } |
| |
|
| | |
| | |
| | |
| | std::ostream& operator << (std::ostream& os, const RS_DimRadial& d) { |
| | os << " DimRadial: " << d.getData() << "\n" << d.getEData() << "\n"; |
| | return os; |
| | } |
| |
|