1 /****************************************************************************
3 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/
6 ** This file is part of the Declarative module of the Qt Toolkit.
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** GNU Lesser General Public License Usage
10 ** This file may be used under the terms of the GNU Lesser General Public
11 ** License version 2.1 as published by the Free Software Foundation and
12 ** appearing in the file LICENSE.LGPL included in the packaging of this
13 ** file. Please review the following information to ensure the GNU Lesser
14 ** General Public License version 2.1 requirements will be met:
15 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
17 ** In addition, as a special exception, Nokia gives you certain additional
18 ** rights. These rights are described in the Nokia Qt LGPL Exception
19 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
21 ** GNU General Public License Usage
22 ** Alternatively, this file may be used under the terms of the GNU General
23 ** Public License version 3.0 as published by the Free Software Foundation
24 ** and appearing in the file LICENSE.GPL included in the packaging of this
25 ** file. Please review the following information to ensure the GNU General
26 ** Public License version 3.0 requirements will be met:
27 ** http://www.gnu.org/copyleft/gpl.html.
30 ** Alternatively, this file may be used in accordance with the terms and
31 ** conditions contained in a signed written agreement between you and Nokia.
40 ****************************************************************************/
42 #include "qquickparticlepainter_p.h"
46 \qmlclass ParticlePainter QQuickParticlePainter
47 \inqmlmodule QtQuick.Particles 2
48 \inherits ParticlePainter
49 \brief ParticlePainter elements allow you to specify how to paint particles.
51 The default implementation paints nothing. See the subclasses if you want to
52 paint something visible.
56 \qmlproperty ParticleSystem QtQuick.Particles2::ParticlePainter::system
57 This is the system whose particles can be painted by the element.
58 If the ParticlePainter is a direct child of a ParticleSystem, it will automatically be associated with it.
61 \qmlproperty list<string> QtQuick.Particles2::ParticlePainter::groups
62 Which logical particle groups will be painted.
64 If empty, it will paint the default particle group ("").
66 QQuickParticlePainter::QQuickParticlePainter(QQuickItem *parent) :
68 m_system(0), m_count(0), m_pleaseReset(true)
72 void QQuickParticlePainter::componentComplete()
74 if (!m_system && qobject_cast<QQuickParticleSystem*>(parentItem()))
75 setSystem(qobject_cast<QQuickParticleSystem*>(parentItem()));
76 QQuickItem::componentComplete();
80 void QQuickParticlePainter::setSystem(QQuickParticleSystem *arg)
82 if (m_system != arg) {
85 m_system->registerParticlePainter(this);
88 emit systemChanged(arg);
92 void QQuickParticlePainter::load(QQuickParticleData* d)
94 initialize(d->group, d->index);
97 m_pendingCommits << qMakePair<int, int>(d->group, d->index);
100 void QQuickParticlePainter::reload(QQuickParticleData* d)
104 m_pendingCommits << qMakePair<int, int>(d->group, d->index);
107 void QQuickParticlePainter::reset()
109 m_pendingCommits.clear();
110 m_pleaseReset = true;
113 void QQuickParticlePainter::setCount(int c)//### TODO: some resizeing so that particles can reallocate on size change instead of recreate
115 Q_ASSERT(c >= 0); //XXX
123 int QQuickParticlePainter::count()
128 void QQuickParticlePainter::calcSystemOffset(bool resetPending)
130 if (!m_system || !parentItem())
132 QPointF lastOffset = m_systemOffset;
133 m_systemOffset = -1 * this->mapFromItem(m_system, QPointF(0.0, 0.0));
134 if (lastOffset != m_systemOffset && !resetPending){
135 //Reload all particles//TODO: Necessary?
136 foreach (const QString &g, m_groups){
137 int gId = m_system->groupIds[g];
138 foreach (QQuickParticleData* d, m_system->groupData[gId]->data)
143 typedef QPair<int,int> intPair;
144 void QQuickParticlePainter::performPendingCommits()
147 foreach (intPair p, m_pendingCommits)
148 commit(p.first, p.second);
149 m_pendingCommits.clear();