Merge branch 'qtquick2' of scm.dev.nokia.troll.no:qt/qtdeclarative-staging into qtquick2
[profile/ivi/qtdeclarative.git] / src / declarative / particles / qsgangleddirection_p.h
1 /****************************************************************************
2 **
3 ** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
6 **
7 ** This file is part of the Declarative module of the Qt Toolkit.
8 **
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** No Commercial Usage
11 ** This file contains pre-release code and may not be distributed.
12 ** You may use this file in accordance with the terms and conditions
13 ** contained in the Technology Preview License Agreement accompanying
14 ** this package.
15 **
16 ** GNU Lesser General Public License Usage
17 ** Alternatively, this file may be used under the terms of the GNU Lesser
18 ** General Public License version 2.1 as published by the Free Software
19 ** Foundation and appearing in the file LICENSE.LGPL included in the
20 ** packaging of this file.  Please review the following information to
21 ** ensure the GNU Lesser General Public License version 2.1 requirements
22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23 **
24 ** In addition, as a special exception, Nokia gives you certain additional
25 ** rights.  These rights are described in the Nokia Qt LGPL Exception
26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27 **
28 ** If you have questions regarding the use of this file, please contact
29 ** Nokia at qt-info@nokia.com.
30 **
31 **
32 **
33 **
34 **
35 **
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 #ifndef QSGANGLEDDIRECTION_H
43 #define QSGANGLEDDIRECTION_H
44 #include "qsgstochasticdirection_p.h"
45 QT_BEGIN_HEADER
46
47 QT_BEGIN_NAMESPACE
48
49 QT_MODULE(Declarative)
50
51 class QSGAngledDirection : public QSGStochasticDirection
52 {
53     Q_OBJECT
54     Q_PROPERTY(qreal angle READ angle WRITE setAngle NOTIFY angleChanged)
55     Q_PROPERTY(qreal magnitude READ magnitude WRITE setMagnitude NOTIFY magnitudeChanged)
56     Q_PROPERTY(qreal angleVariation READ angleVariation WRITE setAngleVariation NOTIFY angleVariationChanged)
57     Q_PROPERTY(qreal magnitudeVariation READ magnitudeVariation WRITE setMagnitudeVariation NOTIFY magnitudeVariationChanged)
58 public:
59     explicit QSGAngledDirection(QObject *parent = 0);
60     const QPointF &sample(const QPointF &from);
61     qreal angle() const
62     {
63         return m_angle;
64     }
65
66     qreal magnitude() const
67     {
68         return m_magnitude;
69     }
70
71     qreal angleVariation() const
72     {
73         return m_angleVariation;
74     }
75
76     qreal magnitudeVariation() const
77     {
78         return m_magnitudeVariation;
79     }
80
81 signals:
82
83     void angleChanged(qreal arg);
84
85     void magnitudeChanged(qreal arg);
86
87     void angleVariationChanged(qreal arg);
88
89     void magnitudeVariationChanged(qreal arg);
90
91 public slots:
92 void setAngle(qreal arg)
93 {
94     if (m_angle != arg) {
95         m_angle = arg;
96         emit angleChanged(arg);
97     }
98 }
99
100 void setMagnitude(qreal arg)
101 {
102     if (m_magnitude != arg) {
103         m_magnitude = arg;
104         emit magnitudeChanged(arg);
105     }
106 }
107
108 void setAngleVariation(qreal arg)
109 {
110     if (m_angleVariation != arg) {
111         m_angleVariation = arg;
112         emit angleVariationChanged(arg);
113     }
114 }
115
116 void setMagnitudeVariation(qreal arg)
117 {
118     if (m_magnitudeVariation != arg) {
119         m_magnitudeVariation = arg;
120         emit magnitudeVariationChanged(arg);
121     }
122 }
123
124 private:
125 qreal m_angle;
126 qreal m_magnitude;
127 qreal m_angleVariation;
128 qreal m_magnitudeVariation;
129 };
130
131 QT_END_NAMESPACE
132 QT_END_HEADER
133 #endif // QSGANGLEDDIRECTION_H