ee44591394eff4d93a6ecada3f88d3e53642585b
[profile/ivi/qtdeclarative.git] / src / quick / particles / qquickpointattractor_p.h
1 /****************************************************************************
2 **
3 ** Copyright (C) 2012 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 ** GNU Lesser General Public License Usage
11 ** This file may be used under the terms of the GNU Lesser General Public
12 ** License version 2.1 as published by the Free Software Foundation and
13 ** appearing in the file LICENSE.LGPL included in the packaging of this
14 ** file. Please review the following information to ensure the GNU Lesser
15 ** General Public License version 2.1 requirements will be met:
16 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
17 **
18 ** In addition, as a special exception, Nokia gives you certain additional
19 ** rights. These rights are described in the Nokia Qt LGPL Exception
20 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
21 **
22 ** GNU General Public License Usage
23 ** Alternatively, this file may be used under the terms of the GNU General
24 ** Public License version 3.0 as published by the Free Software Foundation
25 ** and appearing in the file LICENSE.GPL included in the packaging of this
26 ** file. Please review the following information to ensure the GNU General
27 ** Public License version 3.0 requirements will be met:
28 ** http://www.gnu.org/copyleft/gpl.html.
29 **
30 ** Other Usage
31 ** Alternatively, this file may be used in accordance with the terms and
32 ** conditions contained in a signed written agreement between you and Nokia.
33 **
34 **
35 **
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 #ifndef ATTRACTORAFFECTOR_H
43 #define ATTRACTORAFFECTOR_H
44 #include "qquickparticleaffector_p.h"
45
46 QT_BEGIN_HEADER
47
48 QT_BEGIN_NAMESPACE
49
50 class QQuickAttractorAffector : public QQuickParticleAffector
51 {
52     Q_OBJECT
53     Q_PROPERTY(qreal strength READ strength WRITE setStrength NOTIFY strengthChanged)
54     Q_PROPERTY(qreal pointX READ pointX WRITE setPointX NOTIFY pointXChanged)
55     Q_PROPERTY(qreal pointY READ pointY WRITE setPointY NOTIFY pointYChanged)
56     Q_PROPERTY(AffectableParameters affectedParameter READ affectedParameter WRITE setAffectedParameter NOTIFY affectedParameterChanged)
57     Q_PROPERTY(Proportion proportionalToDistance READ proportionalToDistance WRITE setProportionalToDistance NOTIFY proportionalToDistanceChanged)
58     Q_ENUMS(AffectableParameters)
59     Q_ENUMS(Proportion)
60
61 public:
62     enum Proportion{
63         Constant,
64         Linear,
65         Quadratic,
66         InverseLinear,
67         InverseQuadratic
68     };
69
70     enum AffectableParameters {
71         Position,
72         Velocity,
73         Acceleration
74     };
75
76     explicit QQuickAttractorAffector(QQuickItem *parent = 0);
77
78     qreal strength() const
79     {
80         return m_strength;
81     }
82
83     qreal pointX() const
84     {
85         return m_x;
86     }
87
88     qreal pointY() const
89     {
90         return m_y;
91     }
92
93     AffectableParameters affectedParameter() const
94     {
95         return m_physics;
96     }
97
98     Proportion proportionalToDistance() const
99     {
100         return m_proportionalToDistance;
101     }
102
103 signals:
104
105     void strengthChanged(qreal arg);
106
107     void pointXChanged(qreal arg);
108
109     void pointYChanged(qreal arg);
110
111     void affectedParameterChanged(AffectableParameters arg);
112
113     void proportionalToDistanceChanged(Proportion arg);
114
115 public slots:
116 void setStrength(qreal arg)
117 {
118     if (m_strength != arg) {
119         m_strength = arg;
120         emit strengthChanged(arg);
121     }
122 }
123
124 void setPointX(qreal arg)
125 {
126     if (m_x != arg) {
127         m_x = arg;
128         emit pointXChanged(arg);
129     }
130 }
131
132 void setPointY(qreal arg)
133 {
134     if (m_y != arg) {
135         m_y = arg;
136         emit pointYChanged(arg);
137     }
138 }
139 void setAffectedParameter(AffectableParameters arg)
140 {
141     if (m_physics != arg) {
142         m_physics = arg;
143         emit affectedParameterChanged(arg);
144     }
145 }
146
147 void setProportionalToDistance(Proportion arg)
148 {
149     if (m_proportionalToDistance != arg) {
150         m_proportionalToDistance = arg;
151         emit proportionalToDistanceChanged(arg);
152     }
153 }
154
155 protected:
156     virtual bool affectParticle(QQuickParticleData *d, qreal dt);
157 private:
158 qreal m_strength;
159 qreal m_x;
160 qreal m_y;
161 AffectableParameters m_physics;
162 Proportion m_proportionalToDistance;
163 };
164
165 QT_END_NAMESPACE
166 QT_END_HEADER
167 #endif // ATTRACTORAFFECTOR_H