Seamly2D
Code documentation
vlineangle.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 vlineangle.cpp
27  ** @author Roman Telezhynskyi <dismine(at)gmail.com>
28  ** @date 28 7, 2014
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) 2013-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 "vlineangle.h"
53 
54 #include <QLineF>
55 #include <QMessageLogger>
56 #include <QPointF>
57 #include <QString>
58 
59 #include "../vmisc/def.h"
60 #include "../vmisc/vmath.h"
61 #include "../ifc/ifcdef.h"
62 #include "../vgeometry/vpointf.h"
63 #include "vinternalvariable.h"
64 #include "vlineangle_p.h"
65 
66 #ifdef Q_COMPILER_RVALUE_REFS
67 VLineAngle &VLineAngle::operator=(VLineAngle &&var) Q_DECL_NOTHROW
68 { Swap(var); return *this; }
69 #endif
70 
71 void VLineAngle::Swap(VLineAngle &var) Q_DECL_NOTHROW
72 { VInternalVariable::Swap(var); std::swap(d, var.d); }
73 
74 //---------------------------------------------------------------------------------------------------------------------
77 {
79 }
80 
81 //---------------------------------------------------------------------------------------------------------------------
82 VLineAngle::VLineAngle(const VPointF *p1, const quint32 &p1Id, const VPointF *p2, const quint32 &p2Id)
83  :VInternalVariable(), d(new VLineAngleData(p1Id, p2Id))
84 {
86 
87  SCASSERT(p1 != nullptr)
88  SCASSERT(p2 != nullptr)
89 
90  SetName(QString(angleLine_+"%1_%2").arg(p1->name(), p2->name()));
91  SetValue(p1, p2);
92 }
93 
94 //---------------------------------------------------------------------------------------------------------------------
96  :VInternalVariable(var), d(var.d)
97 {}
98 
99 //---------------------------------------------------------------------------------------------------------------------
101 {
102  if ( &var == this )
103  {
104  return *this;
105  }
107  d = var.d;
108  return *this;
109 }
110 
111 //---------------------------------------------------------------------------------------------------------------------
113 {}
114 
115 //---------------------------------------------------------------------------------------------------------------------
116 bool VLineAngle::Filter(quint32 id)
117 {
118  return id == d->p1Id || id == d->p2Id;
119 }
120 
121 //---------------------------------------------------------------------------------------------------------------------
122 void VLineAngle::SetValue(const VPointF *p1, const VPointF *p2)
123 {
124  SCASSERT(p1 != nullptr)
125  SCASSERT(p2 != nullptr)
126  //Correct angle. Try avoid results like 6,7563e-15.
127  const qreal angle = qFloor(QLineF(static_cast<QPointF>(*p1),
128  static_cast<QPointF>(*p2)).angle() * 100000.) / 100000.;
130 }
131 
132 //---------------------------------------------------------------------------------------------------------------------
133 // cppcheck-suppress unusedFunction
134 quint32 VLineAngle::GetP1Id() const
135 {
136  return d->p1Id;
137 }
138 
139 //---------------------------------------------------------------------------------------------------------------------
140 // cppcheck-suppress unusedFunction
141 quint32 VLineAngle::GetP2Id() const
142 {
143  return d->p2Id;
144 }
virtual QString name() const
name return name graphical object.
Definition: vgobject.cpp:148
void SetType(const VarType &type)
void SetValue(const qreal &value)
void Swap(VInternalVariable &var) Q_DECL_NOTHROW
void SetName(const QString &name)
VInternalVariable & operator=(const VInternalVariable &var)
quint32 GetP2Id() const
Definition: vlineangle.cpp:141
QSharedDataPointer< VLineAngleData > d
Definition: vlineangle.h:86
virtual bool Filter(quint32 id) Q_DECL_OVERRIDE
Definition: vlineangle.cpp:116
VLineAngle & operator=(const VLineAngle &var)
Definition: vlineangle.cpp:100
quint32 GetP1Id() const
Definition: vlineangle.cpp:134
void Swap(VLineAngle &var) Q_DECL_NOTHROW
Definition: vlineangle.cpp:71
void SetValue(const VPointF *p1, const VPointF *p2)
Definition: vlineangle.cpp:122
virtual ~VLineAngle() Q_DECL_OVERRIDE
Definition: vlineangle.cpp:112
The VPointF class keep data of point.
Definition: vpointf.h:75
#define SCASSERT(cond)
Definition: def.h:317
const QString angleLine_
Definition: ifcdef.cpp:415