2013-09-18 21:16:19 +02:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
|
|
|
** Copyright (C) 2013 Valentina project All Rights Reserved.
|
|
|
|
**
|
|
|
|
** This file is part of Valentina.
|
|
|
|
**
|
|
|
|
** Tox 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.
|
|
|
|
**
|
2013-10-27 13:36:29 +01:00
|
|
|
** Valentina is distributed in the hope that it will be useful,
|
2013-09-18 21:16:19 +02:00
|
|
|
** 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/>.
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
2013-08-06 09:56:09 +02:00
|
|
|
#include "vtoolarc.h"
|
2013-11-06 18:06:00 +01:00
|
|
|
#include "../../container/calculator.h"
|
2013-08-06 09:56:09 +02:00
|
|
|
|
2013-10-29 14:45:07 +01:00
|
|
|
const QString VToolArc::TagName = QStringLiteral("arc");
|
|
|
|
const QString VToolArc::ToolType = QStringLiteral("simple");
|
|
|
|
|
2013-09-29 12:58:45 +02:00
|
|
|
VToolArc::VToolArc(VDomDocument *doc, VContainer *data, qint64 id, Tool::Sources typeCreation,
|
2013-11-04 21:35:15 +01:00
|
|
|
QGraphicsItem *parent)
|
|
|
|
:VDrawTool(doc, data, id), QGraphicsPathItem(parent), dialogArc(QSharedPointer<DialogArc>())
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
VArc arc = data->GetArc(id);
|
|
|
|
QPainterPath path;
|
|
|
|
path.addPath(arc.GetPath());
|
|
|
|
path.setFillRule( Qt::WindingFill );
|
|
|
|
this->setPath(path);
|
2013-10-16 11:17:34 +02:00
|
|
|
this->setPen(QPen(Qt::black, widthHairLine/factor));
|
2013-08-06 09:56:09 +02:00
|
|
|
this->setFlag(QGraphicsItem::ItemIsSelectable, true);
|
|
|
|
this->setAcceptHoverEvents(true);
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
if (typeCreation == Tool::FromGui)
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
AddToFile();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::setDialog()
|
|
|
|
{
|
|
|
|
Q_ASSERT(dialogArc.isNull() == false);
|
|
|
|
VArc arc = VAbstractTool::data.GetArc(id);
|
|
|
|
dialogArc->SetCenter(arc.GetCenter());
|
|
|
|
dialogArc->SetF1(arc.GetFormulaF1());
|
|
|
|
dialogArc->SetF2(arc.GetFormulaF2());
|
|
|
|
dialogArc->SetRadius(arc.GetFormulaRadius());
|
2013-08-13 18:48:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void VToolArc::Create(QSharedPointer<DialogArc> &dialog, VMainGraphicsScene *scene, VDomDocument *doc,
|
2013-11-04 21:35:15 +01:00
|
|
|
VContainer *data)
|
|
|
|
{
|
2013-08-13 18:48:36 +02:00
|
|
|
qint64 center = dialog->GetCenter();
|
|
|
|
QString radius = dialog->GetRadius();
|
|
|
|
QString f1 = dialog->GetF1();
|
|
|
|
QString f2 = dialog->GetF2();
|
2013-09-10 14:29:06 +02:00
|
|
|
Create(0, center, radius, f1, f2, scene, doc, data, Document::FullParse, Tool::FromGui);
|
2013-08-13 18:48:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void VToolArc::Create(const qint64 _id, const qint64 ¢er, const QString &radius, const QString &f1,
|
2013-11-04 21:35:15 +01:00
|
|
|
const QString &f2, VMainGraphicsScene *scene, VDomDocument *doc, VContainer *data,
|
|
|
|
const Document::Documents &parse, Tool::Sources typeCreation)
|
|
|
|
{
|
2013-08-13 18:48:36 +02:00
|
|
|
qreal calcRadius = 0, calcF1 = 0, calcF2 = 0;
|
|
|
|
|
|
|
|
Calculator cal(data);
|
|
|
|
QString errorMsg;
|
|
|
|
qreal result = cal.eval(radius, &errorMsg);
|
2013-11-04 21:35:15 +01:00
|
|
|
if (errorMsg.isEmpty())
|
|
|
|
{
|
2013-10-13 20:51:59 +02:00
|
|
|
calcRadius = toPixel(result);
|
2013-08-13 18:48:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
errorMsg.clear();
|
|
|
|
result = cal.eval(f1, &errorMsg);
|
2013-11-04 21:35:15 +01:00
|
|
|
if (errorMsg.isEmpty())
|
|
|
|
{
|
2013-08-13 18:48:36 +02:00
|
|
|
calcF1 = result;
|
|
|
|
}
|
|
|
|
|
|
|
|
errorMsg.clear();
|
|
|
|
result = cal.eval(f2, &errorMsg);
|
2013-11-04 21:35:15 +01:00
|
|
|
if (errorMsg.isEmpty())
|
|
|
|
{
|
2013-08-13 18:48:36 +02:00
|
|
|
calcF2 = result;
|
|
|
|
}
|
|
|
|
|
|
|
|
VArc arc = VArc(data->DataPoints(), center, calcRadius, radius, calcF1, f1, calcF2, f2 );
|
|
|
|
qint64 id = _id;
|
2013-11-04 21:35:15 +01:00
|
|
|
if (typeCreation == Tool::FromGui)
|
|
|
|
{
|
2013-08-13 18:48:36 +02:00
|
|
|
id = data->AddArc(arc);
|
2013-11-04 21:35:15 +01:00
|
|
|
data->AddLengthArc(data->GetNameArc(center, id), toMM(arc.GetLength()));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-08-13 18:48:36 +02:00
|
|
|
data->UpdateArc(id, arc);
|
2013-11-04 21:35:15 +01:00
|
|
|
data->AddLengthArc(data->GetNameArc(center, id), toMM(arc.GetLength()));
|
|
|
|
if (parse != Document::FullParse)
|
|
|
|
{
|
2013-09-30 18:29:03 +02:00
|
|
|
doc->UpdateToolData(id, data);
|
2013-08-13 18:48:36 +02:00
|
|
|
}
|
|
|
|
}
|
2013-09-27 11:17:00 +02:00
|
|
|
VDrawTool::AddRecord(id, Tool::ArcTool, doc);
|
2013-11-04 21:35:15 +01:00
|
|
|
if (parse == Document::FullParse)
|
|
|
|
{
|
2013-09-10 14:29:06 +02:00
|
|
|
VToolArc *toolArc = new VToolArc(doc, data, id, typeCreation);
|
2013-08-13 18:48:36 +02:00
|
|
|
scene->addItem(toolArc);
|
|
|
|
connect(toolArc, &VToolArc::ChoosedTool, scene, &VMainGraphicsScene::ChoosedItem);
|
2013-08-20 12:26:02 +02:00
|
|
|
connect(toolArc, &VToolArc::RemoveTool, scene, &VMainGraphicsScene::RemoveTool);
|
2013-09-30 18:29:03 +02:00
|
|
|
doc->AddTool(id, toolArc);
|
|
|
|
doc->IncrementReferens(center);
|
2013-08-13 18:48:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::FullUpdateFromFile()
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
RefreshGeometry();
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::FullUpdateFromGui(int result)
|
|
|
|
{
|
|
|
|
if (result == QDialog::Accepted)
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
QDomElement domElement = doc->elementById(QString().setNum(id));
|
2013-11-04 21:35:15 +01:00
|
|
|
if (domElement.isElement())
|
|
|
|
{
|
2013-10-29 14:45:07 +01:00
|
|
|
domElement.setAttribute(AttrCenter, QString().setNum(dialogArc->GetCenter()));
|
|
|
|
domElement.setAttribute(AttrRadius, dialogArc->GetRadius());
|
|
|
|
domElement.setAttribute(AttrAngle1, dialogArc->GetF1());
|
|
|
|
domElement.setAttribute(AttrAngle2, dialogArc->GetF2());
|
2013-08-06 09:56:09 +02:00
|
|
|
emit FullUpdateTree();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
dialogArc.clear();
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::ChangedActivDraw(const QString newName)
|
|
|
|
{
|
2013-10-28 16:45:27 +01:00
|
|
|
bool selectable = false;
|
2013-11-04 21:35:15 +01:00
|
|
|
if (nameActivDraw == newName)
|
|
|
|
{
|
2013-10-28 16:45:27 +01:00
|
|
|
selectable = true;
|
2013-10-16 11:17:34 +02:00
|
|
|
currentColor = Qt::black;
|
2013-11-04 21:35:15 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-10-28 16:45:27 +01:00
|
|
|
selectable = false;
|
2013-10-16 11:17:34 +02:00
|
|
|
currentColor = Qt::gray;
|
2013-08-06 09:56:09 +02:00
|
|
|
}
|
2013-10-28 16:45:27 +01:00
|
|
|
this->setPen(QPen(currentColor, widthHairLine/factor));
|
|
|
|
this->setFlag(QGraphicsItem::ItemIsSelectable, selectable);
|
|
|
|
this->setAcceptHoverEvents (selectable);
|
|
|
|
VDrawTool::ChangedActivDraw(newName);
|
2013-08-06 09:56:09 +02:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::ShowTool(qint64 id, Qt::GlobalColor color, bool enable)
|
|
|
|
{
|
2013-10-28 16:45:27 +01:00
|
|
|
ShowItem(this, id, color, enable);
|
2013-08-15 22:39:00 +02:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::SetFactor(qreal factor)
|
|
|
|
{
|
2013-10-16 11:17:34 +02:00
|
|
|
VDrawTool::SetFactor(factor);
|
|
|
|
RefreshGeometry();
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::contextMenuEvent(QGraphicsSceneContextMenuEvent *event)
|
|
|
|
{
|
2013-09-30 18:29:03 +02:00
|
|
|
ContextMenu(dialogArc, this, event);
|
2013-08-06 09:56:09 +02:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::AddToFile()
|
|
|
|
{
|
2013-09-10 14:29:06 +02:00
|
|
|
VArc arc = VAbstractTool::data.GetArc(id);
|
2013-10-29 14:45:07 +01:00
|
|
|
QDomElement domElement = doc->createElement(TagName);
|
|
|
|
|
|
|
|
AddAttribute(domElement, AttrId, id);
|
|
|
|
AddAttribute(domElement, AttrType, ToolType);
|
|
|
|
AddAttribute(domElement, AttrCenter, arc.GetCenter());
|
|
|
|
AddAttribute(domElement, AttrRadius, arc.GetFormulaRadius());
|
|
|
|
AddAttribute(domElement, AttrAngle1, arc.GetFormulaF1());
|
|
|
|
AddAttribute(domElement, AttrAngle2, arc.GetFormulaF2());
|
2013-08-06 09:56:09 +02:00
|
|
|
|
2013-09-10 14:29:06 +02:00
|
|
|
AddToCalculation(domElement);
|
2013-08-06 09:56:09 +02:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::mouseReleaseEvent(QGraphicsSceneMouseEvent *event)
|
|
|
|
{
|
|
|
|
if (event->button() == Qt::LeftButton)
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
emit ChoosedTool(id, Scene::Arc);
|
|
|
|
}
|
|
|
|
QGraphicsItem::mouseReleaseEvent(event);
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::hoverMoveEvent(QGraphicsSceneHoverEvent *event)
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
Q_UNUSED(event);
|
2013-10-16 11:17:34 +02:00
|
|
|
this->setPen(QPen(currentColor, widthMainLine/factor));
|
2013-08-06 09:56:09 +02:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
|
|
|
|
{
|
2013-08-06 09:56:09 +02:00
|
|
|
Q_UNUSED(event);
|
2013-10-16 11:17:34 +02:00
|
|
|
this->setPen(QPen(currentColor, widthHairLine/factor));
|
2013-08-06 09:56:09 +02:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::RemoveReferens()
|
|
|
|
{
|
2013-09-30 18:29:03 +02:00
|
|
|
VArc arc = VAbstractTool::data.GetArc(id);
|
|
|
|
doc->DecrementReferens(arc.GetCenter());
|
|
|
|
}
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
void VToolArc::RefreshGeometry()
|
|
|
|
{
|
2013-10-16 11:17:34 +02:00
|
|
|
this->setPen(QPen(currentColor, widthHairLine/factor));
|
2013-08-13 18:48:36 +02:00
|
|
|
VArc arc = VAbstractTool::data.GetArc(id);
|
2013-08-06 09:56:09 +02:00
|
|
|
QPainterPath path;
|
|
|
|
path.addPath(arc.GetPath());
|
|
|
|
path.setFillRule( Qt::WindingFill );
|
|
|
|
this->setPath(path);
|
|
|
|
}
|