GAudioOutput.h 3.03 KB
Newer Older
pixhawk's avatar
pixhawk committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
/*=====================================================================

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>
37
#include <QThread>
pixhawk's avatar
pixhawk committed
38
#include <QStringList>
39 40

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

pixhawk's avatar
pixhawk committed
42 43 44 45 46 47 48 49 50 51
/**
 * @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
52
    static GAudioOutput *instance();
pixhawk's avatar
pixhawk committed
53 54
    /** @brief List available voices */
    QStringList listVoices(void);
Lorenz Meier's avatar
Lorenz Meier committed
55 56
    enum
    {
57 58 59
        VOICE_MALE = 0,
        VOICE_FEMALE
    } QGVoice;
pixhawk's avatar
pixhawk committed
60

61 62 63 64 65 66 67 68 69 70 71 72
    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
    };

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

pixhawk's avatar
pixhawk committed
76 77
public slots:
    /** @brief Say this text if current output priority matches */
78
    bool say(QString text, int severity = 6);
79
    /** @brief Play alert sound and say notification message */
pixhawk's avatar
pixhawk committed
80 81 82 83 84
    bool alert(QString text);
    /** @brief Start emergency sound */
    bool startEmergency();
    /** @brief Stop emergency sound */
    bool stopEmergency();
85 86 87 88
//    /** @brief Select female voice */
//    void selectFemaleVoice();
//    /** @brief Select male voice */
//    void selectMaleVoice();
89
    /** @brief Play emergency sound once */
pixhawk's avatar
pixhawk committed
90
    void beep();
91 92 93 94
    /** @brief Notify about positive event */
    void notifyPositive();
    /** @brief Notify about negative event */
    void notifyNegative();
95 96
    /** @brief Mute/unmute sound */
    void mute(bool mute);
97 98 99

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

protected:
104
    bool muted;
105 106
    QThread* thread;
    QGCAudioWorker* worker;
pixhawk's avatar
pixhawk committed
107
private:
Lorenz Meier's avatar
Lorenz Meier committed
108 109
    GAudioOutput(QObject *parent = NULL);
    ~GAudioOutput();
pixhawk's avatar
pixhawk committed
110 111 112
};

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