2011-01-31 00:22:51 +01:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
*
|
|
|
|
* @file notifyplugin.cpp
|
|
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
|
|
* @brief
|
|
|
|
* @see The GNU Public License (GPL) Version 3
|
|
|
|
* @defgroup notifyplugin
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
/*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "notifyplugin.h"
|
2011-09-14 23:38:18 +02:00
|
|
|
#include "notificationitem.h"
|
2011-01-31 00:22:51 +01:00
|
|
|
#include "notifypluginoptionspage.h"
|
2011-09-16 17:39:20 +02:00
|
|
|
#include "notifylogging.h"
|
2011-01-31 00:22:51 +01:00
|
|
|
#include <coreplugin/icore.h>
|
|
|
|
#include <QDebug>
|
|
|
|
#include <QtPlugin>
|
|
|
|
#include <QStringList>
|
|
|
|
|
|
|
|
#include <extensionsystem/pluginmanager.h>
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include "qxttimer.h"
|
2011-09-14 23:38:18 +02:00
|
|
|
#include "backendcapabilities.h"
|
2011-01-31 00:22:51 +01:00
|
|
|
|
|
|
|
static const QString VERSION = "1.0.0";
|
|
|
|
|
|
|
|
//#define DEBUG_NOTIFIES
|
|
|
|
|
2011-09-14 23:38:18 +02:00
|
|
|
|
2011-01-31 00:22:51 +01:00
|
|
|
SoundNotifyPlugin::SoundNotifyPlugin()
|
|
|
|
{
|
2011-09-14 23:38:18 +02:00
|
|
|
phonon.mo = NULL;
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
SoundNotifyPlugin::~SoundNotifyPlugin()
|
|
|
|
{
|
|
|
|
Core::ICore::instance()->saveSettings(this);
|
|
|
|
if (phonon.mo != NULL)
|
|
|
|
delete phonon.mo;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool SoundNotifyPlugin::initialize(const QStringList& args, QString *errMsg)
|
|
|
|
{
|
|
|
|
Q_UNUSED(args);
|
|
|
|
Q_UNUSED(errMsg);
|
|
|
|
|
|
|
|
mop = new NotifyPluginOptionsPage(this);
|
|
|
|
addAutoReleasedObject(mop);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::extensionsInitialized()
|
|
|
|
{
|
2011-09-16 17:39:20 +02:00
|
|
|
Core::ICore::instance()->readSettings(this);
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-09-16 17:39:20 +02:00
|
|
|
ExtensionSystem::PluginManager* pm = ExtensionSystem::PluginManager::instance();
|
|
|
|
connect(pm, SIGNAL(objectAdded(QObject*)), this, SLOT(onTelemetryManagerAdded(QObject*)));
|
2011-10-12 07:36:05 +02:00
|
|
|
_toRemoveNotifications.clear();
|
2011-09-16 17:39:20 +02:00
|
|
|
connectNotifications();
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::saveConfig( QSettings* settings, UAVConfigInfo *configInfo){
|
|
|
|
|
|
|
|
configInfo->setVersion(VERSION);
|
|
|
|
|
|
|
|
settings->beginWriteArray("Current");
|
|
|
|
settings->setArrayIndex(0);
|
|
|
|
currentNotification.saveState(settings);
|
|
|
|
settings->endArray();
|
|
|
|
|
|
|
|
settings->beginGroup("listNotifies");
|
|
|
|
settings->remove("");
|
|
|
|
settings->endGroup();
|
|
|
|
|
|
|
|
settings->beginWriteArray("listNotifies");
|
2011-10-12 07:36:05 +02:00
|
|
|
for (int i = 0; i < _notificationList.size(); i++) {
|
2011-10-04 00:59:37 +02:00
|
|
|
settings->setArrayIndex(i);
|
2011-10-12 07:36:05 +02:00
|
|
|
_notificationList.at(i)->saveState(settings);
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
settings->endArray();
|
|
|
|
settings->setValue(QLatin1String("EnableSound"), enableSound);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
void SoundNotifyPlugin::readConfig( QSettings* settings, UAVConfigInfo *configInfo)
|
|
|
|
{
|
|
|
|
// Just for migration to the new format.
|
|
|
|
//Q_ASSERT(configInfo->version() == UAVConfigVersion());
|
2011-09-16 17:39:20 +02:00
|
|
|
|
|
|
|
settings->beginReadArray("Current");
|
|
|
|
settings->setArrayIndex(0);
|
|
|
|
currentNotification.restoreState(settings);
|
|
|
|
settings->endArray();
|
|
|
|
|
|
|
|
// read list of notifications from settings
|
|
|
|
int size = settings->beginReadArray("listNotifies");
|
|
|
|
for (int i = 0; i < size; ++i) {
|
2011-10-04 00:59:37 +02:00
|
|
|
settings->setArrayIndex(i);
|
|
|
|
NotificationItem* notification = new NotificationItem;
|
|
|
|
notification->restoreState(settings);
|
2011-10-12 07:36:05 +02:00
|
|
|
_notificationList.append(notification);
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
|
|
|
settings->endArray();
|
|
|
|
setEnableSound(settings->value(QLatin1String("EnableSound"),0).toBool());
|
|
|
|
}
|
2011-01-31 00:22:51 +01:00
|
|
|
|
|
|
|
void SoundNotifyPlugin::onTelemetryManagerAdded(QObject* obj)
|
|
|
|
{
|
2011-09-16 17:39:20 +02:00
|
|
|
telMngr = qobject_cast<TelemetryManager *>(obj);
|
|
|
|
if (telMngr)
|
|
|
|
connect(telMngr, SIGNAL(disconnected()), this, SLOT(onAutopilotDisconnect()));
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::shutdown()
|
|
|
|
{
|
|
|
|
// Do nothing
|
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::onAutopilotDisconnect()
|
|
|
|
{
|
2011-09-16 17:39:20 +02:00
|
|
|
connectNotifications();
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2011-09-16 17:39:20 +02:00
|
|
|
clear any notify timers from previous flight;
|
|
|
|
reset will be perform on start of option page
|
2011-01-31 00:22:51 +01:00
|
|
|
*/
|
|
|
|
void SoundNotifyPlugin::resetNotification(void)
|
|
|
|
{
|
2011-09-16 17:39:20 +02:00
|
|
|
//first, reject empty args and unknown fields.
|
2011-10-12 07:36:05 +02:00
|
|
|
foreach(NotificationItem* ntf, _notificationList) {
|
2011-09-16 17:39:20 +02:00
|
|
|
ntf->disposeTimer();
|
2011-10-12 07:36:05 +02:00
|
|
|
disconnect(ntf->getTimer(), SIGNAL(timeout()), this, SLOT(on_timerRepeated_Notification()));
|
2011-09-16 17:39:20 +02:00
|
|
|
ntf->disposeExpireTimer();
|
2011-10-12 07:36:05 +02:00
|
|
|
disconnect(ntf->getExpireTimer(), SIGNAL(timeout()), this, SLOT(on_timerRepeated_Notification()));
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2011-09-16 17:39:20 +02:00
|
|
|
update list of notifies;
|
|
|
|
will be perform on OK or APPLY press of option page
|
2011-01-31 00:22:51 +01:00
|
|
|
*/
|
2011-09-14 23:38:18 +02:00
|
|
|
void SoundNotifyPlugin::updateNotificationList(QList<NotificationItem*> list)
|
2011-01-31 00:22:51 +01:00
|
|
|
{
|
2011-10-12 07:36:05 +02:00
|
|
|
_toRemoveNotifications.clear();
|
2011-09-16 17:39:20 +02:00
|
|
|
resetNotification();
|
2011-10-12 07:36:05 +02:00
|
|
|
_notificationList.clear();
|
|
|
|
_notificationList=list;
|
2011-09-16 17:39:20 +02:00
|
|
|
connectNotifications();
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-09-16 17:39:20 +02:00
|
|
|
Core::ICore::instance()->saveSettings(this);
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::connectNotifications()
|
|
|
|
{
|
2011-09-16 17:39:20 +02:00
|
|
|
foreach(UAVDataObject* obj,lstNotifiedUAVObjects) {
|
|
|
|
if (obj != NULL)
|
2011-10-12 07:36:05 +02:00
|
|
|
disconnect(obj,SIGNAL(objectUpdated(UAVObject*)),this,SLOT(on_arrived_Notification(UAVObject*)));
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
|
|
|
if (phonon.mo != NULL) {
|
|
|
|
delete phonon.mo;
|
|
|
|
phonon.mo = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!enableSound) return;
|
|
|
|
|
|
|
|
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
|
|
|
|
UAVObjectManager *objManager = pm->getObject<UAVObjectManager>();
|
|
|
|
|
|
|
|
lstNotifiedUAVObjects.clear();
|
2011-10-12 07:36:05 +02:00
|
|
|
_pendingNotifications.clear();
|
|
|
|
_notificationList.append(_toRemoveNotifications);
|
|
|
|
_toRemoveNotifications.clear();
|
2011-09-16 17:39:20 +02:00
|
|
|
|
|
|
|
//first, reject empty args and unknown fields.
|
2011-10-12 07:36:05 +02:00
|
|
|
foreach(NotificationItem* notify, _notificationList) {
|
|
|
|
notify->_isPlayed = false;
|
2011-09-16 17:39:20 +02:00
|
|
|
notify->isNowPlaying=false;
|
|
|
|
|
2011-10-04 00:59:37 +02:00
|
|
|
if(notify->mute()) continue;
|
2011-10-12 07:36:05 +02:00
|
|
|
// check is all sounds presented for notification,
|
|
|
|
// if not - we must not subscribe to it at all
|
|
|
|
if(notify->toSoundList().isEmpty()) continue;
|
2011-10-04 00:59:37 +02:00
|
|
|
|
2011-09-16 17:39:20 +02:00
|
|
|
UAVDataObject* obj = dynamic_cast<UAVDataObject*>( objManager->getObject(notify->getDataObject()) );
|
|
|
|
if (obj != NULL ) {
|
|
|
|
if (!lstNotifiedUAVObjects.contains(obj)) {
|
2011-10-04 00:59:37 +02:00
|
|
|
lstNotifiedUAVObjects.append(obj);
|
2011-10-12 07:36:05 +02:00
|
|
|
|
|
|
|
connect(obj, SIGNAL(objectUpdated(UAVObject*)), this, SLOT(on_arrived_Notification(UAVObject*)));
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
2011-10-04 00:59:37 +02:00
|
|
|
} else {
|
|
|
|
qNotifyDebug() << "Error: Object is unknown (" << notify->getDataObject() << ").";
|
|
|
|
}
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
if (_notificationList.isEmpty()) return;
|
2011-09-14 23:38:18 +02:00
|
|
|
// set notification message to current event
|
|
|
|
phonon.mo = Phonon::createPlayer(Phonon::NotificationCategory);
|
|
|
|
phonon.mo->clearQueue();
|
|
|
|
phonon.firstPlay = true;
|
|
|
|
QList<Phonon::AudioOutputDevice> audioOutputDevices =
|
|
|
|
Phonon::BackendCapabilities::availableAudioOutputDevices();
|
|
|
|
foreach(Phonon::AudioOutputDevice dev, audioOutputDevices) {
|
|
|
|
qNotifyDebug() << "Notify: Audio Output device: " << dev.name() << " - " << dev.description();
|
|
|
|
}
|
|
|
|
connect(phonon.mo, SIGNAL(stateChanged(Phonon::State,Phonon::State)),
|
|
|
|
this, SLOT(stateChanged(Phonon::State,Phonon::State)));
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
void SoundNotifyPlugin::on_arrived_Notification(UAVObject *object)
|
2011-01-31 00:22:51 +01:00
|
|
|
{
|
2011-10-12 07:36:05 +02:00
|
|
|
foreach(NotificationItem* ntf, _notificationList) {
|
2011-09-16 17:39:20 +02:00
|
|
|
if (object->getName() != ntf->getDataObject())
|
|
|
|
continue;
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
|
|
|
|
// skip duplicate notifications
|
|
|
|
if (_nowPlayingNotification == ntf)
|
2011-09-16 17:39:20 +02:00
|
|
|
continue;
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
// skip periodical notifications
|
|
|
|
// this condition accepts:
|
|
|
|
// 1. Periodical notifications played firstly;
|
|
|
|
// NOTE: At first time it will be played, then it played only by timer,
|
|
|
|
// when conditions became false firstStart flag has been cleared and
|
|
|
|
// notification can be accepted again;
|
|
|
|
// 2. Once time notifications, they removed immediately after first playing;
|
|
|
|
// 3. Instant notifications(played one by one without interval);
|
2011-12-03 03:36:47 +01:00
|
|
|
if (ntf->retryString() != "Repeat Instantly" && ntf->retryString() != "Repeat Once per update" &&
|
2011-10-12 07:36:05 +02:00
|
|
|
ntf->retryString() != "Repeat Once" && ntf->_isPlayed)
|
2011-09-16 17:39:20 +02:00
|
|
|
continue;
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
qNotifyDebug() << QString("new notification: | %1 | %2 | val1: %3 | val2: %4")
|
|
|
|
.arg(ntf->getDataObject())
|
|
|
|
.arg(ntf->getObjectField())
|
|
|
|
.arg(ntf->singleValue().toString())
|
|
|
|
.arg(ntf->valueRange2());
|
|
|
|
|
|
|
|
QString fieldName = ntf->getObjectField();
|
|
|
|
UAVObjectField* field = object->getField(fieldName);
|
|
|
|
|
|
|
|
qNotifyDebug() << QString("UAV object: %1 | value: %2")
|
|
|
|
.arg(object->getName())
|
|
|
|
.arg(field->getValue().toString());
|
|
|
|
|
|
|
|
checkNotificationRule(ntf, object);
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
2011-10-12 07:36:05 +02:00
|
|
|
connect(object, SIGNAL(objectUpdated(UAVObject*)),
|
|
|
|
this, SLOT(on_arrived_Notification(UAVObject*)), Qt::UniqueConnection);
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
void SoundNotifyPlugin::on_timerRepeated_Notification()
|
2011-01-31 00:22:51 +01:00
|
|
|
{
|
2011-10-12 07:36:05 +02:00
|
|
|
NotificationItem* notification = static_cast<NotificationItem*>(sender()->parent());
|
|
|
|
if (!notification)
|
|
|
|
return;
|
|
|
|
// skip duplicate notifications
|
|
|
|
// WARNING: generally we shoudn't ever trap here
|
|
|
|
// this means, that timer fires to early and notification overlap itself
|
|
|
|
if (_nowPlayingNotification == notification) {
|
|
|
|
qNotifyDebug() << "WARN: on_timerRepeated - notification was skipped!";
|
|
|
|
notification->restartTimer();
|
|
|
|
return;
|
|
|
|
}
|
2011-09-18 23:30:57 +02:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
qNotifyDebug() << QString("repeatTimer: %1% | %2 | %3").arg(notification->getDataObject())
|
|
|
|
.arg(notification->getObjectField())
|
|
|
|
.arg(notification->toString());
|
2011-09-16 17:39:20 +02:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
|
|
|
|
UAVObjectManager *objManager = pm->getObject<UAVObjectManager>();
|
|
|
|
UAVObject* object = objManager->getObject(notification->getDataObject());
|
|
|
|
if (object)
|
|
|
|
checkNotificationRule(notification,object);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::on_expiredTimer_Notification()
|
|
|
|
{
|
|
|
|
// fire expire timer
|
|
|
|
NotificationItem* notification = static_cast<NotificationItem*>(sender()->parent());
|
|
|
|
if(!notification)
|
2011-09-18 23:30:57 +02:00
|
|
|
return;
|
2011-10-12 07:36:05 +02:00
|
|
|
notification->stopExpireTimer();
|
|
|
|
|
|
|
|
volatile QMutexLocker lock(&_mutex);
|
|
|
|
|
|
|
|
if (!_pendingNotifications.isEmpty()) {
|
|
|
|
qNotifyDebug() << QString("expireTimer: %1% | %2 | %3").arg(notification->getDataObject())
|
|
|
|
.arg(notification->getObjectField())
|
|
|
|
.arg(notification->toString());
|
|
|
|
|
|
|
|
_pendingNotifications.removeOne(notification);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::stateChanged(Phonon::State newstate, Phonon::State oldstate)
|
|
|
|
{
|
|
|
|
Q_UNUSED(oldstate)
|
|
|
|
|
|
|
|
//qNotifyDebug() << "File length (ms): " << phonon.mo->totalTime();
|
|
|
|
|
|
|
|
#ifndef Q_OS_WIN
|
|
|
|
// This is a hack to force Linux to wait until the end of the
|
|
|
|
// wav file before moving to the next in the queue.
|
|
|
|
// I wish I did not have to go through a #define, but I did not
|
|
|
|
// manage to make this work on both platforms any other way!
|
|
|
|
if (phonon.mo->totalTime()>0)
|
|
|
|
phonon.mo->setTransitionTime(phonon.mo->totalTime());
|
|
|
|
#endif
|
|
|
|
if ((newstate == Phonon::PausedState) ||
|
|
|
|
(newstate == Phonon::StoppedState))
|
|
|
|
{
|
|
|
|
qNotifyDebug() << "New State: " << QVariant(newstate).toString();
|
|
|
|
|
|
|
|
volatile QMutexLocker lock(&_mutex);
|
|
|
|
// assignment to NULL needed to detect that palying is finished
|
|
|
|
// it's useful in repeat timer handler, where we can detect
|
|
|
|
// that notification has not overlap with itself
|
|
|
|
_nowPlayingNotification = NULL;
|
|
|
|
|
|
|
|
if (!_pendingNotifications.isEmpty())
|
|
|
|
{
|
|
|
|
NotificationItem* notification = _pendingNotifications.takeFirst();
|
|
|
|
qNotifyDebug_if(notification) << "play audioFree - " << notification->toString();
|
|
|
|
playNotification(notification);
|
2011-12-03 03:36:47 +01:00
|
|
|
qNotifyDebug()<<"end playNotification";
|
2011-10-12 07:36:05 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (newstate == Phonon::ErrorState) {
|
|
|
|
if (phonon.mo->errorType()==0) {
|
|
|
|
qDebug() << "Phonon::ErrorState: ErrorType = " << phonon.mo->errorType();
|
|
|
|
phonon.mo->clearQueue();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-03 03:36:47 +01:00
|
|
|
bool checkRange(QString fieldValue, QString enumValue, QStringList values, int direction)
|
2011-10-12 07:36:05 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
bool ret = false;
|
|
|
|
switch(direction)
|
|
|
|
{
|
2011-12-03 03:36:47 +01:00
|
|
|
case NotificationItem::equal:
|
2011-10-12 07:36:05 +02:00
|
|
|
ret = !QString::compare(enumValue, fieldValue, Qt::CaseInsensitive) ? true : false;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
ret = true;
|
|
|
|
break;
|
|
|
|
};
|
|
|
|
return ret;
|
|
|
|
}
|
2011-09-18 23:30:57 +02:00
|
|
|
|
2011-12-03 03:36:47 +01:00
|
|
|
bool checkRange(double fieldValue, double min, double max, int direction)
|
2011-10-12 07:36:05 +02:00
|
|
|
{
|
|
|
|
bool ret = false;
|
|
|
|
Q_ASSERT(min < max);
|
|
|
|
switch(direction)
|
2011-09-18 23:30:57 +02:00
|
|
|
{
|
2011-12-03 03:36:47 +01:00
|
|
|
case NotificationItem::equal:
|
2011-10-12 07:36:05 +02:00
|
|
|
ret = (fieldValue == min);
|
2011-09-18 23:30:57 +02:00
|
|
|
break;
|
|
|
|
|
2011-12-03 03:36:47 +01:00
|
|
|
case NotificationItem::bigger:
|
2011-10-12 07:36:05 +02:00
|
|
|
ret = (fieldValue > min);
|
2011-09-18 23:30:57 +02:00
|
|
|
break;
|
|
|
|
|
2011-12-03 03:36:47 +01:00
|
|
|
case NotificationItem::smaller:
|
2011-10-12 07:36:05 +02:00
|
|
|
ret = (fieldValue < min);
|
2011-09-18 23:30:57 +02:00
|
|
|
break;
|
2011-09-29 19:26:46 +02:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
default:
|
|
|
|
ret = (fieldValue > min) && (fieldValue < max);
|
2011-09-29 19:26:46 +02:00
|
|
|
break;
|
2011-10-12 07:36:05 +02:00
|
|
|
};
|
2011-09-29 19:26:46 +02:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SoundNotifyPlugin::checkNotificationRule(NotificationItem* notification, UAVObject* object)
|
|
|
|
{
|
|
|
|
bool condition=false;
|
|
|
|
|
|
|
|
if (notification->mute())
|
|
|
|
return;
|
|
|
|
|
2011-12-03 03:36:47 +01:00
|
|
|
int direction = notification->getCondition();
|
2011-10-12 07:36:05 +02:00
|
|
|
QString fieldName = notification->getObjectField();
|
|
|
|
UAVObjectField* field = object->getField(fieldName);
|
|
|
|
|
|
|
|
if (field->getName().isEmpty())
|
|
|
|
return;
|
|
|
|
|
|
|
|
QVariant value = field->getValue();
|
|
|
|
if(UAVObjectField::ENUM == field->getType()) {
|
2011-12-03 03:36:47 +01:00
|
|
|
qNotifyDebug()<<"Check range ENUM"<<value.toString()<<"|"<<notification->singleValue().toString()<<"|"<<field->getOptions()<<"|"<<
|
|
|
|
direction<<checkRange(value.toString(),
|
|
|
|
notification->singleValue().toString(),
|
|
|
|
field->getOptions(),
|
|
|
|
direction);;
|
2011-10-12 07:36:05 +02:00
|
|
|
condition = checkRange(value.toString(),
|
|
|
|
notification->singleValue().toString(),
|
|
|
|
field->getOptions(),
|
2011-12-03 03:36:47 +01:00
|
|
|
direction);
|
2011-10-12 07:36:05 +02:00
|
|
|
} else {
|
2011-12-03 03:36:47 +01:00
|
|
|
qNotifyDebug()<<"Check range VAL"<<value.toString()<<"|"<<notification->singleValue().toString()<<"|"<<field->getOptions()<<"|"<<
|
|
|
|
direction<<checkRange(value.toDouble(),
|
|
|
|
notification->singleValue().toDouble(),
|
|
|
|
notification->valueRange2(),
|
|
|
|
direction);
|
2011-10-12 07:36:05 +02:00
|
|
|
condition = checkRange(value.toDouble(),
|
|
|
|
notification->singleValue().toDouble(),
|
|
|
|
notification->valueRange2(),
|
2011-12-03 03:36:47 +01:00
|
|
|
direction);
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
notification->_isPlayed = condition;
|
|
|
|
// if condition has been changed, and already in false state
|
|
|
|
// we should reset _isPlayed flag and stop repeat timer
|
|
|
|
if (!notification->_isPlayed) {
|
|
|
|
notification->stopTimer();
|
2011-12-03 03:36:47 +01:00
|
|
|
notification->setCurrentUpdatePlayed(false);
|
2011-09-18 23:30:57 +02:00
|
|
|
return;
|
2011-10-12 07:36:05 +02:00
|
|
|
}
|
2011-12-03 03:36:47 +01:00
|
|
|
if(notification->retryString() == "Repeat Once per update" && notification->getCurrentUpdatePlayed())
|
|
|
|
return;
|
2011-10-12 07:36:05 +02:00
|
|
|
volatile QMutexLocker lock(&_mutex);
|
2011-09-18 23:30:57 +02:00
|
|
|
|
2011-10-04 00:59:37 +02:00
|
|
|
if (!playNotification(notification)) {
|
2011-10-12 07:36:05 +02:00
|
|
|
if (!_pendingNotifications.contains(notification)
|
|
|
|
&& (_nowPlayingNotification != notification)) {
|
2011-09-18 23:30:57 +02:00
|
|
|
notification->stopTimer();
|
|
|
|
|
2011-10-04 00:59:37 +02:00
|
|
|
qNotifyDebug() << "add to pending list - " << notification->toString();
|
2011-09-18 23:30:57 +02:00
|
|
|
// if audio is busy, start expiration timer
|
|
|
|
//ms = (notification->getExpiredTimeout()[in sec])*1000
|
|
|
|
//QxtTimer::singleShot(notification->getExpireTimeout()*1000, this, SLOT(expirationTimerHandler(NotificationItem*)), qVariantFromValue(notification));
|
2011-10-12 07:36:05 +02:00
|
|
|
_pendingNotifications.append(notification);
|
2011-09-18 23:30:57 +02:00
|
|
|
notification->startExpireTimer();
|
2011-10-12 07:36:05 +02:00
|
|
|
connect(notification->getExpireTimer(), SIGNAL(timeout()),
|
|
|
|
this, SLOT(on_expiredTimer_Notification()), Qt::UniqueConnection);
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
|
|
|
}
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
2011-09-14 23:38:18 +02:00
|
|
|
bool SoundNotifyPlugin::playNotification(NotificationItem* notification)
|
2011-01-31 00:22:51 +01:00
|
|
|
{
|
2011-10-12 07:36:05 +02:00
|
|
|
if(!notification)
|
|
|
|
return false;
|
|
|
|
|
2011-01-31 00:22:51 +01:00
|
|
|
// Check: race condition, if phonon.mo got deleted don't go further
|
|
|
|
if (phonon.mo == NULL)
|
|
|
|
return false;
|
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
//qNotifyDebug() << "Phonon State: " << phonon.mo->state();
|
2011-09-16 17:39:20 +02:00
|
|
|
|
|
|
|
if ((phonon.mo->state()==Phonon::PausedState)
|
2011-09-18 23:30:57 +02:00
|
|
|
|| (phonon.mo->state()==Phonon::StoppedState)
|
|
|
|
|| phonon.firstPlay)
|
2011-09-16 17:39:20 +02:00
|
|
|
{
|
2011-10-12 07:36:05 +02:00
|
|
|
_nowPlayingNotification = notification;
|
2011-09-16 17:39:20 +02:00
|
|
|
notification->stopExpireTimer();
|
|
|
|
|
2011-09-18 23:30:57 +02:00
|
|
|
if (notification->retryString() == "Repeat Once") {
|
2011-10-12 07:36:05 +02:00
|
|
|
_toRemoveNotifications.append(_notificationList.takeAt(_notificationList.indexOf(notification)));
|
2011-12-03 03:36:47 +01:00
|
|
|
}
|
|
|
|
else if(notification->retryString() == "Repeat Once per update")
|
|
|
|
notification->setCurrentUpdatePlayed(true);
|
|
|
|
else {
|
2011-09-18 23:30:57 +02:00
|
|
|
if (notification->retryString() != "Repeat Instantly") {
|
2011-09-16 17:39:20 +02:00
|
|
|
QRegExp rxlen("(\\d+)");
|
|
|
|
QString value;
|
|
|
|
int timer_value;
|
2011-09-18 23:30:57 +02:00
|
|
|
int pos = rxlen.indexIn(notification->retryString());
|
2011-09-16 17:39:20 +02:00
|
|
|
if (pos > -1) {
|
|
|
|
value = rxlen.cap(1); // "189"
|
2011-10-12 07:36:05 +02:00
|
|
|
|
|
|
|
// needs to correct repeat timer value,
|
|
|
|
// acording to message play duration,
|
|
|
|
// we don't measure duration of each message,
|
|
|
|
// simply take average duration
|
|
|
|
enum { eAverageDurationSec = 8 };
|
|
|
|
|
|
|
|
enum { eSecToMsec = 1000 };
|
|
|
|
|
|
|
|
timer_value = (value.toInt() + eAverageDurationSec) * eSecToMsec;
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
2011-09-14 23:38:18 +02:00
|
|
|
|
2011-09-16 17:39:20 +02:00
|
|
|
notification->startTimer(timer_value);
|
2011-10-12 07:36:05 +02:00
|
|
|
connect(notification->getTimer(), SIGNAL(timeout()),
|
|
|
|
this, SLOT(on_timerRepeated_Notification()), Qt::UniqueConnection);
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
phonon.mo->clear();
|
2011-10-12 07:36:05 +02:00
|
|
|
qNotifyDebug() << "play: " << notification->toString();
|
2011-10-04 00:59:37 +02:00
|
|
|
foreach (QString item, notification->toSoundList()) {
|
2011-09-16 17:39:20 +02:00
|
|
|
Phonon::MediaSource *ms = new Phonon::MediaSource(item);
|
|
|
|
ms->setAutoDelete(true);
|
|
|
|
phonon.mo->enqueue(*ms);
|
|
|
|
}
|
2011-12-03 03:36:47 +01:00
|
|
|
qNotifyDebug()<<"begin play";
|
2011-09-16 17:39:20 +02:00
|
|
|
phonon.mo->play();
|
2011-12-03 03:36:47 +01:00
|
|
|
qNotifyDebug()<<"end play";
|
2011-09-16 17:39:20 +02:00
|
|
|
phonon.firstPlay = false; // On Linux, you sometimes have to nudge Phonon to play 1 time before
|
2011-10-12 07:36:05 +02:00
|
|
|
// the state is not "Loading" anymore.
|
|
|
|
return true;
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-09-16 17:39:20 +02:00
|
|
|
}
|
2011-01-31 00:22:51 +01:00
|
|
|
|
2011-10-12 07:36:05 +02:00
|
|
|
return false;
|
2011-01-31 00:22:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Q_EXPORT_PLUGIN(SoundNotifyPlugin)
|