summaryrefslogtreecommitdiff
path: root/library/sound.cpp
Unidiff
Diffstat (limited to 'library/sound.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--library/sound.cpp40
1 files changed, 30 insertions, 10 deletions
diff --git a/library/sound.cpp b/library/sound.cpp
index 373fd4c..602fcf0 100644
--- a/library/sound.cpp
+++ b/library/sound.cpp
@@ -22,12 +22,19 @@
22#include <qpe/sound.h> 22#include <qpe/sound.h>
23#include <qpe/qcopenvelope_qws.h> 23#include <qpe/qcopenvelope_qws.h>
24 24
25#include <qsound.h> 25#include <qsound.h>
26#include <qfile.h> 26#include <qfile.h>
27 27
28#include <unistd.h>
29#include <fcntl.h>
30#include <sys/ioctl.h>
31#include <sys/soundcard.h>
32
33#include "config.h"
34#include <qmessagebox.h>
28#ifndef QT_NO_SOUND 35#ifndef QT_NO_SOUND
29static int WAVsoundDuration(const QString& filename) 36static int WAVsoundDuration(const QString& filename)
30{ 37{
31 // bad solution 38 // bad solution
32 39
33 // most of this is copied from qsoundqss.cpp 40 // most of this is copied from qsoundqss.cpp
@@ -96,31 +103,44 @@ static int WAVsoundDuration(const QString& filename)
96class SoundData : public QSound { 103class SoundData : public QSound {
97public: 104public:
98 SoundData(const QString& name) : 105 SoundData(const QString& name) :
99 QSound(Resource::findSound(name)), 106 QSound(Resource::findSound(name)),
100 filename(Resource::findSound(name)) 107 filename(Resource::findSound(name))
101 { 108 {
109 loopsleft=0;
102 } 110 }
103 111
104 void playLoop() 112 void playLoop(int loopcnt = -1)
105 { 113 {
106 // needs server support 114 // needs server support
115 loopsleft = loopcnt;
107 116
108 int ms = WAVsoundDuration(filename); 117 int ms = WAVsoundDuration(filename);
109 if ( ms ) 118 if ( ms )
110 startTimer(ms > 50 ? ms-50 : 0); // 50 for latency 119 startTimer(ms > 50 ? ms-50 : 0); // 50 for latency
111 play(); 120 play();
112 } 121 }
113 122
114 void timerEvent(QTimerEvent*) 123 void timerEvent ( QTimerEvent *e )
115 { 124 {
125 if (loopsleft >= 0) {
126 if (--loopsleft <= 0)
127 killTimer (e->timerId());
128 return;
129 }
116 play(); 130 play();
117 } 131 }
132
133 bool isFinished ( ) const
134 {
135 return ( loopsleft == 0 );
136 }
118 137
119private: 138private:
120 QString filename; 139 QString filename;
140 int loopsleft;
121}; 141};
122#endif 142#endif
123 143
124Sound::Sound(const QString& name) 144Sound::Sound(const QString& name)
125{ 145{
126#ifndef QT_NO_SOUND 146#ifndef QT_NO_SOUND
@@ -136,13 +156,13 @@ Sound::~Sound()
136} 156}
137 157
138void Sound::play() 158void Sound::play()
139{ 159{
140#ifndef QT_NO_SOUND 160#ifndef QT_NO_SOUND
141 d->killTimers(); 161 d->killTimers();
142 d->play(); 162 d->playLoop(1);
143#endif 163#endif
144} 164}
145 165
146void Sound::playLoop() 166void Sound::playLoop()
147{ 167{
148#ifndef QT_NO_SOUND 168#ifndef QT_NO_SOUND
@@ -155,19 +175,19 @@ void Sound::stop()
155{ 175{
156#ifndef QT_NO_SOUND 176#ifndef QT_NO_SOUND
157 d->killTimers(); 177 d->killTimers();
158#endif 178#endif
159} 179}
160 180
181bool Sound::isFinished() const
182{
183#ifndef QT_NO_SOUND
184 return d->isFinished();
185#endif
186}
161 187
162void Sound::soundAlarm() 188void Sound::soundAlarm()
163{ 189{
164#ifdef QT_QWS_CUSTOM 190#ifndef QT_NO_COP
165# ifndef QT_NO_COP
166 QCopEnvelope( "QPE/TaskBar", "soundAlarm()" ); 191 QCopEnvelope( "QPE/TaskBar", "soundAlarm()" );
167# endif
168#else
169# ifndef QT_NO_SOUND
170 QSound::play(Resource::findSound("alarm"));
171# endif
172#endif 192#endif
173} 193}