diff options
author | Lorn Potter <lorn.potter@nokia.com> | 2012-05-17 09:25:54 +1000 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2012-05-17 02:04:00 +0200 |
commit | 4575c1fda70f8b8e1ac4959ad9386964cb9a6222 (patch) | |
tree | cea894cecd8b0bd09c0c2c9b2a8d4d8042fd117f /src/sensors/gestures/qsensorgesturemanagerprivate.cpp | |
parent | 6062bd6530304220c252195b96d46f4b4f76e0a4 (diff) |
send only signals being started. Avoids developer confusion.
Change-Id: I7f49f14d0546a2a59a26777c6f8fa083ec29e0ba
Reviewed-by: Lincoln Ramsay <lincoln.ramsay@nokia.com>
Diffstat (limited to 'src/sensors/gestures/qsensorgesturemanagerprivate.cpp')
-rw-r--r-- | src/sensors/gestures/qsensorgesturemanagerprivate.cpp | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/src/sensors/gestures/qsensorgesturemanagerprivate.cpp b/src/sensors/gestures/qsensorgesturemanagerprivate.cpp index c87d22da..15fccdb9 100644 --- a/src/sensors/gestures/qsensorgesturemanagerprivate.cpp +++ b/src/sensors/gestures/qsensorgesturemanagerprivate.cpp @@ -64,6 +64,9 @@ QSensorGestureManagerPrivate::QSensorGestureManagerPrivate(QObject *parent) : connect(this,SIGNAL(newSensorGestures(QStringList)), connection,SLOT(newSensorGestures(QStringList))); + + connect(this,SIGNAL(removeSensorGestures(QStringList)), + connection,SLOT(removeSensorGestures(QStringList))); #endif loader = new QFactoryLoader("com.Nokia.QSensorGesturePluginInterface", QLatin1String("/sensorgestures")); @@ -148,8 +151,8 @@ bool QSensorGestureManagerPrivate::loadRecognizer(const QString &recognizerId) registeredSensorGestures.insert(recognizer->id(),recognizer); #ifdef SIMULATOR_BUILD - QStringList list = recognizer->gestureSignals(); - Q_EMIT newSensorGestures(list); + connect(recognizer, SIGNAL(started()), this, SLOT(recognizerStarted()), Qt::UniqueConnection); + connect(recognizer, SIGNAL(stopped()), this, SLOT(recognizerStopped()), Qt::UniqueConnection); #endif } } @@ -218,6 +221,26 @@ void QSensorGestureManagerPrivate::sensorGestureDetected() } } +void QSensorGestureManagerPrivate::recognizerStarted() +{ + QSensorGestureRecognizer *recognizer = qobject_cast<QSensorGestureRecognizer *>(sender()); + QStringList list = recognizer->gestureSignals(); + list.removeOne("detected(QString)"); + list.removeOne("started()"); + list.removeOne("stopped()"); + Q_EMIT newSensorGestures(list); +} + +void QSensorGestureManagerPrivate::recognizerStopped() +{ + QSensorGestureRecognizer *recognizer = qobject_cast<QSensorGestureRecognizer *>(sender()); + QStringList list = recognizer->gestureSignals(); + list.removeOne("detected(QString)"); + list.removeOne("started()"); + list.removeOne("stopped()"); + Q_EMIT removeSensorGestures(list); +} + #endif |