Seamly2D
Code documentation
varcradius.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 varcradius.cpp
27  ** @author Roman Telezhynskyi <dismine(at)gmail.com>
28  ** @date 30 5, 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 "varcradius.h"
53 
54 #include <QMessageLogger>
55 #include <QString>
56 
57 #include "../ifc/ifcdef.h"
58 #include "../vgeometry/varc.h"
59 #include "../vgeometry/vellipticalarc.h"
60 
61 //---------------------------------------------------------------------------------------------------------------------
64 {
66 }
67 
68 //---------------------------------------------------------------------------------------------------------------------
69 VArcRadius::VArcRadius(const quint32 &id, const quint32 &parentId, const VArc *arc, Unit patternUnit)
70  :VCurveVariable(id, parentId)
71 {
72  SCASSERT(arc != nullptr)
73 
75  SetName(radius_V + QString("%1").arg(arc->name()));
76  SetValue(FromPixel(arc->GetRadius(), patternUnit));
77 }
78 
79 //---------------------------------------------------------------------------------------------------------------------
80 VArcRadius::VArcRadius(const quint32 &id, const quint32 &parentId, const VEllipticalArc *elArc, const int numberRadius,
81  Unit patternUnit)
82  : VCurveVariable(id, parentId)
83 {
84  SCASSERT(elArc != nullptr)
85 
87  SetName(radius_V + QString("%1%2").arg(numberRadius).arg(elArc->name()));
88  if (numberRadius == 1)
89  {
90  SetValue(FromPixel(elArc->GetRadius1(), patternUnit));
91  }
92  else
93  {
94  SetValue(FromPixel(elArc->GetRadius2(), patternUnit));
95  }
96 }
97 
98 //---------------------------------------------------------------------------------------------------------------------
100  :VCurveVariable(var)
101 {}
102 
103 //---------------------------------------------------------------------------------------------------------------------
105 {
106  if ( &var == this )
107  {
108  return *this;
109  }
111  return *this;
112 }
113 
114 //---------------------------------------------------------------------------------------------------------------------
116 {}
VArcRadius & operator=(const VArcRadius &var)
Definition: varcradius.cpp:104
virtual ~VArcRadius() Q_DECL_OVERRIDE
Definition: varcradius.cpp:115
VArc class for anticlockwise arc.
Definition: varc.h:74
qreal GetRadius() const
GetRadius return formula for radius.
Definition: varc.cpp:482
VCurveVariable & operator=(const VCurveVariable &var)
qreal GetRadius2() const
GetRadius2 return elliptical arc minor radius.
qreal GetRadius1() const
GetRadius1 return elliptical arc major radius.
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)
double FromPixel(double pix, const Unit &unit)
Definition: def.cpp:250
#define SCASSERT(cond)
Definition: def.h:317
Unit
Definition: def.h:105
const QString radius_V
Definition: ifcdef.cpp:420