Improve Add piece undocommand.
Performance improvement. --HG-- branch : develop
This commit is contained in:
parent
614fd3a0f9
commit
6bbd54f6ef
|
@ -35,7 +35,6 @@
|
||||||
#include <QUndoStack>
|
#include <QUndoStack>
|
||||||
#include <Qt>
|
#include <Qt>
|
||||||
|
|
||||||
#include "../../undocommands/adddetnode.h"
|
|
||||||
#include "../ifc/ifcdef.h"
|
#include "../ifc/ifcdef.h"
|
||||||
#include "../ifc/xml/vabstractpattern.h"
|
#include "../ifc/xml/vabstractpattern.h"
|
||||||
#include "../vgeometry/vgobject.h"
|
#include "../vgeometry/vgobject.h"
|
||||||
|
@ -176,6 +175,14 @@ void VAbstractNode::ToolCreation(const Source &typeCreation)
|
||||||
*/
|
*/
|
||||||
void VAbstractNode::AddToModeling(const QDomElement &domElement)
|
void VAbstractNode::AddToModeling(const QDomElement &domElement)
|
||||||
{
|
{
|
||||||
AddDetNode *addNode = new AddDetNode(domElement, doc, m_drawName);
|
QDomElement modeling;
|
||||||
qApp->getUndoStack()->push(addNode);
|
if (m_drawName.isEmpty())
|
||||||
|
{
|
||||||
|
doc->GetActivNodeElement(VAbstractPattern::TagModeling, modeling);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
modeling = doc->GetDraw(m_drawName).firstChildElement(VAbstractPattern::TagModeling);
|
||||||
|
}
|
||||||
|
modeling.appendChild(domElement);
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,7 +50,6 @@ VToolPiecePath *VToolPiecePath::Create(QSharedPointer<DialogTool> dialog, VMainG
|
||||||
initData.parse = Document::FullParse;
|
initData.parse = Document::FullParse;
|
||||||
initData.typeCreation = Source::FromGui;
|
initData.typeCreation = Source::FromGui;
|
||||||
|
|
||||||
qApp->getUndoStack()->beginMacro("add path");
|
|
||||||
initData.path.SetNodes(PrepareNodes(initData.path, scene, doc, data));
|
initData.path.SetNodes(PrepareNodes(initData.path, scene, doc, data));
|
||||||
|
|
||||||
VToolPiecePath *pathTool = Create(initData);
|
VToolPiecePath *pathTool = Create(initData);
|
||||||
|
@ -276,10 +275,6 @@ void VToolPiecePath::ToolCreation(const Source &typeCreation)
|
||||||
if (typeCreation == Source::FromGui || typeCreation == Source::FromTool)
|
if (typeCreation == Source::FromGui || typeCreation == Source::FromTool)
|
||||||
{
|
{
|
||||||
AddToFile();
|
AddToFile();
|
||||||
if (typeCreation != Source::FromTool)
|
|
||||||
{
|
|
||||||
qApp->getUndoStack()->endMacro();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -101,7 +101,6 @@ VToolSeamAllowance *VToolSeamAllowance::Create(QSharedPointer<DialogTool> dialog
|
||||||
initData.parse = Document::FullParse;
|
initData.parse = Document::FullParse;
|
||||||
initData.typeCreation = Source::FromGui;
|
initData.typeCreation = Source::FromGui;
|
||||||
|
|
||||||
qApp->getUndoStack()->beginMacro("add detail");
|
|
||||||
initData.detail.GetPath().SetNodes(PrepareNodes(initData.detail.GetPath(), scene, doc, data));
|
initData.detail.GetPath().SetNodes(PrepareNodes(initData.detail.GetPath(), scene, doc, data));
|
||||||
|
|
||||||
VToolSeamAllowance *piece = Create(initData);
|
VToolSeamAllowance *piece = Create(initData);
|
||||||
|
@ -921,9 +920,7 @@ void VToolSeamAllowance::AddToFile()
|
||||||
AddInternalPaths(doc, domElement, piece.GetInternalPaths());
|
AddInternalPaths(doc, domElement, piece.GetInternalPaths());
|
||||||
AddPins(doc, domElement, piece.GetPins());
|
AddPins(doc, domElement, piece.GetPins());
|
||||||
|
|
||||||
AddPiece *addDet = new AddPiece(domElement, doc, piece, m_drawName);
|
qApp->getUndoStack()->push(new AddPiece(domElement, doc, VAbstractTool::data, m_sceneDetails, m_drawName));
|
||||||
connect(addDet, &AddPiece::NeedFullParsing, doc, &VAbstractPattern::NeedFullParsing);
|
|
||||||
qApp->getUndoStack()->push(addDet);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
@ -1594,10 +1591,6 @@ void VToolSeamAllowance::ToolCreation(const Source &typeCreation)
|
||||||
if (typeCreation == Source::FromGui || typeCreation == Source::FromTool)
|
if (typeCreation == Source::FromGui || typeCreation == Source::FromTool)
|
||||||
{
|
{
|
||||||
AddToFile();
|
AddToFile();
|
||||||
if (typeCreation != Source::FromTool)
|
|
||||||
{
|
|
||||||
qApp->getUndoStack()->endMacro();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,106 +0,0 @@
|
||||||
/************************************************************************
|
|
||||||
**
|
|
||||||
** @file adddetnode.cpp
|
|
||||||
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
|
||||||
** @date 15 6, 2014
|
|
||||||
**
|
|
||||||
** @brief
|
|
||||||
** @copyright
|
|
||||||
** This source code is part of the Valentina project, a pattern making
|
|
||||||
** program, whose allow create and modeling patterns of clothing.
|
|
||||||
** Copyright (C) 2013-2015 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 "adddetnode.h"
|
|
||||||
|
|
||||||
#include <QByteArray>
|
|
||||||
#include <QDomNode>
|
|
||||||
|
|
||||||
#include "../vmisc/logging.h"
|
|
||||||
#include "../ifc/xml/vabstractpattern.h"
|
|
||||||
#include "vundocommand.h"
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
|
||||||
AddDetNode::AddDetNode(const QDomElement &xml, VAbstractPattern *doc, const QString &drawName, QUndoCommand *parent)
|
|
||||||
: VUndoCommand(xml, doc, parent), m_drawName(drawName)
|
|
||||||
{
|
|
||||||
setText(QObject::tr("add node"));
|
|
||||||
nodeId = doc->GetParametrId(xml);
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
|
||||||
AddDetNode::~AddDetNode()
|
|
||||||
{}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
|
||||||
void AddDetNode::undo()
|
|
||||||
{
|
|
||||||
qCDebug(vUndo, "Undo.");
|
|
||||||
|
|
||||||
QDomElement modeling = GetModelingSection();
|
|
||||||
if (not modeling.isNull())
|
|
||||||
{
|
|
||||||
QDomElement domElement = doc->elementById(nodeId);
|
|
||||||
if (domElement.isElement())
|
|
||||||
{
|
|
||||||
if (modeling.removeChild(domElement).isNull())
|
|
||||||
{
|
|
||||||
qCDebug(vUndo, "Can't delete node.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
qCDebug(vUndo, "Can't get node by id = %u.", nodeId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
qCDebug(vUndo, "Can't find tag %s.", qUtf8Printable(VAbstractPattern::TagModeling));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
|
||||||
void AddDetNode::redo()
|
|
||||||
{
|
|
||||||
qCDebug(vUndo, "Redo.");
|
|
||||||
|
|
||||||
QDomElement modeling = GetModelingSection();
|
|
||||||
if (not modeling.isNull())
|
|
||||||
{
|
|
||||||
modeling.appendChild(xml);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
qCDebug(vUndo, "Can't find tag %s.", qUtf8Printable(VAbstractPattern::TagModeling));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
|
||||||
QDomElement AddDetNode::GetModelingSection() const
|
|
||||||
{
|
|
||||||
QDomElement modeling;
|
|
||||||
if (m_drawName.isEmpty())
|
|
||||||
{
|
|
||||||
doc->GetActivNodeElement(VAbstractPattern::TagModeling, modeling);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
modeling = doc->GetDraw(m_drawName).firstChildElement(VAbstractPattern::TagModeling);
|
|
||||||
}
|
|
||||||
return modeling;
|
|
||||||
}
|
|
|
@ -1,57 +0,0 @@
|
||||||
/************************************************************************
|
|
||||||
**
|
|
||||||
** @file adddetnode.h
|
|
||||||
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
|
||||||
** @date 15 6, 2014
|
|
||||||
**
|
|
||||||
** @brief
|
|
||||||
** @copyright
|
|
||||||
** This source code is part of the Valentina project, a pattern making
|
|
||||||
** program, whose allow create and modeling patterns of clothing.
|
|
||||||
** Copyright (C) 2013-2015 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/>.
|
|
||||||
**
|
|
||||||
*************************************************************************/
|
|
||||||
|
|
||||||
#ifndef ADDDETNODE_H
|
|
||||||
#define ADDDETNODE_H
|
|
||||||
|
|
||||||
#include <qcompilerdetection.h>
|
|
||||||
#include <QDomElement>
|
|
||||||
#include <QMetaObject>
|
|
||||||
#include <QObject>
|
|
||||||
#include <QString>
|
|
||||||
#include <QtGlobal>
|
|
||||||
|
|
||||||
#include "vundocommand.h"
|
|
||||||
|
|
||||||
class AddDetNode : public VUndoCommand
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
public:
|
|
||||||
AddDetNode(const QDomElement &xml, VAbstractPattern *doc, const QString &drawName, QUndoCommand *parent = nullptr);
|
|
||||||
virtual ~AddDetNode() Q_DECL_OVERRIDE;
|
|
||||||
virtual void undo() Q_DECL_OVERRIDE;
|
|
||||||
virtual void redo() Q_DECL_OVERRIDE;
|
|
||||||
private:
|
|
||||||
Q_DISABLE_COPY(AddDetNode)
|
|
||||||
|
|
||||||
QString m_drawName;
|
|
||||||
|
|
||||||
QDomElement GetModelingSection() const;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // ADDDETNODE_H
|
|
|
@ -29,21 +29,33 @@
|
||||||
#include "addpiece.h"
|
#include "addpiece.h"
|
||||||
#include "../vpatterndb/vpiecenode.h"
|
#include "../vpatterndb/vpiecenode.h"
|
||||||
#include "../vpatterndb/vpiecepath.h"
|
#include "../vpatterndb/vpiecepath.h"
|
||||||
|
#include "../vwidgets/vmaingraphicsview.h"
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
AddPiece::AddPiece(const QDomElement &xml, VAbstractPattern *doc, const VPiece &detail, const QString &drawName,
|
AddPiece::AddPiece(const QDomElement &xml, VAbstractPattern *doc, VContainer data, VMainGraphicsScene *scene,
|
||||||
QUndoCommand *parent)
|
const QString &drawName, QUndoCommand *parent)
|
||||||
: VUndoCommand(xml, doc, parent),
|
: VUndoCommand(xml, doc, parent),
|
||||||
m_detail(detail),
|
m_detail(),
|
||||||
m_drawName(drawName)
|
m_drawName(drawName),
|
||||||
|
m_tool(),
|
||||||
|
m_record(),
|
||||||
|
m_scene(scene),
|
||||||
|
m_data(data)
|
||||||
{
|
{
|
||||||
setText(tr("add detail"));
|
setText(tr("add detail"));
|
||||||
nodeId = doc->GetParametrId(xml);
|
nodeId = doc->GetParametrId(xml);
|
||||||
|
m_detail = data.GetPiece(nodeId);
|
||||||
|
m_record = VAbstractTool::GetRecord(nodeId, Tool::Piece, doc);
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
AddPiece::~AddPiece()
|
AddPiece::~AddPiece()
|
||||||
{}
|
{
|
||||||
|
if (not m_tool.isNull())
|
||||||
|
{
|
||||||
|
delete m_tool;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void AddPiece::undo()
|
void AddPiece::undo()
|
||||||
|
@ -62,10 +74,23 @@ void AddPiece::undo()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_tool = qobject_cast<VToolSeamAllowance*>(VAbstractPattern::getTool(nodeId));
|
||||||
|
SCASSERT(not m_tool.isNull());
|
||||||
|
m_tool->DisconnectOutsideSignals();
|
||||||
|
m_tool->hide();
|
||||||
|
|
||||||
|
m_scene->removeItem(m_tool);
|
||||||
|
|
||||||
|
VAbstractPattern::RemoveTool(nodeId);
|
||||||
|
m_data.RemovePiece(nodeId);
|
||||||
|
VAbstractTool::RemoveRecord(m_record, doc);
|
||||||
|
|
||||||
DecrementReferences(m_detail.GetPath().GetNodes());
|
DecrementReferences(m_detail.GetPath().GetNodes());
|
||||||
DecrementReferences(m_detail.GetCustomSARecords());
|
DecrementReferences(m_detail.GetCustomSARecords());
|
||||||
DecrementReferences(m_detail.GetInternalPaths());
|
DecrementReferences(m_detail.GetInternalPaths());
|
||||||
DecrementReferences(m_detail.GetPins());
|
DecrementReferences(m_detail.GetPins());
|
||||||
|
|
||||||
|
VMainGraphicsView::NewSceneRect(m_scene, qApp->getSceneView());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -90,13 +115,28 @@ void AddPiece::redo()
|
||||||
if (not details.isNull())
|
if (not details.isNull())
|
||||||
{
|
{
|
||||||
details.appendChild(xml);
|
details.appendChild(xml);
|
||||||
|
|
||||||
|
if (not m_tool.isNull())
|
||||||
|
{
|
||||||
|
VAbstractPattern::AddTool(nodeId, m_tool);
|
||||||
|
m_data.UpdatePiece(nodeId, m_detail);
|
||||||
|
|
||||||
|
m_tool->ReinitInternals(m_detail, m_scene);
|
||||||
|
|
||||||
|
VAbstractTool::AddRecord(m_record, doc);
|
||||||
|
m_scene->addItem(m_tool);
|
||||||
|
m_tool->ConnectOutsideSignals();
|
||||||
|
m_tool->show();
|
||||||
|
m_tool.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
VMainGraphicsView::NewSceneRect(m_scene, qApp->getSceneView());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
qCDebug(vUndo, "Can't find tag %s.", qUtf8Printable(VAbstractPattern::TagDetails));
|
qCDebug(vUndo, "Can't find tag %s.", qUtf8Printable(VAbstractPattern::TagDetails));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
RedoFullParsing();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
|
@ -44,8 +44,8 @@ class AddPiece : public VUndoCommand
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
AddPiece(const QDomElement &xml, VAbstractPattern *doc, const VPiece &detail, const QString &drawName = QString(),
|
AddPiece(const QDomElement &xml, VAbstractPattern *doc, VContainer data, VMainGraphicsScene *scene,
|
||||||
QUndoCommand *parent = nullptr);
|
const QString &drawName = QString(), QUndoCommand *parent = nullptr);
|
||||||
virtual ~AddPiece();
|
virtual ~AddPiece();
|
||||||
|
|
||||||
// cppcheck-suppress unusedFunction
|
// cppcheck-suppress unusedFunction
|
||||||
|
@ -57,6 +57,10 @@ private:
|
||||||
|
|
||||||
VPiece m_detail;
|
VPiece m_detail;
|
||||||
QString m_drawName;
|
QString m_drawName;
|
||||||
|
QPointer<VToolSeamAllowance> m_tool;
|
||||||
|
VToolRecord m_record;
|
||||||
|
VMainGraphicsScene *m_scene;
|
||||||
|
VContainer m_data;
|
||||||
|
|
||||||
QDomElement GetDetailsSection() const;
|
QDomElement GetDetailsSection() const;
|
||||||
};
|
};
|
||||||
|
|
|
@ -10,7 +10,6 @@ HEADERS += \
|
||||||
$$PWD/savetooloptions.h \
|
$$PWD/savetooloptions.h \
|
||||||
$$PWD/deltool.h \
|
$$PWD/deltool.h \
|
||||||
$$PWD/deletepatternpiece.h \
|
$$PWD/deletepatternpiece.h \
|
||||||
$$PWD/adddetnode.h \
|
|
||||||
$$PWD/vundocommand.h \
|
$$PWD/vundocommand.h \
|
||||||
$$PWD/renamepp.h \
|
$$PWD/renamepp.h \
|
||||||
$$PWD/label/movelabel.h \
|
$$PWD/label/movelabel.h \
|
||||||
|
@ -38,7 +37,6 @@ SOURCES += \
|
||||||
$$PWD/savetooloptions.cpp \
|
$$PWD/savetooloptions.cpp \
|
||||||
$$PWD/deltool.cpp \
|
$$PWD/deltool.cpp \
|
||||||
$$PWD/deletepatternpiece.cpp \
|
$$PWD/deletepatternpiece.cpp \
|
||||||
$$PWD/adddetnode.cpp \
|
|
||||||
$$PWD/vundocommand.cpp \
|
$$PWD/vundocommand.cpp \
|
||||||
$$PWD/renamepp.cpp \
|
$$PWD/renamepp.cpp \
|
||||||
$$PWD/label/movelabel.cpp \
|
$$PWD/label/movelabel.cpp \
|
||||||
|
|
Loading…
Reference in New Issue
Block a user