Skip to content
GAudioOutput.h 3.03 KiB
Newer Older
pixhawk's avatar
pixhawk committed
/*=====================================================================

PIXHAWK Micro Air Vehicle Flying Robotics Toolkit

(c) 2009, 2010 PIXHAWK PROJECT  <http://pixhawk.ethz.ch>

This file is part of the PIXHAWK project

    PIXHAWK 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.

    PIXHAWK 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 PIXHAWK. If not, see <http://www.gnu.org/licenses/>.

======================================================================*/

/**
 * @file
 *   @brief Definition of audio output
 *
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef GAUDIOOUTPUT_H
#define GAUDIOOUTPUT_H

#include <QObject>
#include <QTimer>
#include <QThread>
pixhawk's avatar
pixhawk committed
#include <QStringList>

#include <QGCAudioWorker.h>
Lorenz Meier's avatar
Lorenz Meier committed

pixhawk's avatar
pixhawk committed
/**
 * @brief Audio Output (speech synthesizer and "beep" output)
 * This class follows the singleton design pattern
 * @see http://en.wikipedia.org/wiki/Singleton_pattern
 */
class GAudioOutput : public QObject
{
    Q_OBJECT
public:
    /** @brief Get the singleton instance */
Lorenz Meier's avatar
Lorenz Meier committed
    static GAudioOutput *instance();
pixhawk's avatar
pixhawk committed
    /** @brief List available voices */
    QStringList listVoices(void);
Lorenz Meier's avatar
Lorenz Meier committed
    enum
    {
        VOICE_MALE = 0,
        VOICE_FEMALE
    } QGVoice;
pixhawk's avatar
pixhawk committed

    enum AUDIO_SEVERITY
    {
        AUDIO_SEVERITY_EMERGENCY = 0,
        AUDIO_SEVERITY_ALERT = 1,
        AUDIO_SEVERITY_CRITICAL = 2,
        AUDIO_SEVERITY_ERROR = 3,
        AUDIO_SEVERITY_WARNING = 4,
        AUDIO_SEVERITY_NOTICE = 5,
        AUDIO_SEVERITY_INFO = 6,
        AUDIO_SEVERITY_DEBUG = 7
    };

    /** @brief Get the mute state */
    bool isMuted();

pixhawk's avatar
pixhawk committed
public slots:
    /** @brief Say this text if current output priority matches */
    bool say(QString text, int severity = 6);
    /** @brief Play alert sound and say notification message */
pixhawk's avatar
pixhawk committed
    bool alert(QString text);
    /** @brief Start emergency sound */
    bool startEmergency();
    /** @brief Stop emergency sound */
    bool stopEmergency();
//    /** @brief Select female voice */
//    void selectFemaleVoice();
//    /** @brief Select male voice */
//    void selectMaleVoice();
    /** @brief Play emergency sound once */
pixhawk's avatar
pixhawk committed
    void beep();
    /** @brief Notify about positive event */
    void notifyPositive();
    /** @brief Notify about negative event */
    void notifyNegative();
    /** @brief Mute/unmute sound */
    void mute(bool mute);

signals:
    void mutedChanged(bool);
    bool textToSpeak(QString text, int severity = 1);
    void beepOnce();
pixhawk's avatar
pixhawk committed

protected:
    QThread* thread;
    QGCAudioWorker* worker;
pixhawk's avatar
pixhawk committed
private:
Lorenz Meier's avatar
Lorenz Meier committed
    GAudioOutput(QObject *parent = NULL);
    ~GAudioOutput();
pixhawk's avatar
pixhawk committed
};

#endif // AUDIOOUTPUT_H
Lorenz Meier's avatar
Lorenz Meier committed