Seamly2D
Code documentation
vcurveangle.cpp
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 vcurveangle.cpp
27  ** @author Roman Telezhynskyi <dismine(at)gmail.com>
28  ** @date 1 6, 2015
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) 2015 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 #include "vcurveangle.h"
53 
54 #include <QLatin1String>
55 #include <QMessageLogger>
56 
57 #include "../vmisc/def.h"
58 #include "../ifc/ifcdef.h"
59 #include "../vgeometry/vabstractcurve.h"
60 #include "../vgeometry/vspline.h"
61 #include "vcurvevariable.h"
62 
63 //---------------------------------------------------------------------------------------------------------------------
66 {
68 }
69 
70 //---------------------------------------------------------------------------------------------------------------------
71 VCurveAngle::VCurveAngle(const quint32 &id, const quint32 &parentId, const VAbstractCurve *curve, CurveAngle angle)
72  :VCurveVariable(id, parentId)
73 {
75  SCASSERT(curve != nullptr)
76  if (angle == CurveAngle::StartAngle)
77  {
78  SetValue(curve->GetStartAngle());
79  SetName(angle1_V + curve->name());
80  }
81  else
82  {
83  SetValue(curve->GetEndAngle());
84  SetName(angle2_V + curve->name());
85  }
86 }
87 
88 //---------------------------------------------------------------------------------------------------------------------
89 VCurveAngle::VCurveAngle(const quint32 &id, const quint32 &parentId, const QString &baseCurveName, const VSpline &spl,
90  CurveAngle angle, qint32 segment)
91  :VCurveVariable(id, parentId)
92 {
94  if (angle == CurveAngle::StartAngle)
95  {
96  SetValue(spl.GetStartAngle());
97  SetName(angle1_V + baseCurveName + QLatin1String("_") + seg_ + QString().setNum(segment));
98  }
99  else
100  {
101  SetValue(spl.GetEndAngle());
102  SetName(angle2_V + baseCurveName + QLatin1String("_") + seg_ + QString().setNum(segment));
103  }
104 }
105 
106 //---------------------------------------------------------------------------------------------------------------------
108  :VCurveVariable(var)
109 {}
110 
111 //---------------------------------------------------------------------------------------------------------------------
113 {
114  if ( &var == this )
115  {
116  return *this;
117  }
119  return *this;
120 }
121 
122 //---------------------------------------------------------------------------------------------------------------------
124 {}
virtual qreal GetEndAngle() const =0
virtual qreal GetStartAngle() const =0
VCurveAngle & operator=(const VCurveAngle &var)
virtual ~VCurveAngle() Q_DECL_OVERRIDE
VCurveVariable & operator=(const VCurveVariable &var)
virtual QString name() const
name return name graphical object.
Definition: vgobject.cpp:148
void SetType(const VarType &type)
void SetValue(const qreal &value)
void SetName(const QString &name)
VSpline class that implements the spline.
Definition: vspline.h:75
virtual qreal GetStartAngle() const Q_DECL_OVERRIDE
GetAngle1 return first angle control line.
Definition: vspline.cpp:337
virtual qreal GetEndAngle() const Q_DECL_OVERRIDE
GetAngle2 return second angle control line.
Definition: vspline.cpp:347
#define SCASSERT(cond)
Definition: def.h:317
const QString seg_
Definition: ifcdef.cpp:440
const QString angle2_V
Definition: ifcdef.cpp:425
const QString angle1_V
Definition: ifcdef.cpp:424
CurveAngle
Definition: vcurveangle.h:64