79f2ddde2a
--HG-- branch : feature
1302 lines
55 KiB
C++
1302 lines
55 KiB
C++
/************************************************************************
|
|
**
|
|
** @file vpattern.cpp
|
|
** @author Roman Telezhinsky <dismine@gmail.com>
|
|
** @date 24 2, 2014
|
|
**
|
|
** @brief
|
|
** @copyright
|
|
** This source code is part of the Valentine project, a pattern making
|
|
** program, whose allow create and modeling patterns of clothing.
|
|
** Copyright (C) 2013 Valentina project
|
|
** <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 "vpattern.h"
|
|
|
|
#include "../tools/vtooldetail.h"
|
|
#include "../tools/vtooluniondetails.h"
|
|
#include "../tools/drawTools/drawtools.h"
|
|
#include "../tools/nodeDetails/nodedetails.h"
|
|
#include "../exception/vexceptionobjecterror.h"
|
|
#include "../exception/vexceptionwrongparameterid.h"
|
|
#include "../exception/vexceptionuniqueid.h"
|
|
|
|
#include <QMessageBox>
|
|
|
|
const QString VPattern::TagPattern = QStringLiteral("pattern");
|
|
const QString VPattern::TagCalculation = QStringLiteral("calculation");
|
|
const QString VPattern::TagModeling = QStringLiteral("modeling");
|
|
const QString VPattern::TagDetails = QStringLiteral("details");
|
|
const QString VPattern::TagAuthor = QStringLiteral("author");
|
|
const QString VPattern::TagDescription = QStringLiteral("description");
|
|
const QString VPattern::TagNotes = QStringLiteral("notes");
|
|
const QString VPattern::TagIncrements = QStringLiteral("increments");
|
|
const QString VPattern::TagIncrement = QStringLiteral("increment");
|
|
const QString VPattern::TagDraw = QStringLiteral("draw");
|
|
const QString VPattern::TagPoint = QStringLiteral("point");
|
|
const QString VPattern::TagLine = QStringLiteral("line");
|
|
const QString VPattern::TagSpline = QStringLiteral("spline");
|
|
const QString VPattern::TagArc = QStringLiteral("arc");
|
|
const QString VPattern::TagTools = QStringLiteral("tools");
|
|
|
|
const QString VPattern::AttrName = QStringLiteral("name");
|
|
const QString VPattern::AttrType = QStringLiteral("type");
|
|
|
|
const QString VPattern::IncrementName = QStringLiteral("name");
|
|
const QString VPattern::IncrementBase = QStringLiteral("base");
|
|
const QString VPattern::IncrementKsize = QStringLiteral("ksize");
|
|
const QString VPattern::IncrementKgrowth = QStringLiteral("kgrowth");
|
|
const QString VPattern::IncrementDescription = QStringLiteral("description");
|
|
|
|
VPattern::VPattern(VContainer *data, QComboBox *comboBoxDraws, Draw::Draws *mode, QObject *parent)
|
|
: QObject(parent), VDomDocument(data), nameActivDraw(QString()), tools(QHash<quint32, VDataTool*>()),
|
|
history(QVector<VToolRecord>()), cursor(0), comboBoxDraws(comboBoxDraws), mode(mode), patternModified(false)
|
|
{
|
|
}
|
|
|
|
void VPattern::CreateEmptyFile()
|
|
{
|
|
QDomElement patternElement = this->createElement(TagPattern);
|
|
|
|
patternElement.appendChild(createComment("Valentina pattern format."));
|
|
patternElement.appendChild(createElement(TagAuthor));
|
|
patternElement.appendChild(createElement(TagDescription));
|
|
patternElement.appendChild(createElement(TagNotes));
|
|
patternElement.appendChild(createElement(TagIncrements));
|
|
|
|
this->appendChild(patternElement);
|
|
insertBefore(createProcessingInstruction("xml", "version=\"1.0\" encoding=\"UTF-8\""), this->firstChild());
|
|
}
|
|
|
|
void VPattern::ChangeActivDraw(const QString &name, const Document::Documents &parse)
|
|
{
|
|
Q_ASSERT_X(name.isEmpty() == false, "ChangeActivDraw", "name draw is empty");
|
|
if (CheckNameDraw(name))
|
|
{
|
|
this->nameActivDraw = name;
|
|
if (parse == Document::FullParse)
|
|
{
|
|
emit ChangedActivDraw(name);
|
|
}
|
|
}
|
|
}
|
|
|
|
bool VPattern::GetActivDrawElement(QDomElement &element)
|
|
{
|
|
if (nameActivDraw.isEmpty() == false)
|
|
{
|
|
const QDomNodeList elements = this->documentElement().elementsByTagName( TagDraw );
|
|
if (elements.size() == 0)
|
|
{
|
|
return false;
|
|
}
|
|
for ( qint32 i = 0; i < elements.count(); i++ )
|
|
{
|
|
element = elements.at( i ).toElement();
|
|
if (element.isNull() == false)
|
|
{
|
|
const QString fieldName = element.attribute( AttrName );
|
|
if ( fieldName == nameActivDraw )
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool VPattern::appendDraw(const QString &name)
|
|
{
|
|
Q_ASSERT_X(name.isEmpty() == false, "appendDraw", "name draw is empty");
|
|
if (name.isEmpty())
|
|
{
|
|
return false;
|
|
}
|
|
if (CheckNameDraw(name) == false)
|
|
{
|
|
QDomElement rootElement = this->documentElement();
|
|
|
|
QDomElement drawElement = this->createElement(TagDraw);
|
|
SetAttribute(drawElement, AttrName, name);
|
|
|
|
drawElement.appendChild(createElement(TagCalculation));
|
|
drawElement.appendChild(createElement(TagModeling));
|
|
drawElement.appendChild(createElement(TagDetails));
|
|
|
|
rootElement.appendChild(drawElement);
|
|
|
|
if (nameActivDraw.isEmpty())
|
|
{
|
|
SetActivDraw(name);
|
|
}
|
|
else
|
|
{
|
|
ChangeActivDraw(name);
|
|
}
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool VPattern::SetNameDraw(const QString &name)
|
|
{
|
|
Q_ASSERT_X(name.isEmpty() == false, "SetNameDraw", "name draw is empty");
|
|
const QString oldName = nameActivDraw;
|
|
QDomElement element;
|
|
if (GetActivDrawElement(element))
|
|
{
|
|
nameActivDraw = name;
|
|
element.setAttribute(AttrName, nameActivDraw);
|
|
emit patternChanged();
|
|
emit ChangedNameDraw(oldName, nameActivDraw);
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
qWarning()<<"Can't find activ draw"<<Q_FUNC_INFO;
|
|
return false;
|
|
}
|
|
}
|
|
|
|
void VPattern::Parse(const Document::Documents &parse, VMainGraphicsScene *sceneDraw, VMainGraphicsScene *sceneDetail)
|
|
{
|
|
Q_CHECK_PTR(sceneDraw);
|
|
Q_CHECK_PTR(sceneDetail);
|
|
PrepareForParse(parse, sceneDraw, sceneDetail);
|
|
QDomNode domNode = documentElement().firstChild();
|
|
while (domNode.isNull() == false)
|
|
{
|
|
if (domNode.isElement())
|
|
{
|
|
const QDomElement domElement = domNode.toElement();
|
|
if (domElement.isNull() == false)
|
|
{
|
|
QStringList tags;
|
|
tags << TagDraw << TagIncrements;
|
|
switch (tags.indexOf(domElement.tagName()))
|
|
{
|
|
case 0: // TagDraw
|
|
if (parse == Document::FullParse)
|
|
{
|
|
if (nameActivDraw.isEmpty())
|
|
{
|
|
SetActivDraw(GetParametrString(domElement, AttrName));
|
|
}
|
|
else
|
|
{
|
|
ChangeActivDraw(GetParametrString(domElement, AttrName));
|
|
}
|
|
comboBoxDraws->addItem(GetParametrString(domElement, AttrName));
|
|
}
|
|
else
|
|
{
|
|
ChangeActivDraw(GetParametrString(domElement, AttrName), Document::LiteParse);
|
|
}
|
|
ParseDrawElement(sceneDraw, sceneDetail, domElement, parse);
|
|
break;
|
|
case 1: // TagIncrements
|
|
ParseIncrementsElement(domElement);
|
|
break;
|
|
default:
|
|
qWarning()<<"Wrong tag name"<<Q_FUNC_INFO;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
domNode = domNode.nextSibling();
|
|
}
|
|
}
|
|
|
|
VDataTool *VPattern::getTool(const quint32 &id)
|
|
{
|
|
if (tools.contains(id))
|
|
{
|
|
return tools.value(id);
|
|
}
|
|
else
|
|
{
|
|
const QString error = QString(tr("Can't find tool id = %1 in table.")).arg(id);
|
|
throw VException(error);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
void VPattern::setCursor(const quint32 &value)
|
|
{
|
|
cursor = value;
|
|
emit ChangedCursor(cursor);
|
|
}
|
|
|
|
void VPattern::setCurrentData()
|
|
{
|
|
if (*mode == Draw::Calculation)
|
|
{
|
|
const QString nameDraw = comboBoxDraws->itemText(comboBoxDraws->currentIndex());
|
|
if (nameActivDraw != nameDraw)
|
|
{
|
|
nameActivDraw = nameDraw;
|
|
quint32 id = 0;
|
|
if (history.size() == 0)
|
|
{
|
|
return;
|
|
}
|
|
for (qint32 i = 0; i < history.size(); ++i)
|
|
{
|
|
const VToolRecord tool = history.at(i);
|
|
if (tool.getNameDraw() == nameDraw)
|
|
{
|
|
id = tool.getId();
|
|
}
|
|
}
|
|
if (id == 0)
|
|
{
|
|
const VToolRecord tool = history.at(history.size()-1);
|
|
id = tool.getId();
|
|
if (id == 0)
|
|
{
|
|
return;
|
|
}
|
|
}
|
|
if (tools.size() > 0)
|
|
{
|
|
const VDataTool *vTool = tools.value(id);
|
|
data->setData(vTool->getData());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void VPattern::AddTool(const quint32 &id, VDataTool *tool)
|
|
{
|
|
Q_ASSERT_X(id > 0, Q_FUNC_INFO, "id <= 0");
|
|
Q_CHECK_PTR(tool);
|
|
tools.insert(id, tool);
|
|
}
|
|
|
|
void VPattern::UpdateToolData(const quint32 &id, VContainer *data)
|
|
{
|
|
Q_ASSERT_X(id > 0, Q_FUNC_INFO, "id <= 0");
|
|
Q_CHECK_PTR(data);
|
|
VDataTool *tool = tools.value(id);
|
|
Q_CHECK_PTR(tool);
|
|
tool->VDataTool::setData(data);
|
|
}
|
|
|
|
void VPattern::IncrementReferens(quint32 id) const
|
|
{
|
|
Q_ASSERT_X(id > 0, Q_FUNC_INFO, "id <= 0");
|
|
VDataTool *tool = tools.value(id);
|
|
Q_CHECK_PTR(tool);
|
|
tool->incrementReferens();
|
|
}
|
|
|
|
void VPattern::DecrementReferens(quint32 id) const
|
|
{
|
|
Q_ASSERT_X(id > 0, Q_FUNC_INFO, "id <= 0");
|
|
VDataTool *tool = tools.value(id);
|
|
Q_CHECK_PTR(tool);
|
|
tool->decrementReferens();
|
|
}
|
|
|
|
void VPattern::TestUniqueId() const
|
|
{
|
|
QVector<quint32> vector;
|
|
CollectId(documentElement(), vector);
|
|
}
|
|
|
|
quint32 VPattern::SPointActiveDraw()
|
|
{
|
|
QDomElement calcElement;
|
|
if (GetActivNodeElement(TagCalculation, calcElement))
|
|
{
|
|
const QDomNode domNode = calcElement.firstChild();
|
|
if (domNode.isNull() == false && domNode.isElement())
|
|
{
|
|
const QDomElement domElement = domNode.toElement();
|
|
if (domElement.isNull() == false)
|
|
{
|
|
if (domElement.tagName() == VToolPoint::TagName &&
|
|
domElement.attribute(AttrType, "") == VToolSinglePoint::ToolType)
|
|
{
|
|
return GetParametrId(domElement);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
bool VPattern::CheckNameDraw(const QString &name) const
|
|
{
|
|
Q_ASSERT_X(name.isEmpty() == false, "CheckNameDraw", "name draw is empty");
|
|
const QDomNodeList elements = this->documentElement().elementsByTagName( TagDraw );
|
|
if (elements.size() == 0)
|
|
{
|
|
return false;
|
|
}
|
|
for ( qint32 i = 0; i < elements.count(); i++ )
|
|
{
|
|
const QDomElement elem = elements.at( i ).toElement();
|
|
if (elem.isNull() == false)
|
|
{
|
|
if ( GetParametrString(elem, AttrName) == name )
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void VPattern::SetActivDraw(const QString &name)
|
|
{
|
|
Q_ASSERT_X(name.isEmpty() == false, "SetActivDraw", "name draw is empty");
|
|
this->nameActivDraw = name;
|
|
}
|
|
|
|
bool VPattern::GetActivNodeElement(const QString &name, QDomElement &element)
|
|
{
|
|
Q_ASSERT_X(name.isEmpty() == false, "GetActivNodeElement", "name draw is empty");
|
|
QDomElement drawElement;
|
|
if (GetActivDrawElement(drawElement))
|
|
{
|
|
const QDomNodeList listElement = drawElement.elementsByTagName(name);
|
|
if (listElement.size() != 1)
|
|
{
|
|
return false;
|
|
}
|
|
element = listElement.at( 0 ).toElement();
|
|
if (element.isNull() == false)
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void VPattern::FullUpdateTree()
|
|
{
|
|
VMainGraphicsScene *scene = new VMainGraphicsScene();
|
|
Q_CHECK_PTR(scene);
|
|
try
|
|
{
|
|
Parse(Document::LiteParse, scene, scene);
|
|
}
|
|
catch (const std::bad_alloc &)
|
|
{
|
|
delete scene;
|
|
QMessageBox msgBox;
|
|
msgBox.setWindowTitle(tr("Error!"));
|
|
msgBox.setText(tr("Error parsing file."));
|
|
msgBox.setInformativeText("std::bad_alloc");
|
|
msgBox.setStandardButtons(QMessageBox::Ok);
|
|
msgBox.setDefaultButton(QMessageBox::Ok);
|
|
msgBox.setIcon(QMessageBox::Warning);
|
|
msgBox.exec();
|
|
return;
|
|
}
|
|
catch (...)
|
|
{
|
|
delete scene;
|
|
throw;
|
|
}
|
|
|
|
delete scene;
|
|
setCurrentData();
|
|
emit FullUpdateFromFile();
|
|
}
|
|
|
|
void VPattern::haveLiteChange()
|
|
{
|
|
patternModified = true;
|
|
emit patternChanged();
|
|
}
|
|
|
|
void VPattern::ShowHistoryTool(quint32 id, Qt::GlobalColor color, bool enable)
|
|
{
|
|
emit ShowTool(id, color, enable);
|
|
}
|
|
|
|
void VPattern::ParseDrawElement(VMainGraphicsScene *sceneDraw, VMainGraphicsScene *sceneDetail, const QDomNode &node,
|
|
const Document::Documents &parse)
|
|
{
|
|
QDomNode domNode = node.firstChild();
|
|
while (domNode.isNull() == false)
|
|
{
|
|
if (domNode.isElement())
|
|
{
|
|
const QDomElement domElement = domNode.toElement();
|
|
if (domElement.isNull() == false)
|
|
{
|
|
QStringList tags;
|
|
tags << TagCalculation << TagModeling << TagDetails;
|
|
switch (tags.indexOf(domElement.tagName()))
|
|
{
|
|
case 0: // TagCalculation
|
|
data->ClearCalculationGObjects();
|
|
ParseDrawMode(sceneDraw, sceneDetail, domElement, parse, Draw::Calculation);
|
|
break;
|
|
case 1: // TagModeling
|
|
ParseDrawMode(sceneDraw, sceneDetail, domElement, parse, Draw::Modeling);
|
|
break;
|
|
case 2: // TagDetails
|
|
ParseDetails(sceneDetail, domElement, parse);
|
|
break;
|
|
default:
|
|
qWarning()<<"Wrong tag name"<<Q_FUNC_INFO;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
domNode = domNode.nextSibling();
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseDrawMode(VMainGraphicsScene *sceneDraw, VMainGraphicsScene *sceneDetail, const QDomNode &node,
|
|
const Document::Documents &parse, const Draw::Draws &mode)
|
|
{
|
|
Q_CHECK_PTR(sceneDraw);
|
|
Q_CHECK_PTR(sceneDetail);
|
|
VMainGraphicsScene *scene = 0;
|
|
if (mode == Draw::Calculation)
|
|
{
|
|
scene = sceneDraw;
|
|
}
|
|
else
|
|
{
|
|
scene = sceneDetail;
|
|
}
|
|
const QDomNodeList nodeList = node.childNodes();
|
|
const qint32 num = nodeList.size();
|
|
for (qint32 i = 0; i < num; ++i)
|
|
{
|
|
const QDomElement domElement = nodeList.at(i).toElement();
|
|
if (domElement.isNull() == false)
|
|
{
|
|
QStringList tags;
|
|
tags << TagPoint << TagLine << TagSpline << TagArc << TagTools;
|
|
switch (tags.indexOf(domElement.tagName()))
|
|
{
|
|
case 0: // TagPoint
|
|
ParsePointElement(scene, domElement, parse, domElement.attribute(AttrType, ""));
|
|
break;
|
|
case 1: // TagLine
|
|
ParseLineElement(scene, domElement, parse);
|
|
break;
|
|
case 2: // TagSpline
|
|
ParseSplineElement(scene, domElement, parse, domElement.attribute(AttrType, ""));
|
|
break;
|
|
case 3: // TagArc
|
|
ParseArcElement(scene, domElement, parse, domElement.attribute(AttrType, ""));
|
|
break;
|
|
case 4: // TagTools
|
|
ParseToolsElement(scene, domElement, parse, domElement.attribute(AttrType, ""));
|
|
break;
|
|
default:
|
|
qWarning()<<"Wrong tag name"<<Q_FUNC_INFO;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseDetailElement(VMainGraphicsScene *sceneDetail, const QDomElement &domElement,
|
|
const Document::Documents &parse)
|
|
{
|
|
Q_CHECK_PTR(sceneDetail);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
try
|
|
{
|
|
VDetail detail;
|
|
const quint32 id = GetParametrId(domElement);
|
|
detail.setName(GetParametrString(domElement, VAbstractTool::AttrName, ""));
|
|
detail.setMx(toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "0.0")));
|
|
detail.setMy(toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "0.0")));
|
|
detail.setSeamAllowance(GetParametrUInt(domElement, VToolDetail::AttrSupplement, "1"));
|
|
detail.setWidth(GetParametrDouble(domElement, VToolDetail::AttrWidth, "10.0"));
|
|
detail.setClosed(GetParametrUInt(domElement, VToolDetail::AttrClosed, "1"));
|
|
|
|
const QDomNodeList nodeList = domElement.childNodes();
|
|
const qint32 num = nodeList.size();
|
|
for (qint32 i = 0; i < num; ++i)
|
|
{
|
|
const QDomElement element = nodeList.at(i).toElement();
|
|
if (element.isNull() == false)
|
|
{
|
|
if (element.tagName() == VToolDetail::TagNode)
|
|
{
|
|
const quint32 id = GetParametrUInt(element, VToolDetail::AttrIdObject, "0");
|
|
const qreal mx = toPixel(GetParametrDouble(element, VAbstractTool::AttrMx, "0.0"));
|
|
const qreal my = toPixel(GetParametrDouble(element, VAbstractTool::AttrMy, "0.0"));
|
|
const NodeDetail::NodeDetails nodeType = NodeDetail::Contour;
|
|
|
|
const QString t = GetParametrString(element, AttrType, "NodePoint");
|
|
Tool::Tools tool;
|
|
QStringList types;
|
|
types << VToolDetail::NodePoint << VToolDetail::NodeArc << VToolDetail::NodeSpline <<
|
|
VToolDetail::NodeSplinePath;
|
|
switch (types.indexOf(t))
|
|
{
|
|
case 0: // VToolDetail::NodePoint
|
|
tool = Tool::NodePoint;
|
|
break;
|
|
case 1: // VToolDetail::NodeArc
|
|
tool = Tool::NodeArc;
|
|
break;
|
|
case 2: // VToolDetail::NodeSpline
|
|
tool = Tool::NodeSpline;
|
|
break;
|
|
case 3: // VToolDetail::NodeSplinePath
|
|
tool = Tool::NodeSplinePath;
|
|
break;
|
|
default:
|
|
qWarning()<<"Wrong node type."<<Q_FUNC_INFO;
|
|
break;
|
|
}
|
|
detail.append(VNodeDetail(id, tool, nodeType, mx, my));
|
|
}
|
|
}
|
|
}
|
|
VToolDetail::Create(id, detail, sceneDetail, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating detail"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseDetails(VMainGraphicsScene *sceneDetail, const QDomElement &domElement,
|
|
const Document::Documents &parse)
|
|
{
|
|
Q_CHECK_PTR(sceneDetail);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
QDomNode domNode = domElement.firstChild();
|
|
while (domNode.isNull() == false)
|
|
{
|
|
if (domNode.isElement())
|
|
{
|
|
const QDomElement domElement = domNode.toElement();
|
|
if (domElement.isNull() == false)
|
|
{
|
|
if (domElement.tagName() == VToolDetail::TagName)
|
|
{
|
|
ParseDetailElement(sceneDetail, domElement, parse);
|
|
}
|
|
}
|
|
}
|
|
domNode = domNode.nextSibling();
|
|
}
|
|
}
|
|
|
|
void VPattern::ParsePointElement(VMainGraphicsScene *scene, const QDomElement &domElement,
|
|
const Document::Documents &parse, const QString &type)
|
|
{
|
|
Q_CHECK_PTR(scene);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
Q_ASSERT_X(type.isEmpty() == false, Q_FUNC_INFO, "type of point is empty");
|
|
|
|
|
|
QStringList points;
|
|
points << VToolSinglePoint::ToolType << VToolEndLine::ToolType << VToolAlongLine::ToolType
|
|
<< VToolShoulderPoint::ToolType << VToolNormal::ToolType << VToolBisector::ToolType
|
|
<< VToolLineIntersect::ToolType << VToolPointOfContact::ToolType << VNodePoint::ToolType
|
|
<< VToolHeight::ToolType << VToolTriangle::ToolType << VToolPointOfIntersection::ToolType
|
|
<< VToolCutSpline::ToolType << VToolCutSplinePath::ToolType << VToolCutArc::ToolType;
|
|
switch (points.indexOf(type))
|
|
{
|
|
case 0: //VToolSinglePoint::ToolType
|
|
{
|
|
VToolSinglePoint *spoint = 0;
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "A");
|
|
const qreal x = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrX, "10.0"));
|
|
const qreal y = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrY, "10.0"));
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
|
|
data->UpdateGObject(id, new VPointF(x, y, name, mx, my));
|
|
VDrawTool::AddRecord(id, Tool::SinglePointTool, this);
|
|
if (parse != Document::FullParse)
|
|
{
|
|
UpdateToolData(id, data);
|
|
}
|
|
if (parse == Document::FullParse)
|
|
{
|
|
spoint = new VToolSinglePoint(this, data, id, Tool::FromFile);
|
|
Q_CHECK_PTR(spoint);
|
|
scene->addItem(spoint);
|
|
connect(spoint, &VToolSinglePoint::ChoosedTool, scene, &VMainGraphicsScene::ChoosedItem);
|
|
connect(scene, &VMainGraphicsScene::NewFactor, spoint, &VToolSinglePoint::SetFactor);
|
|
tools[id] = spoint;
|
|
}
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating single point"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
scene->removeItem(spoint);
|
|
delete spoint;
|
|
throw excep;
|
|
}
|
|
break;
|
|
}
|
|
case 1: //VToolEndLine::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "100.0");
|
|
const quint32 basePointId = GetParametrUInt(domElement, VAbstractTool::AttrBasePoint, "0");
|
|
const qreal angle = GetParametrDouble(domElement, VAbstractTool::AttrAngle, "0.0");
|
|
|
|
VToolEndLine::Create(id, name, typeLine, formula, angle, basePointId,
|
|
mx, my, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of end line"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 2: //VToolAlongLine::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "100.0");
|
|
const quint32 firstPointId = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPointId = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
|
|
VToolAlongLine::Create(id, name, typeLine, formula, firstPointId, secondPointId, mx, my, scene, this,
|
|
data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point along line"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 3: //VToolShoulderPoint::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "100.0");
|
|
const quint32 p1Line = GetParametrUInt(domElement, VAbstractTool::AttrP1Line, "0");
|
|
const quint32 p2Line = GetParametrUInt(domElement, VAbstractTool::AttrP2Line, "0");
|
|
const quint32 pShoulder = GetParametrUInt(domElement, VAbstractTool::AttrPShoulder, "0");
|
|
|
|
VToolShoulderPoint::Create(id, formula, p1Line, p2Line, pShoulder, typeLine, name, mx, my, scene, this,
|
|
data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of shoulder"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 4: //VToolNormal::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "100.0");
|
|
const quint32 firstPointId = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPointId = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
const qreal angle = GetParametrDouble(domElement, VAbstractTool::AttrAngle, "0.0");
|
|
|
|
VToolNormal::Create(id, formula, firstPointId, secondPointId, typeLine, name, angle, mx, my, scene,
|
|
this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of normal"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 5: //VToolBisector::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "100.0");
|
|
const quint32 firstPointId = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPointId = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
const quint32 thirdPointId = GetParametrUInt(domElement, VAbstractTool::AttrThirdPoint, "0");
|
|
|
|
VToolBisector::Create(id, formula, firstPointId, secondPointId, thirdPointId,
|
|
typeLine, name, mx, my, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of bisector"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 6: //VToolLineIntersect::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const quint32 p1Line1Id = GetParametrUInt(domElement, VAbstractTool::AttrP1Line1, "0");
|
|
const quint32 p2Line1Id = GetParametrUInt(domElement, VAbstractTool::AttrP2Line1, "0");
|
|
const quint32 p1Line2Id = GetParametrUInt(domElement, VAbstractTool::AttrP1Line2, "0");
|
|
const quint32 p2Line2Id = GetParametrUInt(domElement, VAbstractTool::AttrP2Line2, "0");
|
|
|
|
VToolLineIntersect::Create(id, p1Line1Id, p2Line1Id, p1Line2Id, p2Line2Id, name,
|
|
mx, my, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of lineintersection"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 7: //VToolPointOfContact::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString radius = GetParametrString(domElement, VAbstractTool::AttrRadius, "0");
|
|
const quint32 center = GetParametrUInt(domElement, VAbstractTool::AttrCenter, "0");
|
|
const quint32 firstPointId = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPointId = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
|
|
VToolPointOfContact::Create(id, radius, center, firstPointId, secondPointId, name, mx, my, scene, this,
|
|
data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of contact"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 8: //VNodePoint::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 idObject = GetParametrUInt(domElement, VAbstractNode::AttrIdObject, "0");
|
|
const quint32 idTool = GetParametrUInt(domElement, VAbstractNode::AttrIdTool, "0");
|
|
const VPointF *point = data->GeometricObject<const VPointF *>(idObject );
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
data->UpdateGObject(id, new VPointF(point->x(), point->y(), point->name(), mx, my, idObject,
|
|
Draw::Modeling));
|
|
VNodePoint::Create(this, data, id, idObject, parse, Tool::FromFile, idTool);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating modeling point"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 9: //VToolHeight::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
const quint32 basePointId = GetParametrUInt(domElement, VAbstractTool::AttrBasePoint, "0");
|
|
const quint32 p1LineId = GetParametrUInt(domElement, VAbstractTool::AttrP1Line, "0");
|
|
const quint32 p2LineId = GetParametrUInt(domElement, VAbstractTool::AttrP2Line, "0");
|
|
|
|
VToolHeight::Create(id, name, typeLine, basePointId, p1LineId, p2LineId,
|
|
mx, my, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating height"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 10: //VToolTriangle::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const quint32 axisP1Id = GetParametrUInt(domElement, VAbstractTool::AttrAxisP1, "0");
|
|
const quint32 axisP2Id = GetParametrUInt(domElement, VAbstractTool::AttrAxisP2, "0");
|
|
const quint32 firstPointId = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPointId = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
|
|
VToolTriangle::Create(id, name, axisP1Id, axisP2Id, firstPointId, secondPointId, mx, my, scene, this,
|
|
data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating triangle"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 11: //VToolPointOfIntersection::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const quint32 firstPointId = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPointId = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
|
|
VToolPointOfIntersection::Create(id, name, firstPointId, secondPointId, mx, my, scene, this, data,
|
|
parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating point of intersection"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 12: //VToolCutSpline::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "0");
|
|
const quint32 splineId = GetParametrUInt(domElement, VToolCutSpline::AttrSpline, "0");
|
|
|
|
VToolCutSpline::Create(id, name, formula, splineId, mx, my, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating cut spline point"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 13: //VToolCutSplinePath::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "0");
|
|
const quint32 splinePathId = GetParametrUInt(domElement, VToolCutSplinePath::AttrSplinePath, "0");
|
|
|
|
VToolCutSplinePath::Create(id, name, formula, splinePathId, mx, my,
|
|
scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating cut spline path point"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 14: //VToolCutArc::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, VAbstractTool::AttrName, "");
|
|
const qreal mx = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMx, "10.0"));
|
|
const qreal my = toPixel(GetParametrDouble(domElement, VAbstractTool::AttrMy, "15.0"));
|
|
const QString formula = GetParametrString(domElement, VAbstractTool::AttrLength, "0");
|
|
const quint32 arcId = GetParametrUInt(domElement, VToolCutArc::AttrArc, "0");
|
|
|
|
VToolCutArc::Create(id, name, formula, arcId, mx, my, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating cut arc point"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
default:
|
|
qWarning() << "Illegal point type in VDomDocument::ParsePointElement().";
|
|
break;
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseLineElement(VMainGraphicsScene *scene, const QDomElement &domElement,
|
|
const Document::Documents &parse)
|
|
{
|
|
Q_CHECK_PTR(scene);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 firstPoint = GetParametrUInt(domElement, VAbstractTool::AttrFirstPoint, "0");
|
|
const quint32 secondPoint = GetParametrUInt(domElement, VAbstractTool::AttrSecondPoint, "0");
|
|
const QString typeLine = GetParametrString(domElement, VAbstractTool::AttrTypeLine,
|
|
VAbstractTool::TypeLineLine);
|
|
|
|
VToolLine::Create(id, firstPoint, secondPoint, typeLine, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating line"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseSplineElement(VMainGraphicsScene *scene, const QDomElement &domElement,
|
|
const Document::Documents &parse, const QString &type)
|
|
{
|
|
Q_CHECK_PTR(scene);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
Q_ASSERT_X(type.isEmpty() == false, Q_FUNC_INFO, "type of spline is empty");
|
|
|
|
QStringList splines;
|
|
splines << VToolSpline::ToolType << VToolSplinePath::ToolType << VNodeSpline::ToolType << VNodeSplinePath::ToolType;
|
|
switch (splines.indexOf(type))
|
|
{
|
|
case 0: //VToolSpline::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 point1 = GetParametrUInt(domElement, VAbstractTool::AttrPoint1, "0");
|
|
const quint32 point4 = GetParametrUInt(domElement, VAbstractTool::AttrPoint4, "0");
|
|
const qreal angle1 = GetParametrDouble(domElement, VAbstractTool::AttrAngle1, "270.0");
|
|
const qreal angle2 = GetParametrDouble(domElement, VAbstractTool::AttrAngle2, "90.0");
|
|
const qreal kAsm1 = GetParametrDouble(domElement, VAbstractTool::AttrKAsm1, "1.0");
|
|
const qreal kAsm2 = GetParametrDouble(domElement, VAbstractTool::AttrKAsm2, "1.0");
|
|
const qreal kCurve = GetParametrDouble(domElement, VAbstractTool::AttrKCurve, "1.0");
|
|
|
|
VToolSpline::Create(id, point1, point4, kAsm1, kAsm2, angle1, angle2, kCurve, scene, this, data, parse,
|
|
Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating simple curve"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 1: //VToolSplinePath::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const qreal kCurve = GetParametrDouble(domElement, VAbstractTool::AttrKCurve, "1.0");
|
|
VSplinePath *path = new VSplinePath(kCurve);
|
|
Q_CHECK_PTR(path);
|
|
|
|
const QDomNodeList nodeList = domElement.childNodes();
|
|
const qint32 num = nodeList.size();
|
|
for (qint32 i = 0; i < num; ++i)
|
|
{
|
|
const QDomElement element = nodeList.at(i).toElement();
|
|
if (element.isNull() == false)
|
|
{
|
|
if (element.tagName() == VAbstractTool::AttrPathPoint)
|
|
{
|
|
const qreal kAsm1 = GetParametrDouble(element, VAbstractTool::AttrKAsm1, "1.0");
|
|
const qreal angle = GetParametrDouble(element, VAbstractTool::AttrAngle, "0");
|
|
const qreal kAsm2 = GetParametrDouble(element, VAbstractTool::AttrKAsm2, "1.0");
|
|
const quint32 pSpline = GetParametrUInt(element, VAbstractTool::AttrPSpline, "0");
|
|
const VPointF p = *data->GeometricObject<const VPointF *>(pSpline);
|
|
|
|
QLineF line(0, 0, 100, 0);
|
|
line.setAngle(angle+180);
|
|
|
|
VSplinePoint splPoint(p, kAsm1, line.angle(), kAsm2, angle);
|
|
path->append(splPoint);
|
|
if (parse == Document::FullParse)
|
|
{
|
|
IncrementReferens(pSpline);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
VToolSplinePath::Create(id, path, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating curve path"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 2: //VNodeSpline::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 idObject = GetParametrUInt(domElement, VAbstractNode::AttrIdObject, "0");
|
|
const quint32 idTool = GetParametrUInt(domElement, VAbstractNode::AttrIdTool, "0");
|
|
VSpline *spl = new VSpline(*data->GeometricObject<const VSpline *>(idObject));
|
|
Q_CHECK_PTR(spl);
|
|
spl->setIdObject(idObject);
|
|
spl->setMode(Draw::Modeling);
|
|
data->UpdateGObject(id, spl);
|
|
VNodeSpline::Create(this, data, id, idObject, parse, Tool::FromFile, idTool);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating modeling simple curve"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 3: //VNodeSplinePath::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 idObject = GetParametrUInt(domElement, VAbstractNode::AttrIdObject, "0");
|
|
const quint32 idTool = GetParametrUInt(domElement, VAbstractNode::AttrIdTool, "0");
|
|
VSplinePath *path = new VSplinePath(*data->GeometricObject<const VSplinePath *>(idObject));
|
|
Q_CHECK_PTR(path);
|
|
path->setIdObject(idObject);
|
|
path->setMode(Draw::Modeling);
|
|
data->UpdateGObject(id, path);
|
|
VNodeSplinePath::Create(this, data, id, idObject, parse, Tool::FromFile, idTool);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating modeling curve path"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
default:
|
|
qWarning() << "Illegal spline type in VDomDocument::ParseSplineElement().";
|
|
break;
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseArcElement(VMainGraphicsScene *scene, const QDomElement &domElement,
|
|
const Document::Documents &parse, const QString &type)
|
|
{
|
|
Q_CHECK_PTR(scene);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
Q_ASSERT_X(type.isEmpty() == false, Q_FUNC_INFO, "type of spline is empty");
|
|
|
|
QStringList arcs;
|
|
arcs << VToolArc::ToolType << VNodeArc::ToolType;
|
|
|
|
switch (arcs.indexOf(type))
|
|
{
|
|
case 0: //VToolArc::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 center = GetParametrUInt(domElement, VAbstractTool::AttrCenter, "0");
|
|
const QString radius = GetParametrString(domElement, VAbstractTool::AttrRadius, "10");
|
|
const QString f1 = GetParametrString(domElement, VAbstractTool::AttrAngle1, "180");
|
|
const QString f2 = GetParametrString(domElement, VAbstractTool::AttrAngle2, "270");
|
|
|
|
VToolArc::Create(id, center, radius, f1, f2, scene, this, data, parse, Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating simple arc"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
case 1: //VNodeArc::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 idObject = GetParametrUInt(domElement, VAbstractNode::AttrIdObject, "0");
|
|
const quint32 idTool = GetParametrUInt(domElement, VAbstractNode::AttrIdTool, "0");
|
|
VArc *arc = new VArc(*data->GeometricObject<const VArc *>(idObject));
|
|
Q_CHECK_PTR(arc);
|
|
arc->setIdObject(idObject);
|
|
arc->setMode(Draw::Modeling);
|
|
data->UpdateGObject(id, arc);
|
|
VNodeArc::Create(this, data, id, idObject, parse, Tool::FromFile, idTool);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating modeling arc"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
default:
|
|
qWarning() << "Illegal arc type in VDomDocument::ParseArcElement().";
|
|
break;
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseToolsElement(VMainGraphicsScene *scene, const QDomElement &domElement,
|
|
const Document::Documents &parse, const QString &type)
|
|
{
|
|
Q_CHECK_PTR(scene);
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
Q_ASSERT_X(type.isEmpty() == false, Q_FUNC_INFO, "type of spline is empty");
|
|
|
|
QStringList tools;
|
|
tools << VToolUnionDetails::ToolType;
|
|
|
|
switch (tools.indexOf(type))
|
|
{
|
|
case 0: //VToolUnionDetails::ToolType
|
|
try
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const quint32 indexD1 = GetParametrUInt(domElement, VToolUnionDetails::AttrIndexD1, "-1");
|
|
const quint32 indexD2 = GetParametrUInt(domElement, VToolUnionDetails::AttrIndexD2, "-1");
|
|
|
|
const QVector<VDetail> vector = VToolUnionDetails::GetDetailFromFile(this, domElement);
|
|
|
|
VToolUnionDetails::Create(id, vector[0], vector[1], 0, 0, indexD1, indexD2, scene, this, data, parse,
|
|
Tool::FromFile);
|
|
}
|
|
catch (const VExceptionBadId &e)
|
|
{
|
|
VExceptionObjectError excep(tr("Error creating or updating union details"), domElement);
|
|
excep.AddMoreInformation(e.ErrorMessage());
|
|
throw excep;
|
|
}
|
|
break;
|
|
default:
|
|
qWarning() << "Illegal tools type in VDomDocument::ParseToolsElement().";
|
|
break;
|
|
}
|
|
}
|
|
|
|
void VPattern::ParseIncrementsElement(const QDomNode &node)
|
|
{
|
|
QDomNode domNode = node.firstChild();
|
|
while (domNode.isNull() == false)
|
|
{
|
|
if (domNode.isElement())
|
|
{
|
|
const QDomElement domElement = domNode.toElement();
|
|
if (domElement.isNull() == false)
|
|
{
|
|
if (domElement.tagName() == TagIncrement)
|
|
{
|
|
const quint32 id = GetParametrId(domElement);
|
|
const QString name = GetParametrString(domElement, IncrementName, "");
|
|
const qreal base = GetParametrDouble(domElement, IncrementBase, "0");
|
|
const qreal ksize = GetParametrDouble(domElement, IncrementKsize, "0");
|
|
const qreal kgrowth = GetParametrDouble(domElement, IncrementKgrowth, "0");
|
|
const QString desc = GetParametrString(domElement, IncrementDescription, "Description");
|
|
data->UpdateId(id);
|
|
data->AddIncrementTableRow(name, VIncrementTableRow(id, base, ksize, kgrowth, desc));
|
|
}
|
|
}
|
|
}
|
|
domNode = domNode.nextSibling();
|
|
}
|
|
}
|
|
|
|
quint32 VPattern::GetParametrId(const QDomElement &domElement) const
|
|
{
|
|
Q_ASSERT_X(domElement.isNull() == false, Q_FUNC_INFO, "domElement is null");
|
|
const quint32 id = GetParametrUInt(domElement, VAbstractTool::AttrId, "0");
|
|
if (id <= 0)
|
|
{
|
|
throw VExceptionWrongParameterId(tr("Got wrong parameter id. Need only id > 0."), domElement);
|
|
}
|
|
return id;
|
|
}
|
|
|
|
void VPattern::CollectId(const QDomElement &node, QVector<quint32> &vector) const
|
|
{
|
|
if (node.hasAttribute(VAbstractTool::AttrId))
|
|
{
|
|
const quint32 id = GetParametrId(node);
|
|
if (vector.contains(id))
|
|
{
|
|
throw VExceptionUniqueId(tr("This id is not unique."), node);
|
|
}
|
|
vector.append(id);
|
|
}
|
|
|
|
for (qint32 i=0; i<node.childNodes().length(); ++i)
|
|
{
|
|
const QDomNode n = node.childNodes().at(i);
|
|
if (n.isElement())
|
|
{
|
|
CollectId(n.toElement(), vector);
|
|
}
|
|
}
|
|
}
|
|
|
|
void VPattern::PrepareForParse(const Document::Documents &parse, VMainGraphicsScene *sceneDraw,
|
|
VMainGraphicsScene *sceneDetail)
|
|
{
|
|
Q_CHECK_PTR(sceneDraw);
|
|
Q_CHECK_PTR(sceneDetail);
|
|
if (parse == Document::FullParse)
|
|
{
|
|
TestUniqueId();
|
|
data->Clear();
|
|
data->CreateManTableIGroup();
|
|
nameActivDraw.clear();
|
|
sceneDraw->clear();
|
|
sceneDetail->clear();
|
|
comboBoxDraws->clear();
|
|
tools.clear();
|
|
cursor = 0;
|
|
}
|
|
data->ClearLengthLines();
|
|
data->ClearLengthArcs();
|
|
data->ClearLengthSplines();
|
|
data->ClearLineAngles();
|
|
data->ClearDetails();
|
|
history.clear();
|
|
}
|