/************************************************************************ ** ** @file vtoolcubicbezier.cpp ** @author Roman Telezhynskyi ** @date 10 3, 2016 ** ** @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) 2016 Valentina project ** 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 . ** *************************************************************************/ #include "vtoolcubicbezier.h" #include #include #include #include #include #include #include #include #include "../../../dialogs/tools/dialogtool.h" #include "../../../dialogs/tools/dialogcubicbezier.h" #include "../../../visualization/visualization.h" #include "../../../visualization/path/vistoolcubicbezier.h" #include "../ifc/exception/vexception.h" #include "../vgeometry/../ifc/ifcdef.h" #include "../vgeometry/vabstractcurve.h" #include "../vgeometry/vcubicbezier.h" #include "../vgeometry/vgobject.h" #include "../vgeometry/vpointf.h" #include "../vmisc/vabstractapplication.h" #include "../vpatterndb/vcontainer.h" #include "../vwidgets/vmaingraphicsscene.h" #include "../../vabstracttool.h" #include "../vdrawtool.h" #include "vabstractspline.h" const QString VToolCubicBezier::ToolType = QStringLiteral("cubicBezier"); //--------------------------------------------------------------------------------------------------------------------- VToolCubicBezier::VToolCubicBezier(const VToolCubicBezierInitData &initData, QGraphicsItem *parent) :VAbstractSpline(initData.doc, initData.data, initData.id, parent) { sceneType = SceneObject::Spline; this->setFlag(QGraphicsItem::ItemIsFocusable, true);// For keyboard input focus ToolCreation(initData.typeCreation); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::setDialog() { SCASSERT(not m_dialog.isNull()) auto dialogTool = qobject_cast(m_dialog); SCASSERT(dialogTool != nullptr) const auto spl = VAbstractTool::data.GeometricObject(m_id); dialogTool->SetSpline(*spl); dialogTool->SetColor(spl->GetColor()); dialogTool->SetPenStyle(spl->GetPenStyle()); } //--------------------------------------------------------------------------------------------------------------------- VToolCubicBezier *VToolCubicBezier::Create(QSharedPointer dialog, VMainGraphicsScene *scene, VAbstractPattern *doc, VContainer *data) { SCASSERT(not dialog.isNull()) QSharedPointer dialogTool = dialog.objectCast(); SCASSERT(not dialogTool.isNull()) VToolCubicBezierInitData initData; initData.scene = scene; initData.doc = doc; initData.data = data; initData.parse = Document::FullParse; initData.typeCreation = Source::FromGui; initData.spline = new VCubicBezier(dialogTool->GetSpline()); initData.spline->SetColor(dialogTool->GetColor()); initData.spline->SetPenStyle(dialogTool->GetPenStyle()); auto spl = Create(initData); if (spl != nullptr) { spl->m_dialog = dialogTool; } return spl; } //--------------------------------------------------------------------------------------------------------------------- VToolCubicBezier *VToolCubicBezier::Create(VToolCubicBezierInitData initData) { if (initData.typeCreation == Source::FromGui) { initData.id = initData.data->AddGObject(initData.spline); initData.data->AddSpline(initData.data->GeometricObject(initData.id), initData.id); } else { initData.data->UpdateGObject(initData.id, initData.spline); initData.data->AddSpline(initData.data->GeometricObject(initData.id), initData.id); if (initData.parse != Document::FullParse) { initData.doc->UpdateToolData(initData.id, initData.data); } } if (initData.parse == Document::FullParse) { VAbstractTool::AddRecord(initData.id, Tool::CubicBezier, initData.doc); auto _spl = new VToolCubicBezier(initData); initData.scene->addItem(_spl); InitSplineToolConnections(initData.scene, _spl); VAbstractPattern::AddTool(initData.id, _spl); initData.doc->IncrementReferens(initData.spline->GetP1().getIdTool()); initData.doc->IncrementReferens(initData.spline->GetP1().getIdTool()); initData.doc->IncrementReferens(initData.spline->GetP1().getIdTool()); initData.doc->IncrementReferens(initData.spline->GetP4().getIdTool()); return _spl; } return nullptr; } //--------------------------------------------------------------------------------------------------------------------- QString VToolCubicBezier::FirstPointName() const { auto spline = VAbstractTool::data.GeometricObject(m_id); return spline->GetP1().name(); } //--------------------------------------------------------------------------------------------------------------------- QString VToolCubicBezier::SecondPointName() const { auto spline = VAbstractTool::data.GeometricObject(m_id); return spline->GetP2().name(); } //--------------------------------------------------------------------------------------------------------------------- QString VToolCubicBezier::ThirdPointName() const { auto spline = VAbstractTool::data.GeometricObject(m_id); return spline->GetP3().name(); } //--------------------------------------------------------------------------------------------------------------------- QString VToolCubicBezier::ForthPointName() const { auto spline = VAbstractTool::data.GeometricObject(m_id); return spline->GetP4().name(); } //--------------------------------------------------------------------------------------------------------------------- VCubicBezier VToolCubicBezier::getSpline() const { auto spline = VAbstractTool::data.GeometricObject(m_id); return *spline.data(); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::setSpline(const VCubicBezier &spl) { QSharedPointer obj = VAbstractTool::data.GetGObject(m_id); QSharedPointer spline = qSharedPointerDynamicCast(obj); *spline.data() = spl; SaveOption(obj); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::ShowVisualization(bool show) { ShowToolVisualization(show); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::ShowContextMenu(QGraphicsSceneContextMenuEvent *event, quint32 id) { Q_UNUSED(id) try { ContextMenu(event); } catch(const VExceptionToolWasDeleted &e) { Q_UNUSED(e) return;//Leave this method immediately!!! } } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::RemoveReferens() { const auto spl = VAbstractTool::data.GeometricObject(m_id); doc->DecrementReferens(spl->GetP1().getIdTool()); doc->DecrementReferens(spl->GetP2().getIdTool()); doc->DecrementReferens(spl->GetP3().getIdTool()); doc->DecrementReferens(spl->GetP4().getIdTool()); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::SaveDialog(QDomElement &domElement) { SCASSERT(not m_dialog.isNull()) auto dialogTool = qobject_cast(m_dialog); SCASSERT(dialogTool != nullptr) const VCubicBezier spl = dialogTool->GetSpline(); SetSplineAttributes(domElement, spl); doc->SetAttribute(domElement, AttrColor, dialogTool->GetColor()); doc->SetAttribute(domElement, AttrPenStyle, dialogTool->GetPenStyle()); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::SaveOptions(QDomElement &tag, QSharedPointer &obj) { VAbstractSpline::SaveOptions(tag, obj); auto spl = qSharedPointerDynamicCast(obj); SCASSERT(spl.isNull() == false) SetSplineAttributes(tag, *spl); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::SetVisualization() { if (not vis.isNull()) { auto visual = qobject_cast(vis); SCASSERT(visual != nullptr) const QSharedPointer spl = VAbstractTool::data.GeometricObject(m_id); visual->setObject1Id(spl->GetP1().id()); visual->setObject2Id(spl->GetP2().id()); visual->setObject3Id(spl->GetP3().id()); visual->setObject4Id(spl->GetP4().id()); visual->setLineStyle(LineStyleToPenStyle(spl->GetPenStyle())); visual->SetMode(Mode::Show); visual->RefreshGeometry(); } } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::RefreshGeometry() { const QSharedPointer spl = VAbstractTool::data.GeometricObject(m_id); this->setPath(spl->GetPath()); SetVisualization(); } //--------------------------------------------------------------------------------------------------------------------- void VToolCubicBezier::SetSplineAttributes(QDomElement &domElement, const VCubicBezier &spl) { SCASSERT(doc != nullptr) doc->SetAttribute(domElement, AttrType, ToolType); doc->SetAttribute(domElement, AttrPoint1, spl.GetP1().id()); doc->SetAttribute(domElement, AttrPoint2, spl.GetP2().id()); doc->SetAttribute(domElement, AttrPoint3, spl.GetP3().id()); doc->SetAttribute(domElement, AttrPoint4, spl.GetP4().id()); if (spl.GetDuplicate() > 0) { doc->SetAttribute(domElement, AttrDuplicate, spl.GetDuplicate()); } else { if (domElement.hasAttribute(AttrDuplicate)) { domElement.removeAttribute(AttrDuplicate); } } }