2013-12-29 17:48:57 +01:00
|
|
|
/************************************************************************
|
|
|
|
**
|
|
|
|
** @file vtooluniondetails.cpp
|
2014-04-30 07:38:52 +02:00
|
|
|
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
2013-12-29 17:48:57 +01:00
|
|
|
** @date 26 12, 2013
|
|
|
|
**
|
|
|
|
** @brief
|
|
|
|
** @copyright
|
|
|
|
** This source code is part of the Valentine project, a pattern making
|
|
|
|
** program, whose allow create and modeling patterns of clothing.
|
2015-02-27 11:27:48 +01:00
|
|
|
** Copyright (C) 2013-2015 Valentina project
|
2013-12-29 17:48:57 +01:00
|
|
|
** <https://bitbucket.org/dismine/valentina> All Rights Reserved.
|
|
|
|
**
|
|
|
|
** Valentina 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.
|
|
|
|
**
|
|
|
|
** Valentina 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 Valentina. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
**
|
|
|
|
*************************************************************************/
|
|
|
|
|
|
|
|
#include "vtooluniondetails.h"
|
2016-08-08 13:44:49 +02:00
|
|
|
|
|
|
|
#include <QByteArray>
|
|
|
|
#include <QDomNodeList>
|
|
|
|
#include <QHash>
|
|
|
|
#include <QLineF>
|
|
|
|
#include <QMessageLogger>
|
|
|
|
#include <QSharedPointer>
|
|
|
|
#include <QStaticStringData>
|
|
|
|
#include <QStringData>
|
|
|
|
#include <QStringDataPtr>
|
|
|
|
#include <QUndoStack>
|
|
|
|
#include <QtDebug>
|
|
|
|
#include <new>
|
|
|
|
|
2014-06-08 20:10:57 +02:00
|
|
|
#include "../dialogs/tools/dialoguniondetails.h"
|
2016-08-08 13:44:49 +02:00
|
|
|
#include "../ifc/xml/vabstractconverter.h"
|
|
|
|
#include "../ifc/xml/vdomdocument.h"
|
2016-07-07 17:04:26 +02:00
|
|
|
#include "../ifc/xml/vpatternconverter.h"
|
2016-08-09 15:55:46 +02:00
|
|
|
#include "../vgeometry/varc.h"
|
2016-12-20 15:51:58 +01:00
|
|
|
#include "../vgeometry/vellipticalarc.h"
|
2016-08-09 15:55:46 +02:00
|
|
|
#include "../vgeometry/vsplinepath.h"
|
2016-08-08 13:44:49 +02:00
|
|
|
#include "../vgeometry/vabstractcubicbezier.h"
|
|
|
|
#include "../vgeometry/vabstractcubicbezierpath.h"
|
|
|
|
#include "../vgeometry/vgeometrydef.h"
|
|
|
|
#include "../vgeometry/vpointf.h"
|
|
|
|
#include "../vgeometry/vspline.h"
|
|
|
|
#include "../vgeometry/vsplinepoint.h"
|
2016-08-09 15:55:46 +02:00
|
|
|
#include "../vmisc/diagnostic.h"
|
2016-08-08 13:44:49 +02:00
|
|
|
#include "../vmisc/logging.h"
|
|
|
|
#include "../vmisc/vabstractapplication.h"
|
|
|
|
#include "../vpatterndb/vcontainer.h"
|
2017-01-16 11:08:13 +01:00
|
|
|
#include "../vpatterndb/vpiecepath.h"
|
|
|
|
#include "../vpatterndb/vpiecenode.h"
|
2016-08-09 15:55:46 +02:00
|
|
|
#include "../dialogs/tools/dialogtool.h"
|
|
|
|
#include "nodeDetails/vnodearc.h"
|
2016-12-20 15:51:58 +01:00
|
|
|
#include "nodeDetails/vnodeellipticalarc.h"
|
2016-08-09 15:55:46 +02:00
|
|
|
#include "nodeDetails/vnodepoint.h"
|
|
|
|
#include "nodeDetails/vnodespline.h"
|
|
|
|
#include "nodeDetails/vnodesplinepath.h"
|
2017-01-16 16:37:15 +01:00
|
|
|
#include "nodeDetails/vtoolpiecepath.h"
|
2017-02-01 12:31:14 +01:00
|
|
|
#include "nodeDetails/vtoolpin.h"
|
2016-08-09 15:55:46 +02:00
|
|
|
#include "vdatatool.h"
|
2016-08-08 13:44:49 +02:00
|
|
|
#include "vnodedetail.h"
|
2017-01-16 11:08:13 +01:00
|
|
|
#include "vtoolseamallowance.h"
|
2016-01-07 17:43:08 +01:00
|
|
|
|
2013-12-29 17:48:57 +01:00
|
|
|
const QString VToolUnionDetails::ToolType = QStringLiteral("unionDetails");
|
|
|
|
const QString VToolUnionDetails::TagDetail = QStringLiteral("det");
|
|
|
|
const QString VToolUnionDetails::TagNode = QStringLiteral("node");
|
2016-01-07 17:43:08 +01:00
|
|
|
const QString VToolUnionDetails::TagChildren = QStringLiteral("children");
|
|
|
|
const QString VToolUnionDetails::TagChild = QStringLiteral("child");
|
2014-01-02 16:50:01 +01:00
|
|
|
const QString VToolUnionDetails::AttrIndexD1 = QStringLiteral("indexD1");
|
|
|
|
const QString VToolUnionDetails::AttrIndexD2 = QStringLiteral("indexD2");
|
2013-12-29 17:48:57 +01:00
|
|
|
const QString VToolUnionDetails::AttrIdObject = QStringLiteral("idObject");
|
|
|
|
const QString VToolUnionDetails::AttrNodeType = QStringLiteral("nodeType");
|
|
|
|
const QString VToolUnionDetails::NodeTypeContour = QStringLiteral("Contour");
|
|
|
|
const QString VToolUnionDetails::NodeTypeModeling = QStringLiteral("Modeling");
|
|
|
|
|
2016-08-06 20:42:40 +02:00
|
|
|
QT_WARNING_PUSH
|
|
|
|
QT_WARNING_DISABLE_CLANG("-Wmissing-prototypes")
|
|
|
|
QT_WARNING_DISABLE_INTEL(1418)
|
2016-01-07 17:43:08 +01:00
|
|
|
|
|
|
|
Q_LOGGING_CATEGORY(vToolUnion, "v.toolUnion")
|
|
|
|
|
2016-08-06 20:42:40 +02:00
|
|
|
QT_WARNING_POP
|
2016-01-07 17:43:08 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
namespace
|
|
|
|
{
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 16:37:15 +01:00
|
|
|
VPiecePath GetPiecePath(int piece, VAbstractPattern *doc, quint32 id)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QDomElement tool = doc->elementById(id);
|
|
|
|
if (tool.isNull())
|
|
|
|
{
|
|
|
|
VException e(QString("Can't get tool by id='%1'.").arg(id));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomNodeList nodesList = tool.childNodes();
|
|
|
|
for (qint32 i = 0; i < nodesList.size(); ++i)
|
|
|
|
{
|
|
|
|
const QDomElement element = nodesList.at(i).toElement();
|
2017-01-18 09:17:18 +01:00
|
|
|
if (not element.isNull() && element.tagName() == VToolUnionDetails::TagDetail && i+1 == piece)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
const QDomNodeList detList = element.childNodes();
|
|
|
|
for (qint32 j = 0; j < detList.size(); ++j)
|
|
|
|
{
|
|
|
|
const QDomElement element = detList.at(j).toElement();
|
2017-01-18 09:17:18 +01:00
|
|
|
if (not element.isNull() && element.tagName() == VAbstractPattern::TagNodes)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
return VAbstractPattern::ParsePieceNodes(element);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return VPiecePath();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
VPiecePath GetPiece1MainPath(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
return GetPiecePath(1, doc, id);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
VPiecePath GetPiece2MainPath(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
return GetPiecePath(2, doc, id);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<CustomSARecord> GetPiece2CSAPaths(VAbstractPattern *doc, quint32 id)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
const QDomElement tool = doc->elementById(id);
|
|
|
|
if (tool.isNull())
|
|
|
|
{
|
|
|
|
VException e(QString("Can't get tool by id='%1'.").arg(id));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomNodeList nodesList = tool.childNodes();
|
|
|
|
for (qint32 i = 0; i < nodesList.size(); ++i)
|
|
|
|
{
|
|
|
|
const QDomElement element = nodesList.at(i).toElement();
|
2017-01-18 09:17:18 +01:00
|
|
|
if (not element.isNull() && element.tagName() == VToolUnionDetails::TagDetail && i+1 == 2)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
const QDomNodeList detList = element.childNodes();
|
|
|
|
for (qint32 j = 0; j < detList.size(); ++j)
|
|
|
|
{
|
|
|
|
const QDomElement element = detList.at(j).toElement();
|
2017-01-18 09:17:18 +01:00
|
|
|
if (not element.isNull() && element.tagName() == VToolSeamAllowance::TagCSA)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
return VAbstractPattern::ParsePieceCSARecords(element);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return QVector<CustomSARecord>();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<quint32> GetPiece2InternalPaths(VAbstractPattern *doc, quint32 id)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
const QDomElement tool = doc->elementById(id);
|
|
|
|
if (tool.isNull())
|
|
|
|
{
|
|
|
|
VException e(QString("Can't get tool by id='%1'.").arg(id));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomNodeList nodesList = tool.childNodes();
|
|
|
|
for (qint32 i = 0; i < nodesList.size(); ++i)
|
|
|
|
{
|
|
|
|
const QDomElement element = nodesList.at(i).toElement();
|
2017-01-18 09:17:18 +01:00
|
|
|
if (not element.isNull() && element.tagName() == VToolUnionDetails::TagDetail && i+1 == 2)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
const QDomNodeList detList = element.childNodes();
|
|
|
|
for (qint32 j = 0; j < detList.size(); ++j)
|
|
|
|
{
|
|
|
|
const QDomElement element = detList.at(j).toElement();
|
2017-01-18 09:17:18 +01:00
|
|
|
if (not element.isNull() && element.tagName() == VToolSeamAllowance::TagIPaths)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
return VAbstractPattern::ParsePieceInternalPaths(element);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return QVector<quint32>();
|
|
|
|
}
|
|
|
|
|
2017-02-01 12:31:14 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QVector<quint32> GetPiece2Pins(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
|
|
|
const QDomElement tool = doc->elementById(id);
|
|
|
|
if (tool.isNull())
|
|
|
|
{
|
|
|
|
VException e(QString("Can't get tool by id='%1'.").arg(id));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomNodeList nodesList = tool.childNodes();
|
|
|
|
for (qint32 i = 0; i < nodesList.size(); ++i)
|
|
|
|
{
|
|
|
|
const QDomElement element = nodesList.at(i).toElement();
|
|
|
|
if (not element.isNull() && element.tagName() == VToolUnionDetails::TagDetail && i+1 == 2)
|
|
|
|
{
|
|
|
|
const QDomNodeList detList = element.childNodes();
|
|
|
|
for (qint32 j = 0; j < detList.size(); ++j)
|
|
|
|
{
|
|
|
|
const QDomElement element = detList.at(j).toElement();
|
|
|
|
if (not element.isNull() && element.tagName() == VToolSeamAllowance::TagPins)
|
|
|
|
{
|
|
|
|
return VAbstractPattern::ParsePiecePins(element);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return QVector<quint32>();
|
|
|
|
}
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QString DrawName(VAbstractPattern *doc, quint32 d1id, quint32 d2id)
|
|
|
|
{
|
|
|
|
const QDomElement detail1 = doc->elementById(d1id);
|
|
|
|
if (detail1.isNull())
|
|
|
|
{
|
|
|
|
return QString();
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomElement detail2 = doc->elementById(d2id);
|
|
|
|
if (detail2.isNull())
|
|
|
|
{
|
|
|
|
return QString();
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomElement draw1 = detail1.parentNode().parentNode().toElement();
|
|
|
|
if (draw1.isNull() || not draw1.hasAttribute(VAbstractPattern::AttrName))
|
|
|
|
{
|
|
|
|
return QString();
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomElement draw2 = detail2.parentNode().parentNode().toElement();
|
|
|
|
if (draw2.isNull() || not draw2.hasAttribute(VAbstractPattern::AttrName))
|
|
|
|
{
|
|
|
|
return QString();
|
|
|
|
}
|
|
|
|
|
|
|
|
const QString draw1Name = draw1.attribute(VAbstractPattern::AttrName);
|
|
|
|
const QString draw2Name = draw2.attribute(VAbstractPattern::AttrName);
|
|
|
|
|
|
|
|
if (draw1Name == draw2Name)
|
|
|
|
{
|
|
|
|
return draw1Name;
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomElement pattern = draw1.parentNode().toElement();
|
|
|
|
if (pattern.isNull())
|
|
|
|
{
|
|
|
|
return QString();
|
|
|
|
}
|
|
|
|
|
|
|
|
int indexD1 = 0;
|
|
|
|
int indexD2 = 0;
|
|
|
|
const QDomNodeList listDraws = pattern.elementsByTagName(VAbstractPattern::TagDraw);
|
|
|
|
for (int i=0; i < listDraws.size(); ++i)
|
|
|
|
{
|
|
|
|
const QDomElement draw = listDraws.at(i).toElement();
|
|
|
|
if (draw == draw1)
|
|
|
|
{
|
|
|
|
indexD1 = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (draw == draw2)
|
|
|
|
{
|
|
|
|
indexD2 = i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (indexD1 >= indexD2)
|
|
|
|
{
|
|
|
|
return draw1Name;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return draw2Name;
|
|
|
|
}
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
2017-01-16 11:08:13 +01:00
|
|
|
* @brief BiasRotatePoint bias and rotate point.
|
|
|
|
* @param point point.
|
|
|
|
* @param dx bias x axis.
|
|
|
|
* @param dy bias y axis.
|
2014-06-13 19:02:41 +02:00
|
|
|
* @param pRotate point rotation.
|
|
|
|
* @param angle angle rotation.
|
|
|
|
*/
|
2017-01-16 16:37:15 +01:00
|
|
|
void BiasRotatePoint(VPointF *point, qreal dx, qreal dy, const QPointF &pRotate, qreal angle)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
point->setX(point->x()+dx);
|
|
|
|
point->setY(point->y()+dy);
|
2017-03-31 16:04:11 +02:00
|
|
|
QLineF line(pRotate, static_cast<QPointF>(*point));
|
2017-01-16 11:08:13 +01:00
|
|
|
line.setAngle(line.angle()+angle);
|
|
|
|
point->setX(line.p2().x());
|
|
|
|
point->setY(line.p2().y());
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
void PointsOnEdge(const VPiecePath &path, quint32 index, VPointF &p1, VPointF &p2, VContainer *data)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
VPieceNode det2p1;
|
|
|
|
VPieceNode det2p2;
|
2017-01-18 09:17:18 +01:00
|
|
|
path.NodeOnEdge(index, det2p1, det2p2);
|
2017-01-16 11:08:13 +01:00
|
|
|
p1 = VPointF(*data->GeometricObject<VPointF>(det2p1.GetId()));
|
|
|
|
p2 = VPointF(*data->GeometricObject<VPointF>(det2p2.GetId()));
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
void UnionInitParameters(const VToolUnionDetailsInitData &initData, const VPiecePath &d1Path, const VPiecePath &d2Path,
|
|
|
|
VPieceNode &det1p1, qreal &dx, qreal &dy, qreal &angle)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
VPieceNode det1p2;
|
2017-01-18 09:17:18 +01:00
|
|
|
d1Path.NodeOnEdge(initData.indexD1, det1p1, det1p2);
|
2017-01-16 11:08:13 +01:00
|
|
|
Q_UNUSED(det1p2)
|
|
|
|
|
|
|
|
VPointF point1;
|
|
|
|
VPointF point2;
|
2017-01-18 09:17:18 +01:00
|
|
|
PointsOnEdge(d1Path, initData.indexD1, point1, point2, initData.data);
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
VPointF point3;
|
|
|
|
VPointF point4;
|
2017-01-18 09:17:18 +01:00
|
|
|
PointsOnEdge(d2Path, initData.indexD2, point3, point4, initData.data);
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
dx = point1.x() - point4.x();
|
|
|
|
dy = point1.y() - point4.y();
|
|
|
|
|
|
|
|
point3.setX(point3.x()+dx);
|
|
|
|
point3.setY(point3.y()+dy);
|
|
|
|
|
|
|
|
point4.setX(point4.x()+dx);
|
|
|
|
point4.setY(point4.y()+dy);
|
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
const QLineF p4p3 = QLineF(static_cast<QPointF>(point4), static_cast<QPointF>(point3));
|
|
|
|
const QLineF p1p2 = QLineF(static_cast<QPointF>(point1), static_cast<QPointF>(point2));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
angle = p4p3.angleTo(p1p2);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 AddNodePoint(const VPieceNode &node, const VToolUnionDetailsInitData &initData, quint32 idTool,
|
|
|
|
QVector<quint32> &children, const QString &drawName, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
QScopedPointer<VPointF> point(new VPointF(*initData.data->GeometricObject<VPointF>(node.GetId())));
|
|
|
|
point->setMode(Draw::Modeling);
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
BiasRotatePoint(point.data(), dx, dy, static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate)),
|
|
|
|
angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
QScopedPointer<VPointF> point1(new VPointF(*point));
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
const quint32 idObject = initData.data->AddGObject(point.take());
|
|
|
|
children.append(idObject);
|
|
|
|
point1->setMode(Draw::Modeling);
|
|
|
|
const quint32 id = initData.data->AddGObject(point1.take());
|
2017-02-01 12:27:38 +01:00
|
|
|
VNodePoint::Create(initData.doc, initData.data, initData.scene, id, idObject, Document::FullParse, Source::FromTool,
|
2017-01-16 11:08:13 +01:00
|
|
|
drawName, idTool);
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
2017-02-01 12:31:14 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 AddPin(quint32 id, const VToolUnionDetailsInitData &initData, quint32 idTool, QVector<quint32> &children,
|
|
|
|
const QString &drawName, qreal dx, qreal dy, quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
QScopedPointer<VPointF> point(new VPointF(*initData.data->GeometricObject<VPointF>(id)));
|
|
|
|
point->setMode(Draw::Modeling);
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
BiasRotatePoint(point.data(), dx, dy, static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate)),
|
|
|
|
angle);
|
2017-02-01 12:31:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
QScopedPointer<VPointF> point1(new VPointF(*point));
|
|
|
|
|
|
|
|
const quint32 idObject = initData.data->AddGObject(point.take());
|
|
|
|
children.append(idObject);
|
|
|
|
point1->setMode(Draw::Modeling);
|
|
|
|
const quint32 idPin = initData.data->AddGObject(point1.take());
|
|
|
|
VToolPin::Create(idPin, idObject, 0, initData.doc, initData.data, Document::FullParse, Source::FromTool, drawName,
|
|
|
|
idTool);
|
|
|
|
return idPin;
|
|
|
|
}
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 AddNodeArc(const VPieceNode &node, const VToolUnionDetailsInitData &initData, quint32 idTool,
|
|
|
|
QVector<quint32> &children, const QString &drawName, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
const QSharedPointer<VArc> arc = initData.data->GeometricObject<VArc>(node.GetId());
|
|
|
|
VPointF p1 = VPointF(arc->GetP1(), "A", 0, 0);
|
|
|
|
VPointF p2 = VPointF(arc->GetP2(), "A", 0, 0);
|
|
|
|
QScopedPointer<VPointF> center(new VPointF(arc->GetCenter()));
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
BiasRotatePoint(&p1, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(center.data(), dx, dy, p, angle);
|
|
|
|
}
|
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
QLineF l1(static_cast<QPointF>(*center), static_cast<QPointF>(p1));
|
|
|
|
QLineF l2(static_cast<QPointF>(*center), static_cast<QPointF>(p2));
|
2017-01-16 11:08:13 +01:00
|
|
|
center->setMode(Draw::Modeling);
|
|
|
|
VPointF *tmpCenter = center.take();
|
|
|
|
const quint32 idCenter = initData.data->AddGObject(tmpCenter);
|
|
|
|
Q_UNUSED(idCenter)
|
|
|
|
QScopedPointer<VArc> arc1(new VArc(*tmpCenter, arc->GetRadius(), arc->GetFormulaRadius(), l1.angle(),
|
|
|
|
QString().setNum(l1.angle()), l2.angle(), QString().setNum(l2.angle())));
|
|
|
|
arc1->setMode(Draw::Modeling);
|
|
|
|
|
|
|
|
QScopedPointer<VArc>arc2(new VArc(*arc1));
|
|
|
|
|
|
|
|
const quint32 idObject = initData.data->AddGObject(arc1.take());
|
|
|
|
children.append(idObject);
|
|
|
|
|
|
|
|
arc2->setMode(Draw::Modeling);
|
|
|
|
const quint32 id = initData.data->AddGObject(arc2.take());
|
|
|
|
|
2017-02-01 12:27:38 +01:00
|
|
|
VNodeArc::Create(initData.doc, initData.data, id, idObject, Document::FullParse, Source::FromTool, drawName,
|
|
|
|
idTool);
|
2017-01-16 11:08:13 +01:00
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 AddNodeElArc(const VPieceNode &node, const VToolUnionDetailsInitData &initData, quint32 idTool,
|
|
|
|
QVector<quint32> &children, const QString &drawName, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
const QSharedPointer<VEllipticalArc> arc = initData.data->GeometricObject<VEllipticalArc>(node.GetId());
|
|
|
|
VPointF p1 = VPointF(arc->GetP1(), "A", 0, 0);
|
|
|
|
VPointF p2 = VPointF(arc->GetP2(), "A", 0, 0);
|
|
|
|
QScopedPointer<VPointF> center(new VPointF(arc->GetCenter()));
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
BiasRotatePoint(&p1, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(center.data(), dx, dy, p, angle);
|
|
|
|
}
|
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
QLineF l1(static_cast<QPointF>(*center), static_cast<QPointF>(p1));
|
|
|
|
QLineF l2(static_cast<QPointF>(*center), static_cast<QPointF>(p2));
|
2017-01-16 11:08:13 +01:00
|
|
|
center->setMode(Draw::Modeling);
|
|
|
|
VPointF *tmpCenter = center.take();
|
|
|
|
quint32 idCenter = initData.data->AddGObject(tmpCenter);
|
|
|
|
Q_UNUSED(idCenter)
|
|
|
|
QScopedPointer<VEllipticalArc> arc1(new VEllipticalArc (*tmpCenter, arc->GetRadius1(), arc->GetRadius2(),
|
|
|
|
arc->GetFormulaRadius1(), arc->GetFormulaRadius2(),
|
|
|
|
l1.angle(), QString().setNum(l1.angle()), l2.angle(),
|
|
|
|
QString().setNum(l2.angle()), 0, "0"));
|
|
|
|
arc1->setMode(Draw::Modeling);
|
|
|
|
|
|
|
|
QScopedPointer<VEllipticalArc> arc2(new VEllipticalArc(*arc1));
|
|
|
|
|
|
|
|
const quint32 idObject = initData.data->AddGObject(arc1.take());
|
|
|
|
children.append(idObject);
|
|
|
|
|
|
|
|
arc2->setMode(Draw::Modeling);
|
|
|
|
const quint32 id = initData.data->AddGObject(arc2.take());
|
|
|
|
|
2017-02-01 12:27:38 +01:00
|
|
|
VNodeEllipticalArc::Create(initData.doc, initData.data, id, idObject, Document::FullParse, Source::FromTool,
|
2017-01-16 11:08:13 +01:00
|
|
|
drawName, idTool);
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 AddNodeSpline(const VPieceNode &node, const VToolUnionDetailsInitData &initData, quint32 idTool,
|
|
|
|
QVector<quint32> &children, const QString &drawName, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
const QSharedPointer<VAbstractCubicBezier> spline =
|
|
|
|
initData.data->GeometricObject<VAbstractCubicBezier>(node.GetId());
|
|
|
|
|
|
|
|
QScopedPointer<VPointF> p1(new VPointF(spline->GetP1()));
|
|
|
|
VPointF p2 = VPointF(spline->GetP2());
|
|
|
|
VPointF p3 = VPointF(spline->GetP3());
|
|
|
|
QScopedPointer<VPointF> p4(new VPointF(spline->GetP4()));
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
BiasRotatePoint(p1.data(), dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p3, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(p4.data(), dx, dy, p, angle);
|
|
|
|
}
|
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
VSpline *spl = new VSpline(*p1, static_cast<QPointF>(p2), static_cast<QPointF>(p3), *p4, 0, Draw::Modeling);
|
2017-01-16 11:08:13 +01:00
|
|
|
const quint32 idObject = initData.data->AddGObject(spl);
|
|
|
|
children.append(idObject);
|
|
|
|
|
|
|
|
VSpline *spl1 = new VSpline(*spl);
|
|
|
|
spl1->setMode(Draw::Modeling);
|
|
|
|
const quint32 id = initData.data->AddGObject(spl1);
|
2017-02-01 12:27:38 +01:00
|
|
|
VNodeSpline::Create(initData.doc, initData.data, id, idObject, Document::FullParse, Source::FromTool, drawName,
|
2017-01-16 11:08:13 +01:00
|
|
|
idTool);
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 AddNodeSplinePath(const VPieceNode &node, const VToolUnionDetailsInitData &initData, quint32 idTool,
|
|
|
|
QVector<quint32> &children, const QString &drawName, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
QScopedPointer<VSplinePath> path(new VSplinePath());
|
|
|
|
path->setMode(Draw::Modeling);
|
|
|
|
const QSharedPointer<VAbstractCubicBezierPath> splinePath =
|
|
|
|
initData.data->GeometricObject<VAbstractCubicBezierPath>(node.GetId());
|
|
|
|
for (qint32 i = 1; i <= splinePath->CountSubSpl(); ++i)
|
|
|
|
{
|
|
|
|
const VSpline spline = splinePath->GetSpline(i);
|
|
|
|
|
|
|
|
QScopedPointer<VPointF> p1(new VPointF(spline.GetP1()));
|
|
|
|
VPointF p2 = VPointF(spline.GetP2());
|
|
|
|
VPointF p3 = VPointF(spline.GetP3());
|
|
|
|
QScopedPointer<VPointF> p4(new VPointF(spline.GetP4()));
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
2014-01-02 16:50:01 +01:00
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate));
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
BiasRotatePoint(p1.data(), dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p3, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(p4.data(), dx, dy, p, angle);
|
|
|
|
}
|
2016-08-08 16:34:50 +02:00
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
VSpline spl = VSpline(*p1, static_cast<QPointF>(p2), static_cast<QPointF>(p3), *p4);
|
2017-01-16 11:08:13 +01:00
|
|
|
if (i==1)
|
|
|
|
{
|
|
|
|
const qreal angle1 = spl.GetStartAngle()+180;
|
|
|
|
const QString angle1F = QString().number(angle1);
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
path->append(VSplinePoint(*p1, angle1, angle1F, spl.GetStartAngle(), spl.GetStartAngleFormula(),
|
|
|
|
0, "0", spline.GetC1Length(), spline.GetC1LengthFormula()));
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
const qreal angle2 = spl.GetEndAngle()+180;
|
|
|
|
const QString angle2F = QString().number(angle2);
|
|
|
|
qreal pL2 = 0;
|
|
|
|
QString pL2F("0");
|
|
|
|
if (i+1 <= splinePath->CountSubSpl())
|
2016-12-20 15:51:58 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const VSpline nextSpline = splinePath->GetSpline(i+1);
|
|
|
|
pL2 = nextSpline.GetC1Length();
|
|
|
|
pL2F = nextSpline.GetC1LengthFormula();
|
|
|
|
}
|
2016-12-20 15:51:58 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
path->append(VSplinePoint(*p4, spl.GetEndAngle(), spl.GetEndAngleFormula(), angle2, angle2F,
|
|
|
|
spline.GetC2Length(), spline.GetC2LengthFormula(), pL2, pL2F));
|
|
|
|
}
|
|
|
|
QScopedPointer<VSplinePath> path1(new VSplinePath(*path));
|
2016-12-20 15:51:58 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
const quint32 idObject = initData.data->AddGObject(path.take());
|
|
|
|
children.append(idObject);
|
2016-12-20 15:51:58 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
path1->setMode(Draw::Modeling);
|
|
|
|
const quint32 id = initData.data->AddGObject(path1.take());
|
|
|
|
|
2017-02-01 12:27:38 +01:00
|
|
|
VNodeSplinePath::Create(initData.doc, initData.data, id, idObject, Document::FullParse, Source::FromTool, drawName,
|
2017-01-16 11:08:13 +01:00
|
|
|
idTool);
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief AddToNewDetail create united detail adding one node per time.
|
|
|
|
*/
|
2017-03-24 13:48:07 +01:00
|
|
|
void AddNodeToNewPath(const VToolUnionDetailsInitData &initData, VPiecePath &newPath, VPieceNode node,
|
2017-01-16 16:37:15 +01:00
|
|
|
quint32 idTool, QVector<quint32> &children, const QString &drawName, qreal dx = 0, qreal dy = 0,
|
|
|
|
quint32 pRotate = NULL_ID, qreal angle = 0);
|
2017-01-16 11:08:13 +01:00
|
|
|
|
2017-03-24 13:48:07 +01:00
|
|
|
void AddNodeToNewPath(const VToolUnionDetailsInitData &initData, VPiecePath &newPath, VPieceNode node,
|
2017-01-16 16:37:15 +01:00
|
|
|
quint32 idTool, QVector<quint32> &children, const QString &drawName, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
quint32 id = 0;
|
|
|
|
switch (node.GetTypeTool())
|
|
|
|
{
|
|
|
|
case (Tool::NodePoint):
|
|
|
|
id = AddNodePoint(node, initData, idTool, children, drawName, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
case (Tool::NodeArc):
|
|
|
|
id = AddNodeArc(node, initData, idTool, children, drawName, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
case (Tool::NodeElArc):
|
|
|
|
id = AddNodeElArc(node, initData, idTool, children, drawName, dx, dy, pRotate, angle);
|
|
|
|
break;
|
2014-06-12 09:22:29 +02:00
|
|
|
case (Tool::NodeSpline):
|
2017-01-16 16:37:15 +01:00
|
|
|
id = AddNodeSpline(node, initData, idTool, children, drawName, dx, dy, pRotate, angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
break;
|
|
|
|
case (Tool::NodeSplinePath):
|
|
|
|
id = AddNodeSplinePath(node, initData, idTool, children, drawName, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
qDebug()<<"May be wrong tool type!!! Ignoring."<<Q_FUNC_INFO;
|
|
|
|
break;
|
|
|
|
}
|
2017-03-21 16:18:48 +01:00
|
|
|
|
2017-03-24 13:48:07 +01:00
|
|
|
node.SetId(id);
|
|
|
|
newPath.Append(node);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void FindIndexJ(qint32 pointsD2, const VPiecePath &d2Path, quint32 indexD2, qint32 &j)
|
|
|
|
{
|
|
|
|
if (pointsD2 == 0)
|
|
|
|
{
|
|
|
|
VPieceNode node1;
|
|
|
|
VPieceNode node2;
|
|
|
|
d2Path.NodeOnEdge(indexD2, node1, node2);
|
|
|
|
const VPiecePath removedD2 = d2Path.RemoveEdge(indexD2);
|
|
|
|
const int k = removedD2.indexOfNode(node2.GetId());
|
|
|
|
SCASSERT(k != -1)
|
|
|
|
if (k == removedD2.CountNodes()-1)
|
|
|
|
{//We have last node in detail, we wil begin from 0
|
|
|
|
j = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{// Continue from next node
|
|
|
|
j = k+1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 16:37:15 +01:00
|
|
|
QDomElement GetTagChildren(VAbstractPattern *doc, quint32 id)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
QDomElement toolUnion = doc->elementById(id);
|
|
|
|
if (toolUnion.isNull())
|
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
VException e(QString("Can't get tool by id='%1'.").arg(id));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
QDomElement tagChildren = toolUnion.firstChildElement(VToolUnionDetails::TagChildren);
|
|
|
|
|
|
|
|
if (tagChildren.isNull())
|
|
|
|
{
|
|
|
|
tagChildren = doc->createElement(VToolUnionDetails::TagChildren);
|
|
|
|
toolUnion.appendChild(tagChildren);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
return tagChildren;
|
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void SaveChildren(VAbstractPattern *doc, quint32 id, QDomElement section, const QVector<quint32> &children)
|
|
|
|
{
|
2017-02-01 11:22:36 +01:00
|
|
|
if (children.size() > 0)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
2017-02-01 11:22:36 +01:00
|
|
|
for (int i=0; i<children.size(); ++i)
|
|
|
|
{
|
|
|
|
QDomElement tagChild = doc->createElement(VToolUnionDetails::TagChild);
|
|
|
|
tagChild.appendChild(doc->createTextNode(QString().setNum(children.at(i))));
|
|
|
|
section.appendChild(tagChild);
|
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
|
2017-02-01 11:22:36 +01:00
|
|
|
GetTagChildren(doc, id).appendChild(section);
|
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 16:37:15 +01:00
|
|
|
void SaveNodesChildren(VAbstractPattern *doc, quint32 id, const QVector<quint32> &children)
|
|
|
|
{
|
|
|
|
SaveChildren(doc, id, doc->createElement(VAbstractPattern::TagNodes), children);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void SaveCSAChildren(VAbstractPattern *doc, quint32 id, const QVector<quint32> &children)
|
|
|
|
{
|
|
|
|
SaveChildren(doc, id, doc->createElement(VToolSeamAllowance::TagCSA), children);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void SaveInternalPathsChildren(VAbstractPattern *doc, quint32 id, const QVector<quint32> &children)
|
|
|
|
{
|
|
|
|
SaveChildren(doc, id, doc->createElement(VToolSeamAllowance::TagIPaths), children);
|
|
|
|
}
|
|
|
|
|
2017-02-01 12:31:14 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void SavePinsChildren(VAbstractPattern *doc, quint32 id, const QVector<quint32> &children)
|
|
|
|
{
|
|
|
|
SaveChildren(doc, id, doc->createElement(VToolSeamAllowance::TagPins), children);
|
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QVector<quint32> GetChildren(VAbstractPattern *doc, quint32 id, const QString &tagName)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
const QDomElement toolUnion = doc->elementById(id);
|
|
|
|
if (toolUnion.isNull())
|
|
|
|
{
|
|
|
|
return QVector<quint32>();
|
|
|
|
}
|
|
|
|
|
|
|
|
const QDomElement tagChildren = toolUnion.firstChildElement(VToolUnionDetails::TagChildren);
|
|
|
|
if (tagChildren.isNull())
|
|
|
|
{
|
|
|
|
return QVector<quint32>();
|
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
const QDomElement tagNodes = tagChildren.firstChildElement(tagName);
|
2017-01-16 11:08:13 +01:00
|
|
|
if (tagNodes.isNull())
|
|
|
|
{
|
|
|
|
return QVector<quint32>();
|
|
|
|
}
|
|
|
|
|
|
|
|
QVector<quint32> childrenId;
|
|
|
|
const QDomNodeList listChildren = tagNodes.elementsByTagName(VToolUnionDetails::TagChild);
|
|
|
|
for (int i=0; i < listChildren.size(); ++i)
|
|
|
|
{
|
|
|
|
const QDomElement domElement = listChildren.at(i).toElement();
|
|
|
|
if (not domElement.isNull())
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
childrenId.append(domElement.text().toUInt());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return childrenId;
|
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QVector<quint32> GetNodesChildren(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
|
|
|
return GetChildren(doc, id, VAbstractPattern::TagNodes);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QVector<quint32> GetCSAChildren(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
|
|
|
return GetChildren(doc, id, VToolSeamAllowance::TagCSA);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QVector<quint32> GetInternalPathsChildren(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
|
|
|
return GetChildren(doc, id, VToolSeamAllowance::TagIPaths);
|
|
|
|
}
|
|
|
|
|
2017-02-01 12:31:14 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QVector<quint32> GetPinChildren(VAbstractPattern *doc, quint32 id)
|
|
|
|
{
|
|
|
|
return GetChildren(doc, id, VToolSeamAllowance::TagPins);
|
|
|
|
}
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
quint32 TakeNextId(QVector<quint32> &children)
|
|
|
|
{
|
|
|
|
quint32 idChild = NULL_ID;
|
|
|
|
if (not children.isEmpty())
|
|
|
|
{
|
|
|
|
idChild = children.takeFirst();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
idChild = NULL_ID;
|
|
|
|
}
|
|
|
|
return idChild;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateNodePoint(VContainer *data, const VPieceNode &node, QVector<quint32> &children, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
QScopedPointer<VPointF> point(new VPointF(*data->GeometricObject<VPointF>(node.GetId())));
|
|
|
|
point->setMode(Draw::Modeling);
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
BiasRotatePoint(point.data(), dx, dy, static_cast<QPointF>(*data->GeometricObject<VPointF>(pRotate)), angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
data->UpdateGObject(TakeNextId(children), point.take());
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateNodeArc(VContainer *data, const VPieceNode &node, QVector<quint32> &children, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
const QSharedPointer<VArc> arc = data->GeometricObject<VArc>(node.GetId());
|
|
|
|
VPointF p1 = VPointF(arc->GetP1());
|
|
|
|
VPointF p2 = VPointF(arc->GetP2());
|
|
|
|
QScopedPointer<VPointF> center(new VPointF(arc->GetCenter()));
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*data->GeometricObject<VPointF>(pRotate));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
BiasRotatePoint(&p1, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(center.data(), dx, dy, p, angle);
|
|
|
|
}
|
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
QLineF l1(static_cast<QPointF>(*center), static_cast<QPointF>(p1));
|
|
|
|
QLineF l2(static_cast<QPointF>(*center), static_cast<QPointF>(p2));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
QScopedPointer<VArc> arc1(new VArc(*center, arc->GetRadius(), arc->GetFormulaRadius(), l1.angle(),
|
|
|
|
QString().setNum(l1.angle()), l2.angle(), QString().setNum(l2.angle())));
|
|
|
|
arc1->setMode(Draw::Modeling);
|
|
|
|
data->UpdateGObject(TakeNextId(children), arc1.take());
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateNodeElArc(VContainer *data, const VPieceNode &node, QVector<quint32> &children, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
const QSharedPointer<VEllipticalArc> arc = data->GeometricObject<VEllipticalArc>(node.GetId());
|
|
|
|
VPointF p1 = VPointF(arc->GetP1());
|
|
|
|
VPointF p2 = VPointF(arc->GetP2());
|
|
|
|
QScopedPointer<VPointF> center(new VPointF(arc->GetCenter()));
|
|
|
|
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*data->GeometricObject<VPointF>(pRotate));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
BiasRotatePoint(&p1, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(center.data(), dx, dy, p, angle);
|
|
|
|
}
|
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
QLineF l1(static_cast<QPointF>(*center), static_cast<QPointF>(p1));
|
|
|
|
QLineF l2(static_cast<QPointF>(*center), static_cast<QPointF>(p2));
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
QScopedPointer<VEllipticalArc> arc1(new VEllipticalArc (*center, arc->GetRadius1(), arc->GetRadius2(),
|
|
|
|
arc->GetFormulaRadius1(), arc->GetFormulaRadius2(),
|
|
|
|
l1.angle(), QString().setNum(l1.angle()), l2.angle(),
|
|
|
|
QString().setNum(l2.angle()), 0, "0"));
|
|
|
|
arc1->setMode(Draw::Modeling);
|
|
|
|
data->UpdateGObject(TakeNextId(children), arc1.take());
|
|
|
|
}
|
2014-01-02 16:50:01 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateNodeSpline(VContainer *data, const VPieceNode &node, QVector<quint32> &children, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
const QSharedPointer<VAbstractCubicBezier> spline =
|
|
|
|
data->GeometricObject<VAbstractCubicBezier>(node.GetId());
|
2014-01-02 16:50:01 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
QScopedPointer<VPointF> p1(new VPointF(spline->GetP1()));
|
|
|
|
VPointF p2 = VPointF(spline->GetP2());
|
|
|
|
VPointF p3 = VPointF(spline->GetP3());
|
|
|
|
QScopedPointer<VPointF> p4(new VPointF(spline->GetP4()));
|
2016-08-08 16:34:50 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*data->GeometricObject<VPointF>(pRotate));
|
2014-01-02 16:50:01 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
BiasRotatePoint(p1.data(), dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p3, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(p4.data(), dx, dy, p, angle);
|
|
|
|
}
|
2014-01-02 16:50:01 +01:00
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
QScopedPointer<VSpline> spl(new VSpline(*p1, static_cast<QPointF>(p2), static_cast<QPointF>(p3), *p4, 0,
|
|
|
|
Draw::Modeling));
|
2017-01-16 11:08:13 +01:00
|
|
|
data->UpdateGObject(TakeNextId(children), spl.take());
|
|
|
|
}
|
2013-12-29 17:48:57 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateNodeSplinePath(VContainer *data, const VPieceNode &node, QVector<quint32> &children, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
QScopedPointer<VSplinePath> path(new VSplinePath());
|
|
|
|
path->setMode(Draw::Modeling);
|
|
|
|
const QSharedPointer<VAbstractCubicBezierPath> splinePath =
|
|
|
|
data->GeometricObject<VAbstractCubicBezierPath>(node.GetId());
|
|
|
|
SCASSERT(splinePath != nullptr)
|
|
|
|
for (qint32 i = 1; i <= splinePath->CountSubSpl(); ++i)
|
|
|
|
{
|
|
|
|
const VSpline spline = splinePath->GetSpline(i);
|
2016-08-08 16:34:50 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
QScopedPointer<VPointF> p1(new VPointF(spline.GetP1()));
|
|
|
|
VPointF p2 = VPointF(spline.GetP2());
|
|
|
|
VPointF p3 = VPointF(spline.GetP3());
|
|
|
|
QScopedPointer<VPointF> p4(new VPointF(spline.GetP4()));
|
2013-12-29 17:48:57 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
const QPointF p = static_cast<QPointF>(*data->GeometricObject<VPointF>(pRotate));
|
2016-03-04 17:08:29 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
BiasRotatePoint(p1.data(), dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p2, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(&p3, dx, dy, p, angle);
|
|
|
|
BiasRotatePoint(p4.data(), dx, dy, p, angle);
|
|
|
|
}
|
2016-03-04 17:08:29 +01:00
|
|
|
|
2017-03-31 16:04:11 +02:00
|
|
|
VSpline spl = VSpline(*p1, static_cast<QPointF>(p2), static_cast<QPointF>(p3), *p4);
|
2017-01-16 11:08:13 +01:00
|
|
|
if (i==1)
|
|
|
|
{
|
|
|
|
const qreal angle1 = spl.GetStartAngle()+180;
|
|
|
|
const QString angle1F = QString().number(angle1);
|
2016-03-04 17:08:29 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
path->append(VSplinePoint(*p1, angle1, angle1F, spl.GetStartAngle(), spl.GetStartAngleFormula(),
|
|
|
|
0, "0", spline.GetC1Length(), spline.GetC1LengthFormula()));
|
|
|
|
}
|
2016-03-04 17:08:29 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
const qreal angle2 = spl.GetEndAngle()+180;
|
|
|
|
const QString angle2F = QString().number(angle2);
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
qreal pL2 = 0;
|
|
|
|
QString pL2F("0");
|
|
|
|
if (i+1 <= splinePath->CountSubSpl())
|
|
|
|
{
|
|
|
|
const VSpline nextSpline = splinePath->GetSpline(i+1);
|
|
|
|
pL2 = nextSpline.GetC1Length();
|
|
|
|
pL2F = nextSpline.GetC1LengthFormula();
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
path->append(VSplinePoint(*p4, spl.GetEndAngle(), spl.GetEndAngleFormula(), angle2, angle2F,
|
|
|
|
spline.GetC2Length(), spline.GetC2LengthFormula(), pL2, pL2F));
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
data->UpdateGObject(TakeNextId(children), path.take());
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
2017-01-16 11:08:13 +01:00
|
|
|
* @brief UpdateNodes update nodes of united detail.
|
2014-06-13 19:02:41 +02:00
|
|
|
* @param data container with variables.
|
2017-01-27 13:07:12 +01:00
|
|
|
* @param node detail's node.
|
2016-01-07 17:43:08 +01:00
|
|
|
* @param children list ids of all children.
|
2014-06-13 19:02:41 +02:00
|
|
|
* @param dx bias node x axis.
|
|
|
|
* @param dy bias node y axis.
|
|
|
|
* @param pRotate point rotation.
|
|
|
|
* @param angle angle rotation.
|
|
|
|
*/
|
2017-01-16 16:37:15 +01:00
|
|
|
void UpdatePathNode(VContainer *data, const VPieceNode &node, QVector<quint32> &children,
|
2017-01-16 11:08:13 +01:00
|
|
|
qreal dx = 0, qreal dy = 0, quint32 pRotate = NULL_ID, qreal angle = 0);
|
2017-01-16 16:37:15 +01:00
|
|
|
void UpdatePathNode(VContainer *data, const VPieceNode &node, QVector<quint32> &children, qreal dx, qreal dy,
|
2017-01-16 11:08:13 +01:00
|
|
|
quint32 pRotate, qreal angle)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
switch (node.GetTypeTool())
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2014-06-12 09:22:29 +02:00
|
|
|
case (Tool::NodePoint):
|
2017-01-16 11:08:13 +01:00
|
|
|
UpdateNodePoint(data, node, children, dx, dy, pRotate, angle);
|
|
|
|
break;
|
2014-06-12 09:22:29 +02:00
|
|
|
case (Tool::NodeArc):
|
2017-01-16 11:08:13 +01:00
|
|
|
UpdateNodeArc(data, node, children, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
case (Tool::NodeElArc):
|
|
|
|
UpdateNodeElArc(data, node, children, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
case (Tool::NodeSpline):
|
|
|
|
UpdateNodeSpline(data, node, children, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
case (Tool::NodeSplinePath):
|
|
|
|
UpdateNodeSplinePath(data, node, children, dx, dy, pRotate, angle);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
qDebug()<<"May be wrong tool type!!! Ignoring."<<Q_FUNC_INFO;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 16:37:15 +01:00
|
|
|
void CreateUnitedNodes(VPiece &newDetail, const VPiece &d1, const VPiece &d2, quint32 id, const QString &drawName,
|
|
|
|
const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate, qreal angle)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
|
|
|
const VPiecePath d1Path = d1.GetPath().RemoveEdge(initData.indexD1);
|
|
|
|
const VPiecePath d2Path = d2.GetPath().RemoveEdge(initData.indexD2);
|
2015-03-31 12:39:10 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
const qint32 countNodeD1 = d1Path.CountNodes();
|
|
|
|
const qint32 countNodeD2 = d2Path.CountNodes();
|
2016-12-20 15:51:58 +01:00
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
qint32 pointsD2 = 0; //Keeps number points the second detail, what we have already added.
|
2017-01-16 11:08:13 +01:00
|
|
|
qint32 i = 0;
|
|
|
|
QVector<quint32> children;
|
2017-01-16 16:37:15 +01:00
|
|
|
VPiecePath newPath;
|
|
|
|
const int det1P1Index = d1.GetPath().indexOfNode(pRotate);
|
2017-01-16 11:08:13 +01:00
|
|
|
do
|
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
AddNodeToNewPath(initData, newPath, d1Path.at(i), id, children, drawName);
|
2017-01-16 11:08:13 +01:00
|
|
|
++i;
|
|
|
|
if (i > det1P1Index && pointsD2 < countNodeD2-1)
|
|
|
|
{
|
|
|
|
qint32 j = 0;
|
|
|
|
FindIndexJ(pointsD2, d2.GetPath(), initData.indexD2, j);
|
|
|
|
do
|
2016-12-20 15:51:58 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
if (j >= countNodeD2)
|
|
|
|
{
|
|
|
|
j=0;
|
|
|
|
}
|
2017-01-16 16:37:15 +01:00
|
|
|
AddNodeToNewPath(initData, newPath, d2Path.at(j), id, children, drawName, dx, dy, pRotate, angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
++pointsD2;
|
|
|
|
++j;
|
|
|
|
} while (pointsD2 < countNodeD2-1);
|
|
|
|
}
|
|
|
|
} while (i < countNodeD1);
|
2016-12-20 15:51:58 +01:00
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
newDetail.SetPath(newPath);
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
SCASSERT(not children.isEmpty())
|
|
|
|
SaveNodesChildren(initData.doc, id, children);
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
2016-12-20 15:51:58 +01:00
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void CreateUnitedDetailCSA(VPiece &newDetail, const VPiece &d, QVector<quint32> &children, quint32 id,
|
|
|
|
const QString &drawName, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<quint32> nodeChildren;
|
2017-01-31 15:26:28 +01:00
|
|
|
for(int i=0; i < d.GetCustomSARecords().size(); ++i)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
2017-01-31 15:26:28 +01:00
|
|
|
CustomSARecord record = d.GetCustomSARecords().at(i);
|
2017-01-16 16:37:15 +01:00
|
|
|
const VPiecePath path = initData.data->GetPiecePath(record.path);
|
|
|
|
VPiecePath newPath = path;
|
|
|
|
newPath.Clear();//Clear nodes
|
|
|
|
for (int i=0; i < path.CountNodes(); ++i)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
AddNodeToNewPath(initData, newPath, path.at(i), id, nodeChildren, drawName, dx, dy, pRotate, angle);
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
2017-01-18 09:17:18 +01:00
|
|
|
const quint32 idPath = initData.data->AddPiecePath(newPath);
|
|
|
|
VToolPiecePath::Create(idPath, newPath, NULL_ID, initData.scene, initData.doc, initData.data, initData.parse,
|
|
|
|
Source::FromTool, drawName, id);
|
|
|
|
record.path = idPath;
|
2017-01-31 15:26:28 +01:00
|
|
|
newDetail.GetCustomSARecords().append(record);
|
2017-01-18 09:17:18 +01:00
|
|
|
nodeChildren.prepend(idPath);
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
2017-01-18 09:17:18 +01:00
|
|
|
children += nodeChildren;
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
2013-12-29 17:48:57 +01:00
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void CreateUnitedCSA(VPiece &newDetail, const VPiece &d1, const VPiece &d2, quint32 id, const QString &drawName,
|
|
|
|
const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate, qreal angle)
|
|
|
|
{
|
2017-01-31 15:26:28 +01:00
|
|
|
for (int i = 0; i < d1.GetCustomSARecords().size(); ++i)
|
2017-01-18 09:17:18 +01:00
|
|
|
{
|
2017-01-31 15:26:28 +01:00
|
|
|
newDetail.GetCustomSARecords().append(d1.GetCustomSARecords().at(i));
|
2017-01-18 09:17:18 +01:00
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
QVector<quint32> children;
|
|
|
|
CreateUnitedDetailCSA(newDetail, d2, children, id, drawName, initData, dx, dy, pRotate, angle);
|
|
|
|
SaveCSAChildren(initData.doc, id, children);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void CreateUnitedDetailInternalPaths(VPiece &newDetail, const VPiece &d, QVector<quint32> &children, quint32 id,
|
|
|
|
const QString &drawName, const VToolUnionDetailsInitData &initData, qreal dx,
|
|
|
|
qreal dy, quint32 pRotate, qreal angle)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<quint32> nodeChildren;
|
2017-01-31 15:26:28 +01:00
|
|
|
for(int i=0; i < d.GetInternalPaths().size(); ++i)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
2017-01-31 15:26:28 +01:00
|
|
|
const VPiecePath path = initData.data->GetPiecePath(d.GetInternalPaths().at(i));
|
2017-01-16 16:37:15 +01:00
|
|
|
VPiecePath newPath = path;
|
|
|
|
newPath.Clear();//Clear nodes
|
|
|
|
|
|
|
|
for (int i=0; i < path.CountNodes(); ++i)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
AddNodeToNewPath(initData, newPath, path.at(i), id, nodeChildren, drawName, dx, dy, pRotate, angle);
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
2017-01-18 09:17:18 +01:00
|
|
|
const quint32 idPath = initData.data->AddPiecePath(newPath);
|
|
|
|
VToolPiecePath::Create(idPath, newPath, NULL_ID, initData.scene, initData.doc, initData.data, initData.parse,
|
|
|
|
Source::FromTool, drawName, id);
|
2017-01-31 15:26:28 +01:00
|
|
|
newDetail.GetInternalPaths().append(idPath);
|
2017-01-18 09:17:18 +01:00
|
|
|
nodeChildren.prepend(idPath);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
2017-01-18 09:17:18 +01:00
|
|
|
children += nodeChildren;
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
2014-01-02 16:50:01 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 16:37:15 +01:00
|
|
|
void CreateUnitedInternalPaths(VPiece &newDetail, const VPiece &d1, const VPiece &d2, quint32 id,
|
|
|
|
const QString &drawName, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
2017-01-31 15:26:28 +01:00
|
|
|
for (int i = 0; i < d1.GetInternalPaths().size(); ++i)
|
2017-01-18 09:17:18 +01:00
|
|
|
{
|
2017-01-31 15:26:28 +01:00
|
|
|
newDetail.GetInternalPaths().append(d1.GetInternalPaths().at(i));
|
2017-01-18 09:17:18 +01:00
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
QVector<quint32> children;
|
|
|
|
CreateUnitedDetailInternalPaths(newDetail, d2, children, id, drawName, initData, dx, dy, pRotate, angle);
|
|
|
|
|
|
|
|
SaveInternalPathsChildren(initData.doc, id, children);
|
|
|
|
}
|
|
|
|
|
2017-02-01 12:31:14 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void CreateUnitedDetailPins(VPiece &newDetail, const VPiece &d, QVector<quint32> &children, quint32 idTool,
|
|
|
|
const QString &drawName, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
QVector<quint32> nodeChildren;
|
|
|
|
for(int i=0; i < d.GetPins().size(); ++i)
|
|
|
|
{
|
|
|
|
const quint32 id = AddPin(d.GetPins().at(i), initData, idTool, children, drawName, dx, dy, pRotate, angle);
|
|
|
|
newDetail.GetPins().append(id);
|
|
|
|
nodeChildren.prepend(id);
|
|
|
|
}
|
|
|
|
children += nodeChildren;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void CreateUnitedPins(VPiece &newDetail, const VPiece &d1, const VPiece &d2, quint32 id, const QString &drawName,
|
|
|
|
const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate, qreal angle)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < d1.GetPins().size(); ++i)
|
|
|
|
{
|
|
|
|
newDetail.GetPins().append(d1.GetPins().at(i));
|
|
|
|
}
|
|
|
|
|
|
|
|
QVector<quint32> children;
|
|
|
|
CreateUnitedDetailPins(newDetail, d2, children, id, drawName, initData, dx, dy, pRotate, angle);
|
|
|
|
SavePinsChildren(initData.doc, id, children);
|
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateUnitedNodes(quint32 id, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate,
|
|
|
|
qreal angle)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
const VPiecePath d1Path = GetPiece1MainPath(initData.doc, id);
|
2017-01-16 11:08:13 +01:00
|
|
|
const VPiecePath d1REPath = d1Path.RemoveEdge(initData.indexD1);
|
2016-08-08 16:34:50 +02:00
|
|
|
|
2017-01-18 09:17:18 +01:00
|
|
|
const VPiecePath d2Path = GetPiece2MainPath(initData.doc, id);
|
2017-01-16 11:08:13 +01:00
|
|
|
const VPiecePath d2REPath = d2Path.RemoveEdge(initData.indexD2);
|
2016-07-06 12:34:05 +02:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
const qint32 countNodeD1 = d1REPath.CountNodes();
|
|
|
|
const qint32 countNodeD2 = d2REPath.CountNodes();
|
|
|
|
|
|
|
|
QVector<quint32> children = GetNodesChildren(initData.doc, id);
|
|
|
|
if (not children.isEmpty())
|
|
|
|
{
|
|
|
|
// This check need for backward compatibility
|
|
|
|
// Remove check and "else" part if min version is 0.3.2
|
|
|
|
Q_STATIC_ASSERT_X(VPatternConverter::PatternMinVer < CONVERTER_VERSION_CHECK(0, 3, 2),
|
|
|
|
"Time to refactor the code.");
|
|
|
|
if (children.size() == countNodeD1 + countNodeD2-1)
|
2014-01-02 16:50:01 +01:00
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
qint32 pointsD2 = 0; //Keeps number points the second detail, what we have already added.
|
2017-01-16 11:08:13 +01:00
|
|
|
qint32 i = 0;
|
2017-01-16 16:37:15 +01:00
|
|
|
const int indexOfNode = d1Path.indexOfNode(pRotate);
|
2017-01-16 11:08:13 +01:00
|
|
|
do
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
UpdatePathNode(initData.data, d1REPath.at(i), children);
|
2017-01-16 11:08:13 +01:00
|
|
|
++i;
|
|
|
|
if (i > indexOfNode && pointsD2 < countNodeD2-1)
|
2016-07-06 12:34:05 +02:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
qint32 j = 0;
|
|
|
|
FindIndexJ(pointsD2, d2Path, initData.indexD2, j);
|
|
|
|
do
|
|
|
|
{
|
|
|
|
if (j >= countNodeD2)
|
|
|
|
{
|
|
|
|
j=0;
|
|
|
|
}
|
2017-01-16 16:37:15 +01:00
|
|
|
UpdatePathNode(initData.data, d2REPath.at(j), children, dx, dy, pRotate, angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
++pointsD2;
|
|
|
|
++j;
|
|
|
|
} while (pointsD2 < countNodeD2-1);
|
2016-07-06 12:34:05 +02:00
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
} while (i<countNodeD1);
|
|
|
|
}
|
|
|
|
else // remove if min version is 0.3.2
|
|
|
|
{
|
2017-01-16 16:37:15 +01:00
|
|
|
qint32 pointsD2 = 0; //Keeps number points the second detail, what we have already added.
|
2017-01-16 11:08:13 +01:00
|
|
|
qint32 i = 0;
|
2017-01-16 16:37:15 +01:00
|
|
|
const int indexOfNode = d1Path.indexOfNode(pRotate);
|
2017-01-16 11:08:13 +01:00
|
|
|
do
|
|
|
|
{
|
|
|
|
++i;
|
|
|
|
if (i > indexOfNode)
|
2016-07-06 12:34:05 +02:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const int childrenCount = children.size();
|
|
|
|
qint32 j = 0;
|
|
|
|
FindIndexJ(pointsD2, d2Path, initData.indexD2, j);
|
|
|
|
do
|
|
|
|
{
|
|
|
|
if (j >= countNodeD2)
|
|
|
|
{
|
|
|
|
j=0;
|
|
|
|
}
|
2017-01-16 16:37:15 +01:00
|
|
|
UpdatePathNode(initData.data, d2REPath.at(j), children, dx, dy, pRotate, angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
++pointsD2;
|
|
|
|
++j;
|
|
|
|
} while (pointsD2 < childrenCount);
|
|
|
|
break;
|
2016-07-06 12:34:05 +02:00
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
} while (i<countNodeD1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-03-04 17:08:29 +01:00
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
void UpdateUnitedDetailPaths(const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate,
|
|
|
|
qreal angle, const QVector<quint32> &records, QVector<quint32> children)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
|
|
|
for (int i=0; i < records.size(); ++i)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
const VPiecePath path = initData.data->GetPiecePath(records.at(i));
|
|
|
|
const quint32 updatedId = TakeNextId(children);
|
2017-01-16 16:37:15 +01:00
|
|
|
|
2017-01-18 09:17:18 +01:00
|
|
|
VPiecePath updatedPath(path);
|
|
|
|
updatedPath.Clear();
|
|
|
|
|
|
|
|
for (int j=0; j < path.CountNodes(); ++j)
|
|
|
|
{
|
|
|
|
const VPieceNode &node = path.at(j);
|
|
|
|
const quint32 id = TakeNextId(children);
|
|
|
|
updatedPath.Append(VPieceNode(id, node.GetTypeTool(), node.GetReverse()));
|
|
|
|
QVector<quint32> nodeChildren = {id};
|
|
|
|
UpdatePathNode(initData.data, path.at(j), nodeChildren, dx, dy, pRotate, angle);
|
|
|
|
}
|
|
|
|
initData.data->UpdatePiecePath(updatedId, updatedPath);
|
|
|
|
}
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
void UpdateUnitedDetailCSA(quint32 id, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate,
|
|
|
|
qreal angle, const QVector<CustomSARecord> &records)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<quint32> idRecords;
|
|
|
|
for (int i = 0; i < records.size(); ++i)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
idRecords.append(records.at(i).path);
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
2017-01-18 09:17:18 +01:00
|
|
|
UpdateUnitedDetailPaths(initData, dx, dy, pRotate, angle, idRecords, GetCSAChildren(initData.doc, id));
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
void UpdateUnitedDetailInternalPaths(quint32 id, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle, const QVector<quint32> &records)
|
2017-01-16 16:37:15 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
UpdateUnitedDetailPaths(initData, dx, dy, pRotate, angle, records, GetInternalPathsChildren(initData.doc, id));
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
|
|
|
|
2017-02-01 12:31:14 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateUnitedDetailPins(quint32 id, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy,
|
|
|
|
quint32 pRotate, qreal angle, const QVector<quint32> &records)
|
|
|
|
{
|
|
|
|
QVector<quint32> children = GetPinChildren(initData.doc, id);
|
|
|
|
|
|
|
|
for (int i = 0; i < records.size(); ++i)
|
|
|
|
{
|
|
|
|
QScopedPointer<VPointF> point(new VPointF(*initData.data->GeometricObject<VPointF>(records.at(i))));
|
|
|
|
point->setMode(Draw::Modeling);
|
|
|
|
if (not qFuzzyIsNull(dx) || not qFuzzyIsNull(dy) || pRotate != NULL_ID)
|
|
|
|
{
|
2017-03-31 16:04:11 +02:00
|
|
|
BiasRotatePoint(point.data(), dx, dy,
|
|
|
|
static_cast<QPointF>(*initData.data->GeometricObject<VPointF>(pRotate)), angle);
|
2017-02-01 12:31:14 +01:00
|
|
|
}
|
|
|
|
initData.data->UpdateGObject(TakeNextId(children), point.take());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-16 16:37:15 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void CreateUnitedDetail(quint32 id, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate,
|
|
|
|
qreal angle)
|
|
|
|
{
|
|
|
|
const QString drawName = DrawName(initData.doc, initData.d1id, initData.d2id);
|
|
|
|
SCASSERT(not drawName.isEmpty())
|
|
|
|
|
|
|
|
const VPiece d1 = initData.data->GetPiece(initData.d1id);
|
|
|
|
const VPiece d2 = initData.data->GetPiece(initData.d2id);
|
|
|
|
|
|
|
|
VPiece newDetail;
|
|
|
|
|
|
|
|
CreateUnitedNodes(newDetail, d1, d2, id, drawName, initData, dx, dy, pRotate, angle);
|
|
|
|
CreateUnitedCSA(newDetail, d1, d2, id, drawName, initData, dx, dy, pRotate, angle);
|
|
|
|
CreateUnitedInternalPaths(newDetail, d1, d2, id, drawName, initData, dx, dy, pRotate, angle);
|
2017-02-01 12:31:14 +01:00
|
|
|
CreateUnitedPins(newDetail, d1, d2, id, drawName, initData, dx, dy, pRotate, angle);
|
2017-01-16 16:37:15 +01:00
|
|
|
|
|
|
|
newDetail.SetName(QObject::tr("United detail"));
|
2017-01-21 14:24:40 +01:00
|
|
|
QString formulaSAWidth = d1.GetFormulaSAWidth();
|
|
|
|
newDetail.SetFormulaSAWidth(formulaSAWidth, d1.GetSAWidth());
|
2017-01-16 16:37:15 +01:00
|
|
|
newDetail.SetMx(d1.GetMx());
|
|
|
|
newDetail.SetMy(d1.GetMy());
|
2017-01-22 14:21:08 +01:00
|
|
|
newDetail.SetUnited(true);
|
2017-01-21 14:24:40 +01:00
|
|
|
VToolSeamAllowance::Create(0, newDetail, formulaSAWidth, initData.scene, initData.doc, initData.data,
|
|
|
|
initData.parse, Source::FromTool, drawName);
|
2017-01-16 16:37:15 +01:00
|
|
|
|
|
|
|
auto RemoveDetail = [initData](quint32 id)
|
|
|
|
{
|
2017-03-23 09:25:46 +01:00
|
|
|
VToolSeamAllowance *toolDet = qobject_cast<VToolSeamAllowance*>(VAbstractPattern::getTool(id));
|
2017-01-16 16:37:15 +01:00
|
|
|
SCASSERT(toolDet != nullptr);
|
|
|
|
bool ask = false;
|
|
|
|
toolDet->Remove(ask);
|
2017-01-18 11:22:02 +01:00
|
|
|
// We do not call full parse, so will need more to do more cleaning than usually
|
|
|
|
initData.doc->RemoveTool(id);
|
|
|
|
initData.data->RemovePiece(id);
|
2017-01-16 16:37:15 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
if (not initData.retainPieces)
|
|
|
|
{
|
|
|
|
RemoveDetail(initData.d1id);
|
|
|
|
RemoveDetail(initData.d2id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UpdateUnitedDetail(quint32 id, const VToolUnionDetailsInitData &initData, qreal dx, qreal dy, quint32 pRotate,
|
|
|
|
qreal angle)
|
|
|
|
{
|
|
|
|
UpdateUnitedNodes(id, initData, dx, dy, pRotate, angle);
|
2017-01-18 09:17:18 +01:00
|
|
|
UpdateUnitedDetailCSA(id, initData, dx, dy, pRotate, angle, GetPiece2CSAPaths(initData.doc, id));
|
|
|
|
UpdateUnitedDetailInternalPaths(id, initData, dx, dy, pRotate, angle, GetPiece2InternalPaths(initData.doc, id));
|
2017-02-01 12:31:14 +01:00
|
|
|
UpdateUnitedDetailPins(id, initData, dx, dy, pRotate, angle, GetPiece2Pins(initData.doc, id));
|
2017-01-16 16:37:15 +01:00
|
|
|
}
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void UniteDetails(quint32 id, const VToolUnionDetailsInitData &initData)
|
|
|
|
{
|
|
|
|
VPieceNode det1p1;
|
|
|
|
qreal dx = 0;
|
|
|
|
qreal dy = 0;
|
|
|
|
qreal angle = 0;
|
2016-03-04 17:08:29 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
if (initData.typeCreation == Source::FromGui)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
const VPiece d1 = initData.data->GetPiece(initData.d1id);
|
|
|
|
const VPiece d2 = initData.data->GetPiece(initData.d2id);
|
|
|
|
UnionInitParameters(initData, d1.GetPath(), d2.GetPath(), det1p1, dx, dy, angle);
|
|
|
|
CreateUnitedDetail(id, initData, dx, dy, det1p1.GetId(), angle);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
const VPiecePath d1Path = GetPiece1MainPath(initData.doc, id);
|
|
|
|
const VPiecePath d2Path = GetPiece2MainPath(initData.doc, id);
|
|
|
|
UnionInitParameters(initData, d1Path, d2Path, det1p1, dx, dy, angle);
|
2017-01-16 16:37:15 +01:00
|
|
|
UpdateUnitedDetail(id, initData, dx, dy, det1p1.GetId(), angle);
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
} // static functions
|
2013-12-29 17:48:57 +01:00
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
2017-01-16 11:08:13 +01:00
|
|
|
* @brief VToolUnionDetails costructor.
|
|
|
|
* @param id object id in container.
|
|
|
|
* @param initData global init data.
|
|
|
|
* @param parent parent object.
|
2014-06-13 19:02:41 +02:00
|
|
|
*/
|
2017-01-16 11:08:13 +01:00
|
|
|
VToolUnionDetails::VToolUnionDetails(quint32 id, const VToolUnionDetailsInitData &initData,
|
|
|
|
QObject *parent)
|
|
|
|
: VAbstractTool(initData.doc, initData.data, id, parent),
|
|
|
|
d1id(initData.d1id),
|
|
|
|
d2id(initData.d2id),
|
|
|
|
indexD1(initData.indexD1),
|
|
|
|
indexD2(initData.indexD2)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
_referens = 0;
|
|
|
|
ToolCreation(initData.typeCreation);
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2014-08-30 21:58:31 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QString VToolUnionDetails::getTagName() const
|
|
|
|
{
|
2016-05-16 19:59:04 +02:00
|
|
|
return VAbstractPattern::TagTools;
|
2014-08-30 21:58:31 +02:00
|
|
|
}
|
|
|
|
|
2014-09-03 15:52:16 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void VToolUnionDetails::ShowVisualization(bool show)
|
|
|
|
{
|
2014-09-11 18:52:02 +02:00
|
|
|
Q_UNUSED(show)
|
2014-09-03 15:52:16 +02:00
|
|
|
}
|
|
|
|
|
2015-12-26 18:10:02 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void VToolUnionDetails::incrementReferens()
|
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
VDataTool::incrementReferens();
|
2015-12-26 18:10:02 +01:00
|
|
|
if (_referens == 1)
|
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QVector<quint32> objects = GetReferenceObjects();
|
|
|
|
for(int i = 0; i < objects.size(); ++i)
|
2015-12-26 18:10:02 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
doc->IncrementReferens(objects.at(i));
|
2015-12-26 18:10:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
QDomElement domElement = doc->elementById(id);
|
|
|
|
if (domElement.isElement())
|
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
doc->SetParametrUsage(domElement, AttrInUse, NodeUsage::InUse);
|
2016-01-07 17:43:08 +01:00
|
|
|
}
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
2014-03-04 13:55:57 +01:00
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 11:08:13 +01:00
|
|
|
void VToolUnionDetails::decrementReferens()
|
2014-03-06 14:28:46 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
VDataTool::decrementReferens();
|
|
|
|
if (_referens == 0)
|
2014-03-06 14:28:46 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QVector<quint32> objects = GetReferenceObjects();
|
|
|
|
for(int i = 0; i < objects.size(); ++i)
|
|
|
|
{
|
|
|
|
doc->DecrementReferens(objects.at(i));
|
2014-03-06 14:28:46 +01:00
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
QDomElement domElement = doc->elementById(id);
|
|
|
|
if (domElement.isElement())
|
|
|
|
{
|
|
|
|
doc->SetParametrUsage(domElement, AttrInUse, NodeUsage::NotInUse);
|
2014-03-06 14:28:46 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void VToolUnionDetails::GroupVisibility(quint32 object, bool visible)
|
|
|
|
{
|
|
|
|
Q_UNUSED(object)
|
|
|
|
Q_UNUSED(visible)
|
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
2017-01-16 11:08:13 +01:00
|
|
|
* @brief Create help create tool from GUI.
|
|
|
|
* @param dialog dialog.
|
2014-06-13 19:02:41 +02:00
|
|
|
* @param doc dom document container.
|
2017-01-16 11:08:13 +01:00
|
|
|
* @param data container with variables.
|
|
|
|
*/
|
2017-04-15 16:39:59 +02:00
|
|
|
VToolUnionDetails* VToolUnionDetails::Create(QSharedPointer<DialogTool> dialog, VMainGraphicsScene *scene,
|
|
|
|
VAbstractPattern *doc, VContainer *data)
|
2017-01-16 11:08:13 +01:00
|
|
|
{
|
2017-04-15 16:39:59 +02:00
|
|
|
SCASSERT(not dialog.isNull())
|
|
|
|
QSharedPointer<DialogUnionDetails> dialogTool = dialog.objectCast<DialogUnionDetails>();
|
|
|
|
SCASSERT(not dialogTool.isNull())
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
VToolUnionDetailsInitData initData;
|
|
|
|
initData.d1id = dialogTool->getD1();
|
|
|
|
initData.d2id = dialogTool->getD2();
|
|
|
|
initData.indexD1 = static_cast<quint32>(dialogTool->getIndexD1());
|
|
|
|
initData.indexD2 = static_cast<quint32>(dialogTool->getIndexD2());
|
|
|
|
initData.scene = scene;
|
|
|
|
initData.doc = doc;
|
|
|
|
initData.data = data;
|
|
|
|
initData.parse = Document::FullParse;
|
|
|
|
initData.typeCreation = Source::FromGui;
|
|
|
|
initData.retainPieces = dialogTool->RetainPieces();
|
|
|
|
|
|
|
|
qApp->getUndoStack()->beginMacro(tr("union details"));
|
|
|
|
VToolUnionDetails* tool = Create(0, initData);
|
|
|
|
qApp->getUndoStack()->endMacro();
|
|
|
|
return tool;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief Create help create tool.
|
|
|
|
* @param _id tool id, 0 if tool doesn't exist yet.
|
2017-01-27 13:07:12 +01:00
|
|
|
* @param initData contains all init data.
|
2014-06-13 19:02:41 +02:00
|
|
|
*/
|
2017-01-16 11:08:13 +01:00
|
|
|
VToolUnionDetails* VToolUnionDetails::Create(const quint32 _id, const VToolUnionDetailsInitData &initData)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
VToolUnionDetails *unionDetails = nullptr;
|
|
|
|
quint32 id = _id;
|
|
|
|
if (initData.typeCreation == Source::FromGui)
|
|
|
|
{
|
2017-03-23 09:25:46 +01:00
|
|
|
id = VContainer::getNextId();
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
|
|
|
else
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
if (initData.parse != Document::FullParse)
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
initData.doc->UpdateToolData(id, initData.data);
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
|
|
|
|
//First add tool to file
|
|
|
|
if (initData.parse == Document::FullParse)
|
|
|
|
{
|
2017-02-13 07:55:42 +01:00
|
|
|
VAbstractTool::AddRecord(id, Tool::UnionDetails, initData.doc);
|
2017-01-16 11:08:13 +01:00
|
|
|
//Scene doesn't show this tool, so doc will destroy this object.
|
|
|
|
unionDetails = new VToolUnionDetails(id, initData);
|
2017-03-23 09:25:46 +01:00
|
|
|
VAbstractPattern::AddTool(id, unionDetails);
|
2017-01-16 11:08:13 +01:00
|
|
|
// Unfortunatelly doc will destroy all objects only in the end, but we should delete them before each FullParse
|
|
|
|
initData.doc->AddToolOnRemove(unionDetails);
|
|
|
|
}
|
|
|
|
UniteDetails(id, initData);
|
|
|
|
return unionDetails;
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
|
|
|
* @brief AddToFile add tag with informations about tool into file.
|
|
|
|
*/
|
2013-12-29 17:48:57 +01:00
|
|
|
void VToolUnionDetails::AddToFile()
|
|
|
|
{
|
2016-05-16 19:59:04 +02:00
|
|
|
QDomElement domElement = doc->createElement(getTagName());
|
2013-12-29 17:48:57 +01:00
|
|
|
|
2014-03-21 11:08:29 +01:00
|
|
|
doc->SetAttribute(domElement, VDomDocument::AttrId, id);
|
2014-02-25 15:02:09 +01:00
|
|
|
doc->SetAttribute(domElement, AttrType, ToolType);
|
|
|
|
doc->SetAttribute(domElement, AttrIndexD1, indexD1);
|
|
|
|
doc->SetAttribute(domElement, AttrIndexD2, indexD2);
|
2013-12-29 17:48:57 +01:00
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
AddDetail(domElement, data.GetPiece(d1id));
|
|
|
|
AddDetail(domElement, data.GetPiece(d2id));
|
2013-12-29 17:48:57 +01:00
|
|
|
|
|
|
|
AddToModeling(domElement);
|
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
|
|
|
* @brief RefreshDataInFile refresh attributes in file. If attributes don't exist create them.
|
|
|
|
*/
|
2013-12-29 17:48:57 +01:00
|
|
|
void VToolUnionDetails::RefreshDataInFile()
|
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
// do nothing
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
|
|
|
* @brief AddDetail add detail to xml file.
|
|
|
|
* @param domElement tag in xml tree.
|
|
|
|
* @param d detail.
|
|
|
|
*/
|
2017-01-16 11:08:13 +01:00
|
|
|
void VToolUnionDetails::AddDetail(QDomElement &domElement, const VPiece &d) const
|
2013-12-29 17:48:57 +01:00
|
|
|
{
|
|
|
|
QDomElement det = doc->createElement(TagDetail);
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
// nodes
|
|
|
|
VToolSeamAllowance::AddNodes(doc, det, d);
|
|
|
|
//custom seam allowance
|
|
|
|
VToolSeamAllowance::AddCSARecords(doc, det, d.GetCustomSARecords());
|
|
|
|
VToolSeamAllowance::AddInternalPaths(doc, det, d.GetInternalPaths());
|
2017-01-31 17:09:18 +01:00
|
|
|
VToolSeamAllowance::AddPins(doc, det, d.GetPins());
|
2013-12-29 17:48:57 +01:00
|
|
|
|
|
|
|
domElement.appendChild(det);
|
|
|
|
}
|
|
|
|
|
2014-05-02 13:11:30 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-13 19:02:41 +02:00
|
|
|
/**
|
|
|
|
* @brief AddToModeling add tool to xml tree.
|
|
|
|
* @param domElement tag in xml tree.
|
|
|
|
*/
|
2013-12-29 17:48:57 +01:00
|
|
|
void VToolUnionDetails::AddToModeling(const QDomElement &domElement)
|
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QString drawName = DrawName(doc, d1id, d2id);
|
|
|
|
SCASSERT(not drawName.isEmpty())
|
|
|
|
|
2016-01-07 17:43:08 +01:00
|
|
|
QDomElement modeling = doc->GetDraw(drawName).firstChildElement(VAbstractPattern::TagModeling);
|
|
|
|
if (not modeling.isNull())
|
|
|
|
{
|
|
|
|
modeling.appendChild(domElement);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
qCCritical(vToolUnion, "Can't find tag %s.", qUtf8Printable(VAbstractPattern::TagModeling));
|
2016-01-07 17:43:08 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-03-08 18:49:16 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-16 11:08:13 +01:00
|
|
|
QVector<quint32> VToolUnionDetails::GetReferenceObjects() const
|
2016-03-08 18:49:16 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
QVector<quint32> list;
|
|
|
|
const QDomElement tool = doc->elementById(id);
|
|
|
|
if (tool.isNull())
|
2016-03-08 18:49:16 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
return list;
|
2016-03-08 18:49:16 +01:00
|
|
|
}
|
|
|
|
|
2017-01-16 11:08:13 +01:00
|
|
|
const QStringList parts = QStringList() << VAbstractPattern::TagNodes /*0*/
|
|
|
|
<< VToolSeamAllowance::TagCSA /*1*/
|
|
|
|
<< VToolSeamAllowance::TagIPaths; /*2*/
|
|
|
|
|
|
|
|
const QDomNodeList nodesList = tool.childNodes();
|
|
|
|
for (qint32 i = 0; i < nodesList.size(); ++i)
|
2016-03-08 18:49:16 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QDomElement element = nodesList.at(i).toElement();
|
|
|
|
if (not element.isNull() && element.tagName() == VToolUnionDetails::TagDetail)
|
2016-03-08 18:49:16 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QDomNodeList detList = element.childNodes();
|
|
|
|
for (qint32 j = 0; j < detList.size(); ++j)
|
2016-03-08 18:49:16 +01:00
|
|
|
{
|
2017-01-16 11:08:13 +01:00
|
|
|
const QDomElement element = detList.at(j).toElement();
|
|
|
|
if (not element.isNull())
|
|
|
|
{
|
|
|
|
switch (parts.indexOf(element.tagName()))
|
|
|
|
{
|
|
|
|
case 0://VAbstractPattern::TagNodes
|
2017-01-18 09:17:18 +01:00
|
|
|
list += ReferenceObjects(element, TagNode, AttrIdObject);
|
2017-01-16 11:08:13 +01:00
|
|
|
break;
|
|
|
|
case 1://VToolSeamAllowance::TagCSA
|
|
|
|
case 2://VToolSeamAllowance::TagIPaths
|
2017-01-18 09:17:18 +01:00
|
|
|
list += ReferenceObjects(element, VToolSeamAllowance::TagRecord,
|
|
|
|
VAbstractPattern::AttrPath);
|
2017-01-16 11:08:13 +01:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2016-03-08 18:49:16 +01:00
|
|
|
}
|
2016-01-07 17:43:08 +01:00
|
|
|
}
|
|
|
|
}
|
2017-01-16 11:08:13 +01:00
|
|
|
return list;
|
2016-01-07 17:43:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<quint32> VToolUnionDetails::ReferenceObjects(const QDomElement &root, const QString &tag,
|
|
|
|
const QString &attribute) const
|
2016-01-07 17:43:08 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
QVector<quint32> objects;
|
2016-01-07 17:43:08 +01:00
|
|
|
|
2017-01-18 09:17:18 +01:00
|
|
|
const QDomNodeList list = root.childNodes();
|
|
|
|
for (qint32 i = 0; i < list.size(); ++i)
|
2016-01-07 17:43:08 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
const QDomElement element = list.at(i).toElement();
|
|
|
|
if (not element.isNull() && element.tagName() == tag)
|
2016-01-07 17:43:08 +01:00
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
const quint32 id = doc->GetParametrUInt(element, attribute, NULL_ID_STR);
|
2017-01-16 11:08:13 +01:00
|
|
|
if (id > NULL_ID)
|
|
|
|
{
|
2017-01-18 09:17:18 +01:00
|
|
|
objects.append(id);
|
2017-01-16 11:08:13 +01:00
|
|
|
}
|
2016-01-07 17:43:08 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-18 09:17:18 +01:00
|
|
|
return objects;
|
2013-12-29 17:48:57 +01:00
|
|
|
}
|