Seamly2D
Code documentation
vcubicbezier.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 vcubicbezier.h
27  ** @author Roman Telezhynskyi <dismine(at)gmail.com>
28  ** @date 8 3, 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 VCUBICBEZIER_H
53 #define VCUBICBEZIER_H
54 
55 #include <qcompilerdetection.h>
56 #include <QPointF>
57 #include <QSharedDataPointer>
58 #include <QString>
59 #include <QTypeInfo>
60 #include <QVector>
61 #include <QtGlobal>
62 
63 #include "vabstractcubicbezier.h"
64 #include "vgeometrydef.h"
65 #include "vpointf.h"
66 
67 class VCubicBezierData;
68 
70 {
71 public:
72  VCubicBezier();
73  VCubicBezier(const VCubicBezier &curve);
74  VCubicBezier(const VPointF &p1, const VPointF &p2, const VPointF &p3, const VPointF &p4, quint32 idObject = 0,
75  Draw mode = Draw::Calculation);
76  VCubicBezier Rotate(const QPointF &originPoint, qreal degrees, const QString &prefix = QString()) const;
77  VCubicBezier Flip(const QLineF &axis, const QString &prefix = QString()) const;
78  VCubicBezier Move(qreal length, qreal angle, const QString &prefix = QString()) const;
79  virtual ~VCubicBezier();
80 
81  VCubicBezier &operator=(const VCubicBezier &curve);
82 #ifdef Q_COMPILER_RVALUE_REFS
83  VCubicBezier &operator=(VCubicBezier &&curve) Q_DECL_NOTHROW;
84 #endif
85 
86  void Swap(VCubicBezier &curve) Q_DECL_NOTHROW;
87 
88  virtual VPointF GetP1() const Q_DECL_OVERRIDE;
89  void SetP1(const VPointF &p);
90 
91  virtual VPointF GetP2() const Q_DECL_OVERRIDE;
92  void SetP2(const VPointF &p);
93 
94  virtual VPointF GetP3() const Q_DECL_OVERRIDE;
95  void SetP3(const VPointF &p);
96 
97  virtual VPointF GetP4() const Q_DECL_OVERRIDE;
98  void SetP4(const VPointF &p);
99 
100  virtual qreal GetStartAngle() const Q_DECL_OVERRIDE;
101  virtual qreal GetEndAngle() const Q_DECL_OVERRIDE;
102  virtual qreal GetLength() const Q_DECL_OVERRIDE;
103  virtual QVector<QPointF> getPoints() const Q_DECL_OVERRIDE;
104 
105  virtual qreal GetC1Length() const Q_DECL_OVERRIDE;
106  virtual qreal GetC2Length() const Q_DECL_OVERRIDE;
107 
108 protected:
109  virtual QPointF GetControlPoint1() const Q_DECL_OVERRIDE;
110  virtual QPointF GetControlPoint2() const Q_DECL_OVERRIDE;
111 
112 private:
113  QSharedDataPointer<VCubicBezierData> d;
114 };
115 
117 
118 #endif // VCUBICBEZIER_H
virtual qreal GetC2Length() const Q_DECL_OVERRIDE
virtual qreal GetStartAngle() const Q_DECL_OVERRIDE
void Swap(VCubicBezier &curve) Q_DECL_NOTHROW
void SetP4(const VPointF &p)
void SetP3(const VPointF &p)
virtual QPointF GetControlPoint1() const Q_DECL_OVERRIDE
virtual qreal GetEndAngle() const Q_DECL_OVERRIDE
virtual VPointF GetP1() const Q_DECL_OVERRIDE
QSharedDataPointer< VCubicBezierData > d
Definition: vcubicbezier.h:113
VCubicBezier Rotate(const QPointF &originPoint, qreal degrees, const QString &prefix=QString()) const
virtual qreal GetC1Length() const Q_DECL_OVERRIDE
VCubicBezier Move(qreal length, qreal angle, const QString &prefix=QString()) const
VCubicBezier & operator=(const VCubicBezier &curve)
virtual VPointF GetP3() const Q_DECL_OVERRIDE
void SetP1(const VPointF &p)
virtual QPointF GetControlPoint2() const Q_DECL_OVERRIDE
virtual qreal GetLength() const Q_DECL_OVERRIDE
GetLength return length of cubic bezier curve.
virtual VPointF GetP2() const Q_DECL_OVERRIDE
void SetP2(const VPointF &p)
VCubicBezier Flip(const QLineF &axis, const QString &prefix=QString()) const
virtual QVector< QPointF > getPoints() const Q_DECL_OVERRIDE
GetPoints return list with cubic bezier curve points.
virtual ~VCubicBezier()
virtual VPointF GetP4() const Q_DECL_OVERRIDE
The VPointF class keep data of point.
Definition: vpointf.h:75
Q_DECLARE_TYPEINFO(VCubicBezier, Q_MOVABLE_TYPE)
Draw
Definition: vgeometrydef.h:55
@ Calculation