⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rs_dimlinear.cpp

📁 qcad2.05可用于windows和linux的源码
💻 CPP
字号:
/****************************************************************************** $Id: rs_dimlinear.cpp 2331 2005-03-27 21:29:45Z andrew $**** Copyright (C) 2001-2003 RibbonSoft. All rights reserved.**** This file is part of the qcadlib Library project.**** This file may be distributed and/or modified under the terms of the** GNU General Public License version 2 as published by the Free Software** Foundation and appearing in the file LICENSE.GPL included in the** packaging of this file.**** Licensees holding valid qcadlib Professional Edition licenses may use ** this file in accordance with the qcadlib Commercial License** Agreement provided with the Software.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.**** See http://www.ribbonsoft.com for further details.**** Contact info@ribbonsoft.com if any conditions of this licensing are** not clear to you.************************************************************************/#include "rs_dimlinear.h"#include "rs_constructionline.h"#include "rs_text.h"#include "rs_solid.h"#include "rs_graphic.h"/** * Constructor. * * @para parent Parent Entity Container. * @para d Common dimension geometrical data. * @para ed Extended geometrical data for linear dimension. */RS_DimLinear::RS_DimLinear(RS_EntityContainer* parent,                           const RS_DimensionData& d,                           const RS_DimLinearData& ed)        : RS_Dimension(parent, d), edata(ed) {    calculateBorders();}RS_VectorSolutions RS_DimLinear::getRefPoints() {	RS_VectorSolutions ret(edata.extensionPoint1, edata.extensionPoint2,						data.definitionPoint, data.middleOfText);	return ret;}/** * @return Automatically created label for the default  * measurement of this dimension. */RS_String RS_DimLinear::getMeasuredLabel() {    // direction of dimension line    RS_Vector dirDim;    dirDim.setPolar(100.0, edata.angle);    // construction line for dimension line    RS_ConstructionLine dimLine(NULL,                                RS_ConstructionLineData(data.definitionPoint,                                                        data.definitionPoint + dirDim));    RS_Vector dimP1 = dimLine.getNearestPointOnEntity(edata.extensionPoint1);    RS_Vector dimP2 = dimLine.getNearestPointOnEntity(edata.extensionPoint2);    // Definitive dimension line:    double dist = dimP1.distanceTo(dimP2);	RS_Graphic* graphic = getGraphic();    RS_String ret;	if (graphic!=NULL) {		ret = RS_Units::formatLinear(dist, graphic->getUnit(), 			graphic->getLinearFormat(), graphic->getLinearPrecision());	}	else {    	ret = RS_String("%1").arg(dist);	}    return ret;}bool RS_DimLinear::hasEndpointsWithinWindow(RS_Vector v1, RS_Vector v2) {	return (edata.extensionPoint1.isInWindow(v1, v2) ||	        edata.extensionPoint2.isInWindow(v1, v2));}/** * Updates the sub entities of this dimension. Called when the  * text or the position, alignment, .. changes. * * @param autoText Automatically reposition the text label */void RS_DimLinear::update(bool autoText) {    RS_DEBUG->print("RS_DimLinear::update");    clear();	if (isUndone()) {		return;	}    // distance from entities (DIMEXO)    double dimexo = getExtensionLineOffset();    // extension line extension (DIMEXE)    double dimexe = getExtensionLineExtension();    RS_LineData ld;    double extAngle = edata.angle + (M_PI/2.0);    // direction of dimension line    RS_Vector dirDim;    dirDim.setPolar(100.0, edata.angle);    // direction of extension lines    RS_Vector dirExt;    dirExt.setPolar(100.0, extAngle);    // construction line for dimension line    RS_ConstructionLine dimLine(        NULL,        RS_ConstructionLineData(data.definitionPoint,                                data.definitionPoint + dirDim));    RS_Vector dimP1 = dimLine.getNearestPointOnEntity(edata.extensionPoint1);    RS_Vector dimP2 = dimLine.getNearestPointOnEntity(edata.extensionPoint2);    // Definitive dimension line:    updateCreateDimensionLine(dimP1, dimP2, true, true, autoText);    /*    ld = RS_LineData(data.definitionPoint, dimP1);    RS_Line* dimensionLine = new RS_Line(this, ld);       addEntity(dimensionLine);    */    RS_Vector vDimexo1, vDimexe1, vDimexo2, vDimexe2;    vDimexe1.setPolar(dimexe, edata.extensionPoint1.angleTo(dimP1));    vDimexo1.setPolar(dimexo, edata.extensionPoint1.angleTo(dimP1));    vDimexe2.setPolar(dimexe, edata.extensionPoint2.angleTo(dimP2));    vDimexo2.setPolar(dimexo, edata.extensionPoint2.angleTo(dimP2));	    if ((edata.extensionPoint1-dimP1).magnitude()<1e-6) {        vDimexe1.setPolar(dimexe,                          data.definitionPoint.angleTo(dimP1)-M_PI/2.0);        vDimexo1.setPolar(dimexo,                          data.definitionPoint.angleTo(dimP1)-M_PI/2.0);    }    if ((edata.extensionPoint2-dimP2).magnitude()<1e-6) {        vDimexe2.setPolar(dimexe,                          data.definitionPoint.angleTo(dimP2)-M_PI/2.0);        vDimexo2.setPolar(dimexo,                          data.definitionPoint.angleTo(dimP2)-M_PI/2.0);    }	    // extension lines:    ld = RS_LineData(edata.extensionPoint1+vDimexo1,                     dimP1+vDimexe1);    RS_Line* line = new RS_Line(this, ld);    line->setPen(RS_Pen(RS2::FlagInvalid));    line->setLayer(NULL);    addEntity(line);    ld = RS_LineData(edata.extensionPoint2+vDimexo2,                     dimP2+vDimexe2);    //data.definitionPoint+vDimexe2);    line = new RS_Line(this, ld);    line->setPen(RS_Pen(RS2::FlagInvalid));    line->setLayer(NULL);    addEntity(line);    calculateBorders();}void RS_DimLinear::move(RS_Vector offset) {    RS_Dimension::move(offset);    edata.extensionPoint1.move(offset);    edata.extensionPoint2.move(offset);    update();}void RS_DimLinear::rotate(RS_Vector center, double angle) {    RS_Dimension::rotate(center, angle);    edata.extensionPoint1.rotate(center, angle);    edata.extensionPoint2.rotate(center, angle);    edata.angle = RS_Math::correctAngle(edata.angle+angle);    update();}void RS_DimLinear::scale(RS_Vector center, RS_Vector factor) {    RS_Dimension::scale(center, factor);    edata.extensionPoint1.scale(center, factor);    edata.extensionPoint2.scale(center, factor);    update();}void RS_DimLinear::mirror(RS_Vector axisPoint1, RS_Vector axisPoint2) {    RS_Dimension::mirror(axisPoint1, axisPoint2);    edata.extensionPoint1.mirror(axisPoint1, axisPoint2);    edata.extensionPoint2.mirror(axisPoint1, axisPoint2);    RS_Vector vec;    vec.setPolar(1.0, edata.angle);    vec.mirror(RS_Vector(0.0,0.0), axisPoint2-axisPoint1);    edata.angle = vec.angle();    update();}void RS_DimLinear::stretch(RS_Vector firstCorner,                           RS_Vector secondCorner,                           RS_Vector offset) {    //e->calculateBorders();    if (getMin().isInWindow(firstCorner, secondCorner) &&            getMax().isInWindow(firstCorner, secondCorner)) {        move(offset);    } else {        //RS_Vector v = data.definitionPoint - edata.extensionPoint2;        //double len = edata.extensionPoint2.distanceTo(data.definitionPoint);        //double ang1 = edata.extensionPoint1.angleTo(edata.extensionPoint2)        //              + M_PI/2;        if (edata.extensionPoint1.isInWindow(firstCorner,                                            secondCorner)) {            edata.extensionPoint1.move(offset);        }        if (edata.extensionPoint2.isInWindow(firstCorner,                                            secondCorner)) {            edata.extensionPoint2.move(offset);        }		/*        double ang2 = edata.extensionPoint1.angleTo(edata.extensionPoint2)                      + M_PI/2;        double diff = RS_Math::getAngleDifference(ang1, ang2);        if (diff>M_PI) {            diff-=2*M_PI;        }        if (fabs(diff)>M_PI/2) {            ang2 = RS_Math::correctAngle(ang2+M_PI);        }        RS_Vector v;        v.setPolar(len, ang2);        data.definitionPoint = edata.extensionPoint2 + v;		*/    }    update(true);}void RS_DimLinear::moveRef(const RS_Vector& ref, const RS_Vector& offset) {    if (ref.distanceTo(data.definitionPoint)<1.0e-4) {        data.definitionPoint += offset;		update(true);    }	else if (ref.distanceTo(data.middleOfText)<1.0e-4) {        data.middleOfText += offset;		update(false);    }	else if (ref.distanceTo(edata.extensionPoint1)<1.0e-4) {        edata.extensionPoint1 += offset;		update(true);    }	else if (ref.distanceTo(edata.extensionPoint2)<1.0e-4) {        edata.extensionPoint2 += offset;		update(true);    }}/** * Dumps the point's data to stdout. */std::ostream& operator << (std::ostream& os, const RS_DimLinear& d) {    os << " DimLinear: " << d.getData() << "\n" << d.getEData() << "\n";    return os;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -