Commit 57815987 authored by Alan Alpert's avatar Alan Alpert Committed by Qt by Nokia
Browse files

Add noCap and startTime properties to Emitter

Change-Id: I8498b2e574a32bfbab9f139e718424572b1258a0
Reviewed-on: http://codereview.qt.nokia.com/2855


Reviewed-by: default avatarAlan Alpert <alan.alpert@nokia.com>
Reviewed-by: default avatarQt Sanity Bot <qt_sanity_bot@ovi.com>
parent f5db9800
dev 5.10 5.11 5.12 5.12.1 5.12.10 5.12.11 5.12.12 5.12.2 5.12.3 5.12.4 5.12.5 5.12.6 5.12.7 5.12.8 5.12.9 5.13 5.13.0 5.13.1 5.13.2 5.14 5.14.0 5.14.1 5.14.2 5.15 5.15.0 5.15.1 5.15.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 5.9.8 6.0 6.0.0 6.1 6.1.0 6.1.1 6.1.2 6.1.3 6.2 6.2.0 6.2.1 6.2.2 old/5.0 old/5.1 old/5.2 wip/animation-refactor wip/cmake wip/dbus wip/gc wip/itemviews wip/nacl wip/new-backend wip/pointerhandler wip/propertycache-refactor wip/qquickdeliveryagent wip/scenegraphng wip/tizen wip/webassembly v5.15.0-alpha1 v5.14.1 v5.14.0 v5.14.0-rc2 v5.14.0-rc1 v5.14.0-beta3 v5.14.0-beta2 v5.14.0-beta1 v5.14.0-alpha1 v5.13.2 v5.13.1 v5.13.0 v5.13.0-rc3 v5.13.0-rc2 v5.13.0-rc1 v5.13.0-beta4 v5.13.0-beta3 v5.13.0-beta2 v5.13.0-beta1 v5.13.0-alpha1 v5.12.7 v5.12.6 v5.12.5 v5.12.4 v5.12.3 v5.12.2 v5.12.1 v5.12.0 v5.12.0-rc2 v5.12.0-rc1 v5.12.0-beta4 v5.12.0-beta3 v5.12.0-beta2 v5.12.0-beta1 v5.12.0-alpha1 v5.11.3 v5.11.2 v5.11.1 v5.11.0 v5.11.0-rc2 v5.11.0-rc1 v5.11.0-beta4 v5.11.0-beta3 v5.11.0-beta2 v5.11.0-beta1 v5.11.0-alpha1 v5.10.1 v5.10.0 v5.10.0-rc3 v5.10.0-rc2 v5.10.0-rc1 v5.10.0-beta4 v5.10.0-beta3 v5.10.0-beta2 v5.10.0-beta1 v5.10.0-alpha1 v5.9.9 v5.9.8 v5.9.7 v5.9.6 v5.9.5 v5.9.4 v5.9.3 v5.9.2 v5.9.1 v5.9.0 v5.9.0-rc2 v5.9.0-rc1 v5.9.0-beta4 v5.9.0-beta3 v5.9.0-beta2 v5.9.0-beta1 v5.9.0-alpha1 v5.8.0 v5.8.0-rc1 v5.8.0-beta1 v5.8.0-alpha1 v5.7.1 v5.7.0 v5.7.0-rc1 v5.7.0-beta1 v5.7.0-alpha1 v5.6.3 v5.6.2 v5.6.1 v5.6.1-1 v5.6.0 v5.6.0-rc1 v5.6.0-beta1 v5.6.0-alpha1 v5.5.1 v5.5.0 v5.5.0-rc1 v5.5.0-beta1 v5.5.0-alpha1 v5.4.2 v5.4.1 v5.4.0 v5.4.0-rc1 v5.4.0-beta1 v5.4.0-alpha1 v5.3.2 v5.3.1 v5.3.0 v5.3.0-rc1 v5.3.0-beta1 v5.3.0-alpha1 v5.2.1 v5.2.0 v5.2.0-rc1 v5.2.0-beta1 v5.2.0-alpha1 v5.1.1 v5.1.0 v5.1.0-rc2 v5.1.0-rc1 v5.1.0-beta1 v5.1.0-alpha1 v5.0.2 v5.0.1 v5.0.0 v5.0.0-rc2 v5.0.0-rc1 v5.0.0-beta2 v5.0.0-beta1 qt-v5.0.0-alpha1
No related merge requests found
Showing with 64 additions and 7 deletions
...@@ -61,7 +61,6 @@ Rectangle{ ...@@ -61,7 +61,6 @@ Rectangle{
x: ma.mouseX x: ma.mouseX
y: ma.mouseY y: ma.mouseY
emitRate: 16000 emitRate: 16000
lifeSpan: 1000
emitCap: 4000 emitCap: 4000
acceleration: AngledDirection{angleVariation: 360; magnitude: 360; } acceleration: AngledDirection{angleVariation: 360; magnitude: 360; }
size: 8 size: 8
...@@ -75,7 +74,7 @@ Rectangle{ ...@@ -75,7 +74,7 @@ Rectangle{
MouseArea{ MouseArea{
width: 100 width: 100
height: 100 height: 100
onClicked: sys.overwrite = !sys.overwrite onClicked: bursty.noCap = true;
id: ma2 id: ma2
Rectangle{ Rectangle{
anchors.fill: parent anchors.fill: parent
......
...@@ -134,6 +134,7 @@ void QSGFollowEmitter::emitWindow(int timeStamp) ...@@ -134,6 +134,7 @@ void QSGFollowEmitter::emitWindow(int timeStamp)
} }
} }
//TODO: Implement startTime and speedFromMovement
qreal time = timeStamp / 1000.; qreal time = timeStamp / 1000.;
qreal particleRatio = 1. / m_particlesPerParticlePerSecond; qreal particleRatio = 1. / m_particlesPerParticlePerSecond;
qreal pt; qreal pt;
...@@ -158,7 +159,7 @@ void QSGFollowEmitter::emitWindow(int timeStamp) ...@@ -158,7 +159,7 @@ void QSGFollowEmitter::emitWindow(int timeStamp)
continue; continue;
} }
while (pt < time || !m_burstQueue.isEmpty()){ while (pt < time || !m_burstQueue.isEmpty()){
QSGParticleData* datum = m_system->newDatum(gId2); QSGParticleData* datum = m_system->newDatum(gId2, !m_overwrite);
if (datum){//else, skip this emission if (datum){//else, skip this emission
datum->e = this;//###useful? datum->e = this;//###useful?
......
...@@ -110,6 +110,7 @@ QT_BEGIN_NAMESPACE ...@@ -110,6 +110,7 @@ QT_BEGIN_NAMESPACE
Default value is 0. Default value is 0.
*/ */
/*! /*!
\qmlproperty int QtQuick.Particles2::Emitter::emitCap \qmlproperty int QtQuick.Particles2::Emitter::emitCap
...@@ -119,6 +120,21 @@ QT_BEGIN_NAMESPACE ...@@ -119,6 +120,21 @@ QT_BEGIN_NAMESPACE
to stagger emissions. The default value is emitRate * lifeSpan in seconds, which to stagger emissions. The default value is emitRate * lifeSpan in seconds, which
is the number of particles that would be alive at any one time given the default settings. is the number of particles that would be alive at any one time given the default settings.
*/ */
/*!
\qmlproperty bool QtQuick.Particles2::Emitter::noCap
If set to true, the emitCap will be ignored and this emitter will never skip emitting
a particle based on how many it has alive.
Default value is false.
*/
/*!
\qmlproperty int QtQuick.Particles2::Emitter::startTime
If this value is set when the emitter is loaded, then it will emit particles from the
past, up to startTime milliseconds ago. These will simulate as if they were emitted then,
but will not have any affectors applied to them. Affectors will take effect from the present time.
*/
/*! /*!
\qmlproperty real QtQuick.Particles2::Emitter::size \qmlproperty real QtQuick.Particles2::Emitter::size
...@@ -184,8 +200,10 @@ QSGParticleEmitter::QSGParticleEmitter(QSGItem *parent) : ...@@ -184,8 +200,10 @@ QSGParticleEmitter::QSGParticleEmitter(QSGItem *parent) :
, m_speed_from_movement(0) , m_speed_from_movement(0)
, m_particle_count(0) , m_particle_count(0)
, m_reset_last(true) , m_reset_last(true)
, m_last_timestamp(0) , m_last_timestamp(-1)
, m_last_emission(0) , m_last_emission(0)
, m_startTime(0)
, m_overwrite(false)
{ {
//TODO: Reset speed/acc back to null vector? Or allow null pointer? //TODO: Reset speed/acc back to null vector? Or allow null pointer?
...@@ -297,7 +315,10 @@ void QSGParticleEmitter::emitWindow(int timeStamp) ...@@ -297,7 +315,10 @@ void QSGParticleEmitter::emitWindow(int timeStamp)
if (m_reset_last) { if (m_reset_last) {
m_last_emitter = m_last_last_emitter = QPointF(x(), y()); m_last_emitter = m_last_last_emitter = QPointF(x(), y());
m_last_timestamp = timeStamp/1000.; if (m_last_timestamp == -1)
m_last_timestamp = timeStamp/1000. - m_startTime;
else
m_last_timestamp = timeStamp/1000.;
m_last_emission = m_last_timestamp; m_last_emission = m_last_timestamp;
m_reset_last = false; m_reset_last = false;
} }
...@@ -339,7 +360,7 @@ void QSGParticleEmitter::emitWindow(int timeStamp) ...@@ -339,7 +360,7 @@ void QSGParticleEmitter::emitWindow(int timeStamp)
pt = time; pt = time;
while (pt < time || !m_burstQueue.isEmpty()) { while (pt < time || !m_burstQueue.isEmpty()) {
//int pos = m_last_particle % m_particle_count; //int pos = m_last_particle % m_particle_count;
QSGParticleData* datum = m_system->newDatum(m_system->m_groupIds[m_particle]); QSGParticleData* datum = m_system->newDatum(m_system->m_groupIds[m_particle], !m_overwrite);
if (datum){//actually emit(otherwise we've been asked to skip this one) if (datum){//actually emit(otherwise we've been asked to skip this one)
datum->e = this;//###useful? datum->e = this;//###useful?
qreal t = 1 - (pt - opt) / dt; qreal t = 1 - (pt - opt) / dt;
......
...@@ -64,6 +64,8 @@ class QSGParticleEmitter : public QSGItem ...@@ -64,6 +64,8 @@ class QSGParticleEmitter : public QSGItem
Q_PROPERTY(QString particle READ particle WRITE setParticle NOTIFY particleChanged) Q_PROPERTY(QString particle READ particle WRITE setParticle NOTIFY particleChanged)
Q_PROPERTY(QSGParticleExtruder* shape READ extruder WRITE setExtruder NOTIFY extruderChanged) Q_PROPERTY(QSGParticleExtruder* shape READ extruder WRITE setExtruder NOTIFY extruderChanged)
Q_PROPERTY(bool emitting READ emitting WRITE setEmitting NOTIFY emittingChanged) Q_PROPERTY(bool emitting READ emitting WRITE setEmitting NOTIFY emittingChanged)
Q_PROPERTY(int startTime READ startTime WRITE setStartTime NOTIFY startTimeChanged)
Q_PROPERTY(bool noCap READ overwrite WRITE setOverWrite NOTIFY overwriteChanged)
Q_PROPERTY(qreal emitRate READ particlesPerSecond WRITE setParticlesPerSecond NOTIFY particlesPerSecondChanged) Q_PROPERTY(qreal emitRate READ particlesPerSecond WRITE setParticlesPerSecond NOTIFY particlesPerSecondChanged)
Q_PROPERTY(int lifeSpan READ particleDuration WRITE setParticleDuration NOTIFY particleDurationChanged) Q_PROPERTY(int lifeSpan READ particleDuration WRITE setParticleDuration NOTIFY particleDurationChanged)
...@@ -144,6 +146,10 @@ signals: ...@@ -144,6 +146,10 @@ signals:
void speedFromMovementChanged(); void speedFromMovementChanged();
void startTimeChanged(int arg);
void overwriteChanged(bool arg);
public slots: public slots:
void pulse(qreal seconds); void pulse(qreal seconds);
void burst(int num); void burst(int num);
...@@ -241,6 +247,22 @@ public slots: ...@@ -241,6 +247,22 @@ public slots:
void setMaxParticleCount(int arg); void setMaxParticleCount(int arg);
void setStartTime(int arg)
{
if (m_startTime != arg) {
m_startTime = arg;
emit startTimeChanged(arg);
}
}
void setOverWrite(bool arg)
{
if (m_overwrite != arg) {
m_overwrite = arg;
emit overwriteChanged(arg);
}
}
public: public:
int particleCount() const; int particleCount() const;
...@@ -280,6 +302,16 @@ public: ...@@ -280,6 +302,16 @@ public:
return m_maxParticleCount; return m_maxParticleCount;
} }
int startTime() const
{
return m_startTime;
}
bool overwrite() const
{
return m_overwrite;
}
protected: protected:
qreal m_particlesPerSecond; qreal m_particlesPerSecond;
int m_particleDuration; int m_particleDuration;
...@@ -296,6 +328,10 @@ protected: ...@@ -296,6 +328,10 @@ protected:
qreal m_particleEndSize; qreal m_particleEndSize;
qreal m_particleSizeVariation; qreal m_particleSizeVariation;
qreal m_speedFromMovement;
int m_startTime;
bool m_overwrite;
int m_burstLeft;//TODO: Rename to pulse int m_burstLeft;//TODO: Rename to pulse
QList<QPair<int, QPointF > > m_burstQueue; QList<QPair<int, QPointF > > m_burstQueue;
int m_maxParticleCount; int m_maxParticleCount;
...@@ -314,7 +350,7 @@ protected: ...@@ -314,7 +350,7 @@ protected:
private: private:
QSGStochasticDirection m_nullVector; QSGStochasticDirection m_nullVector;
qreal m_speedFromMovement;
}; };
QT_END_NAMESPACE QT_END_NAMESPACE
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment