Seamly2D
Code documentation
visoperation.h
Go to the documentation of this file.
1 /***************************************************************************
2  * *
3  * Copyright (C) 2017 Seamly, LLC *
4  * *
5  * https://github.com/fashionfreedom/seamly2d *
6  * *
7  ***************************************************************************
8  **
9  ** Seamly2D is free software: you can redistribute it and/or modify
10  ** it under the terms of the GNU General Public License as published by
11  ** the Free Software Foundation, either version 3 of the License, or
12  ** (at your option) any later version.
13  **
14  ** Seamly2D is distributed in the hope that it will be useful,
15  ** but WITHOUT ANY WARRANTY; without even the implied warranty of
16  ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  ** GNU General Public License for more details.
18  **
19  ** You should have received a copy of the GNU General Public License
20  ** along with Seamly2D. If not, see <http://www.gnu.org/licenses/>.
21  **
22  **************************************************************************
23 
24  ************************************************************************
25  **
26  ** @file
27  ** @author Roman Telezhynskyi <dismine(at)gmail.com>
28  ** @date 12 9, 2016
29  **
30  ** @brief
31  ** @copyright
32  ** This source code is part of the Valentine project, a pattern making
33  ** program, whose allow create and modeling patterns of clothing.
34  ** Copyright (C) 2016 Seamly2D project
35  ** <https://github.com/fashionfreedom/seamly2d> All Rights Reserved.
36  **
37  ** Seamly2D is free software: you can redistribute it and/or modify
38  ** it under the terms of the GNU General Public License as published by
39  ** the Free Software Foundation, either version 3 of the License, or
40  ** (at your option) any later version.
41  **
42  ** Seamly2D is distributed in the hope that it will be useful,
43  ** but WITHOUT ANY WARRANTY; without even the implied warranty of
44  ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
45  ** GNU General Public License for more details.
46  **
47  ** You should have received a copy of the GNU General Public License
48  ** along with Seamly2D. If not, see <http://www.gnu.org/licenses/>.
49  **
50  *************************************************************************/
51 
52 #ifndef VISOPERATION_H
53 #define VISOPERATION_H
54 
55 #include <QtGlobal>
56 
57 #include "../visline.h"
58 #include "../vpatterndb/vcontainer.h"
59 
60 class VisOperation : public VisLine
61 {
62  Q_OBJECT
63 public:
64  explicit VisOperation(const VContainer *data, QGraphicsItem *parent = nullptr);
65  virtual ~VisOperation();
66 
68 
69  virtual void VisualMode(const quint32 &pointId = NULL_ID) Q_DECL_OVERRIDE;
70 
71  virtual int type() const Q_DECL_OVERRIDE {return Type;}
72  enum {Type = UserType + static_cast<int>(Vis::ToolRotation)};
73 protected:
75  QColor supportColor2;
76  QColor supportColor3;
77 
80 
81  VScaledEllipse *GetPoint(quint32 i, const QColor &color);
82  VCurvePathItem *GetCurve(quint32 i, const QColor &color);
83 
84  template <class Item>
85  int addFlippedCurve(const QPointF &firstPoint, const QPointF &secondPoint, quint32 id, int i);
86 
87  void refreshMirroredObjects(const QPointF &firstPoint, const QPointF &secondPoint);
88 private:
89  Q_DISABLE_COPY(VisOperation)
90 };
91 
92 //---------------------------------------------------------------------------------------------------------------------
93 template <class Item>
94 int VisOperation::addFlippedCurve(const QPointF &firstPoint, const QPointF &secondPoint, quint32 id, int i)
95 {
96  const QSharedPointer<Item> curve = Visualization::data->template GeometricObject<Item>(id);
97 
98  ++i;
99  VCurvePathItem *path = GetCurve(static_cast<quint32>(i), supportColor2);
100  DrawPath(path, curve->GetPath(), curve->DirectionArrows(), supportColor2, Qt::SolidLine,
101  lineWeight, Qt::RoundCap);
102 
103  ++i;
104  path = GetCurve(static_cast<quint32>(i), supportColor);
105  if (object1Id != NULL_ID)
106  {
107  const Item flipped = curve->Flip(QLineF(firstPoint, secondPoint));
108  DrawPath(path, flipped.GetPath(), flipped.DirectionArrows(), supportColor, Qt::SolidLine,
109  lineWeight, Qt::RoundCap);
110  }
111 
112  return i;
113 }
114 
115 #endif // VISOPERATION_H
The VContainer class container of all variables.
Definition: vcontainer.h:141
void setObjects(QVector< quint32 > objects)
virtual void VisualMode(const quint32 &pointId=NULL_ID) Q_DECL_OVERRIDE
QVector< VScaledEllipse * > points
Definition: visoperation.h:78
void refreshMirroredObjects(const QPointF &firstPoint, const QPointF &secondPoint)
VCurvePathItem * GetCurve(quint32 i, const QColor &color)
virtual int type() const Q_DECL_OVERRIDE
Definition: visoperation.h:71
VisOperation(const VContainer *data, QGraphicsItem *parent=nullptr)
QColor supportColor3
Definition: visoperation.h:76
VScaledEllipse * GetPoint(quint32 i, const QColor &color)
QVector< quint32 > objects
Definition: visoperation.h:74
QColor supportColor2
Definition: visoperation.h:75
QVector< VCurvePathItem * > curves
Definition: visoperation.h:79
int addFlippedCurve(const QPointF &firstPoint, const QPointF &secondPoint, quint32 id, int i)
Definition: visoperation.h:94
virtual ~VisOperation()
QColor supportColor
const VContainer * data
Definition: visualization.h:97
void DrawPath(VCurvePathItem *pathItem, const QPainterPath &path, const QColor &color, Qt::PenStyle style=Qt::SolidLine, const qreal &weight=0.35, Qt::PenCapStyle cap=Qt::SquareCap)
quint32 object1Id
@ ToolRotation
#define NULL_ID
Definition: ifcdef.h:76