From fd39c19da065753afeb72180ad557de7c93b5a47 Mon Sep 17 00:00:00 2001 From: Roman Telezhynskyi Date: Wed, 18 May 2016 19:13:48 +0300 Subject: [PATCH] Show selected objects even before selecting origin point. --HG-- branch : feature --- .../visualization/line/vistoolrotation.cpp | 119 ++++++++++-------- 1 file changed, 64 insertions(+), 55 deletions(-) diff --git a/src/libs/vtools/visualization/line/vistoolrotation.cpp b/src/libs/vtools/visualization/line/vistoolrotation.cpp index e5602e3eb..70173feb3 100644 --- a/src/libs/vtools/visualization/line/vistoolrotation.cpp +++ b/src/libs/vtools/visualization/line/vistoolrotation.cpp @@ -75,9 +75,11 @@ void VisToolRotation::RefreshGeometry() return; } + QSharedPointer origin; + if (object1Id != NULL_ID) { - const QSharedPointer origin = Visualization::data->GeometricObject(object1Id); + origin = Visualization::data->GeometricObject(object1Id); DrawPoint(point, *origin, supportColor2); QLineF rLine; @@ -105,65 +107,69 @@ void VisToolRotation::RefreshGeometry() Visualization::toolTip = tr("Rotating angle = %1°, Shift - sticking angle, " "Mouse click - finish creation").arg(rLine.angle()); + } - int iPoint = -1; - int iCurve = -1; - for (int i = 0; i < objects.size(); ++i) + int iPoint = -1; + int iCurve = -1; + for (int i = 0; i < objects.size(); ++i) + { + const quint32 id = objects.at(i); + const QSharedPointer obj = Visualization::data->GetGObject(id); + + // This check helps to find missed objects in the switch + Q_STATIC_ASSERT_X(static_cast(GOType::Unknown) == 7, "Not all objects was handled."); + + switch(static_cast(obj->getType())) { - const quint32 id = objects.at(i); - const QSharedPointer obj = Visualization::data->GetGObject(id); - - // This check helps to find missed objects in the switch - Q_STATIC_ASSERT_X(static_cast(GOType::Unknown) == 7, "Not all objects was handled."); - - switch(static_cast(obj->getType())) + case GOType::Point: { - case GOType::Point: + const QSharedPointer p = Visualization::data->GeometricObject(id); + + ++iPoint; + QGraphicsEllipseItem *point = GetPoint(iPoint); + DrawPoint(point, *p, supportColor); + + ++iPoint; + point = GetPoint(iPoint); + + if (object1Id != NULL_ID) { - const QSharedPointer p = Visualization::data->GeometricObject(id); - - ++iPoint; - QGraphicsEllipseItem *point = GetPoint(iPoint); - DrawPoint(point, *p, supportColor); - - ++iPoint; - point = GetPoint(iPoint); DrawPoint(point, p->Rotate(*origin, angle), supportColor); - break; } - case GOType::Arc: - { - iCurve = AddCurve(*origin, id, iCurve); - break; - } - case GOType::EllipticalArc: - { - iCurve = AddCurve(*origin, id, iCurve); - break; - } - case GOType::Spline: - { - iCurve = AddCurve(*origin, id, iCurve); - break; - } - case GOType::SplinePath: - { - iCurve = AddCurve(*origin, id, iCurve); - break; - } - case GOType::CubicBezier: - { - iCurve = AddCurve(*origin, id, iCurve); - break; - } - case GOType::CubicBezierPath: - { - iCurve = AddCurve(*origin, id, iCurve); - break; - } - case GOType::Unknown: - break; + break; } + case GOType::Arc: + { + iCurve = AddCurve(*origin, id, iCurve); + break; + } + case GOType::EllipticalArc: + { + iCurve = AddCurve(*origin, id, iCurve); + break; + } + case GOType::Spline: + { + iCurve = AddCurve(*origin, id, iCurve); + break; + } + case GOType::SplinePath: + { + iCurve = AddCurve(*origin, id, iCurve); + break; + } + case GOType::CubicBezier: + { + iCurve = AddCurve(*origin, id, iCurve); + break; + } + case GOType::CubicBezierPath: + { + iCurve = AddCurve(*origin, id, iCurve); + break; + } + case GOType::Unknown: + break; } } } @@ -253,8 +259,11 @@ int VisToolRotation::AddCurve(const QPointF &origin, quint32 id, int i) ++i; path = GetCurve(i); - const Item rotated = curve->Rotate(origin, angle); - DrawPath(path, rotated.GetPath(PathDirection::Hide), mainColor, Qt::SolidLine, Qt::RoundCap); + if (object1Id != NULL_ID) + { + const Item rotated = curve->Rotate(origin, angle); + DrawPath(path, rotated.GetPath(PathDirection::Hide), mainColor, Qt::SolidLine, Qt::RoundCap); + } return i; }