author | llornkcor <llornkcor> | 2005-02-19 01:41:12 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2005-02-19 01:41:12 (UTC) |
commit | 42ff7b7515ef2220d3400c468f4cea5828f4faea (patch) (unidiff) | |
tree | 3358e973ff98fcd79311298ffc56c88e39c8b4eb | |
parent | e24ddf0db8e3e4329caeb8d0bee5db87cec1d2da (diff) | |
download | opie-42ff7b7515ef2220d3400c468f4cea5828f4faea.zip opie-42ff7b7515ef2220d3400c468f4cea5828f4faea.tar.gz opie-42ff7b7515ef2220d3400c468f4cea5828f4faea.tar.bz2 |
simplify some things
-rw-r--r-- | noncore/multimedia/opierec/device.cpp | 286 | ||||
-rw-r--r-- | noncore/multimedia/opierec/device.h | 4 | ||||
-rw-r--r-- | noncore/multimedia/opierec/qtrec.cpp | 121 | ||||
-rw-r--r-- | noncore/multimedia/opierec/waveform.cpp | 2 |
4 files changed, 125 insertions, 288 deletions
diff --git a/noncore/multimedia/opierec/device.cpp b/noncore/multimedia/opierec/device.cpp index cb47b77..e7e0f4b 100644 --- a/noncore/multimedia/opierec/device.cpp +++ b/noncore/multimedia/opierec/device.cpp | |||
@@ -1,263 +1,169 @@ | |||
1 | // device.cpp | 1 | // device.cpp |
2 | 2 | ||
3 | #include "device.h" | 3 | #include "device.h" |
4 | 4 | ||
5 | #include <qpe/config.h> | 5 | #include <qpe/config.h> |
6 | #include <qpe/qcopenvelope_qws.h> | 6 | #include <qpe/qcopenvelope_qws.h> |
7 | 7 | ||
8 | #include <opie2/odebug.h> | ||
9 | |||
8 | /* STD */ | 10 | /* STD */ |
9 | #include <fcntl.h> | 11 | #include <fcntl.h> |
10 | #include <stdio.h> | 12 | #include <stdio.h> |
11 | #include <stdlib.h> | 13 | #include <stdlib.h> |
12 | #include <sys/ioctl.h> | 14 | #include <sys/ioctl.h> |
13 | #include <sys/soundcard.h> | 15 | #include <sys/soundcard.h> |
14 | #include <unistd.h> | 16 | #include <unistd.h> |
15 | #include <sys/wait.h> | 17 | #include <sys/wait.h> |
16 | #include <unistd.h> | 18 | #include <unistd.h> |
17 | #include <errno.h> | 19 | #include <errno.h> |
18 | 20 | ||
19 | //extern QtRec *qperec; | 21 | //extern QtRec *qperec; |
22 | #if defined(QT_QWS_SL5XXX) | ||
23 | ///#if defined(QT_QWS_EBX) | ||
24 | |||
25 | #define DSPSTROUT "/dev/dsp" | ||
26 | #define DSPSTRMIXEROUT "/dev/mixer" | ||
27 | |||
28 | #ifdef SHARP | ||
29 | #define DSPSTRIN "/dev/dsp1" | ||
30 | #define DSPSTRMIXERIN "/dev/mixer1" | ||
31 | #else | ||
32 | #define DSPSTRIN "/dev/dsp" | ||
33 | #define DSPSTRMIXERIN "/dev/mixer" | ||
34 | #endif | ||
35 | |||
36 | #else | ||
37 | |||
38 | #ifdef QT_QWS_DEVFS | ||
39 | #define DSPSTROUT "/dev/sound/dsp" | ||
40 | #define DSPSTRIN "/dev/sound/dsp" | ||
41 | #define DSPSTRMIXERIN "/dev/sound/mixer" | ||
42 | #define DSPSTRMIXEROUT "/dev/sound/mixer" | ||
43 | #else | ||
44 | #define DSPSTROUT "/dev/dsp" | ||
45 | #define DSPSTRIN "/dev/dsp" | ||
46 | #define DSPSTRMIXERIN "/dev/mixer" | ||
47 | #define DSPSTRMIXEROUT "/dev/mixer" | ||
48 | #endif | ||
49 | |||
50 | #endif | ||
20 | 51 | ||
21 | Device::Device( QObject * parent, const char * dsp, const char * mixr, bool record ) | 52 | Device::Device( QObject * parent, bool record ) |
22 | : QObject( parent) | 53 | : QObject( parent) |
23 | { | 54 | { |
24 | dspstr = (char *)dsp; | 55 | // dspstr = dsp; |
25 | mixstr = (char *)mixr; | 56 | devForm = -1; |
26 | 57 | devCh = -1; | |
27 | devForm=-1; | 58 | devRate = -1; |
28 | devCh=-1; | ||
29 | devRate=-1; | ||
30 | 59 | ||
31 | if( !record){ //playing | 60 | if( !record){ //playing |
32 | qDebug( "setting up DSP for playing" ); | 61 | owarn << "setting up DSP for playing" << oendl; |
33 | flags = O_WRONLY; | 62 | flags = O_WRONLY; |
34 | } else { //recording | 63 | } else { //recording |
35 | qDebug( "setting up DSP for recording" ); | 64 | owarn << "setting up DSP for recording" << oendl; |
36 | flags = O_RDWR; | 65 | flags = O_RDWR; |
37 | // flags = O_RDONLY; | 66 | // flags = O_RDONLY; |
38 | 67 | selectMicInput(); | |
39 | // selectMicInput(); | ||
40 | |||
41 | } | 68 | } |
42 | } | 69 | } |
43 | 70 | ||
44 | bool Device::openDsp() { | 71 | bool Device::openDsp() { |
45 | if( openDevice( flags) == -1) { | 72 | if( openDevice( flags) == -1) { |
46 | perror("<<<<<<<<<<<<<<ioctl(\"Open device\")"); | 73 | perror("<<<<<<<<<<<<<<ioctl(\"Open device\")"); |
47 | return false; | 74 | return false; |
48 | } | 75 | } |
49 | return true; | 76 | return true; |
50 | } | 77 | } |
51 | 78 | ||
52 | int Device::openDevice( int flags) { | 79 | int Device::openDevice( int flags) { |
53 | /* pid_t pid; | 80 | owarn << "Opening"<< dspstr; |
54 | int status; | 81 | |
55 | int pipefd[2]; | 82 | if (( sd = ::open( DSPSTROUT, flags)) == -1) { |
56 | char message[20]; | 83 | perror("open(\"/dev/dsp\")"); |
57 | if (pipe(pipefd) == -1){ | 84 | QString errorMsg="Could not open audio device\n /dev/dsp\n" |
58 | perror ("Error creating pipe"); | 85 | +(QString)strerror(errno); |
59 | exit(1); | 86 | qDebug( "XXXXXXXXXXXXXXXXXXXXXXX "+errorMsg ); |
60 | } | 87 | return -1; |
61 | switch (pid = fork()) { | 88 | } |
62 | case -1: | 89 | |
63 | perror("The fork failed!"); | 90 | if(ioctl(sd,SNDCTL_DSP_RESET,0)<0){ |
64 | break; | 91 | perror("ioctl RESET"); |
65 | case 0: { | 92 | } |
66 | */ | ||
67 | qDebug( "Opening %s",dspstr); | ||
68 | if (( sd = ::open( dspstr, flags)) == -1) { | ||
69 | perror("open(\"/dev/dsp\")"); | ||
70 | QString errorMsg="Could not open audio device\n /dev/dsp\n" | ||
71 | +(QString)strerror(errno); | ||
72 | qDebug( "XXXXXXXXXXXXXXXXXXXXXXX "+errorMsg ); | ||
73 | return -1; | ||
74 | } | ||
75 | |||
76 | qDebug( "Opening mixer" ); | ||
77 | int mixerHandle=0; | ||
78 | #ifdef QT_QWS_DEVFS | ||
79 | if (( mixerHandle = open("/dev/sound/mixer",O_RDWR))<0) { | ||
80 | #else | ||
81 | if (( mixerHandle = open("/dev/mixer",O_RDWR))<0) { | ||
82 | #endif | ||
83 | perror("open(\"/dev/mixer\")"); | ||
84 | QString errorMsg="Could not open audio device\n /dev/dsp\n" | ||
85 | +(QString)strerror(errno); | ||
86 | qDebug( "XXXXXXXXXXXXXXXXXXXXXX "+errorMsg ); | ||
87 | } | ||
88 | |||
89 | if(ioctl(sd,SNDCTL_DSP_RESET,0)<0){ | ||
90 | perror("ioctl RESET"); | ||
91 | } | ||
92 | // sprintf(message, "%d", sd); | ||
93 | |||
94 | /* QFile f1("/pid"); | ||
95 | f1.open(IO_WriteOnly ); | ||
96 | f1.writeBlock(message, strlen(message)); | ||
97 | f1.close(); | ||
98 | */ | ||
99 | /* close(pipefd[0]); | ||
100 | write(pipefd[1], message, sizeof(message)); | ||
101 | close(pipefd[1]); | ||
102 | // qDebug( "" + soundDevice->sd ); | ||
103 | _exit(0); | ||
104 | } | ||
105 | default: | ||
106 | // pid greater than zero is parent getting the child's pid | ||
107 | printf("Child's pid is %d\n",pid); | ||
108 | QString s; | ||
109 | close(pipefd[1]); | ||
110 | read(pipefd[0], message, sizeof(message)); | ||
111 | s = message; | ||
112 | close(pipefd[0]); | ||
113 | |||
114 | // while(wait(NULL)!=pid) | ||
115 | // ; | ||
116 | printf("child %ld terminated normally, return status is zero\n", (long) pid); | ||
117 | */ | ||
118 | // filePara.sd=(long) pid; | ||
119 | /* QFile f2("/pid"); | ||
120 | f2.open(IO_ReadOnly); | ||
121 | QTextStream t(&f2); | ||
122 | // for(int f=0; f < t.atEnd() ;f++) { | ||
123 | s = t.readLine(); | ||
124 | // } | ||
125 | */ | ||
126 | // bool ok; | ||
127 | // sd = s.toInt(&ok, 10); | ||
128 | // qDebug( "<<<<<<<<<<<<<>>>>>>>>>>>>"+s ); | ||
129 | |||
130 | // f2.close(); | ||
131 | // } | ||
132 | ::close(mixerHandle ); | ||
133 | // qDebug( "open device " + dspstr ); | ||
134 | // qDebug( "success! " + sd ); | ||
135 | return sd; | 93 | return sd; |
136 | } | 94 | } |
137 | 95 | ||
96 | int Device::getInVolume() { | ||
97 | unsigned int volume = 0; | ||
98 | Config cfg("qpe"); | ||
99 | cfg.setGroup("Volume"); | ||
100 | |||
101 | return cfg.readNumEntry("Mic"); | ||
102 | } | ||
138 | 103 | ||
139 | int Device::getOutVolume( ) { | 104 | int Device::getOutVolume( ) { |
140 | unsigned int volume; | 105 | unsigned int volume; |
141 | int mixerHandle = open( mixstr, O_RDWR ); | ||
142 | if ( mixerHandle >= 0 ) { | ||
143 | if(ioctl( mixerHandle, MIXER_READ(SOUND_MIXER_VOLUME), &volume )==-1) | ||
144 | perror("<<<<<<<<<<<<<<ioctl(\"MIXER_READ\")"); | ||
145 | ::close( mixerHandle ); | ||
146 | } else | ||
147 | perror("open(\"/dev/mixer\")"); | ||
148 | printf("<<<<<<<<<<<<<<<<<<<<output volume %d\n",volume); | ||
149 | |||
150 | Config cfg("qpe"); | 106 | Config cfg("qpe"); |
151 | cfg.setGroup("Volume"); | 107 | cfg.setGroup("Volume"); |
152 | 108 | ||
153 | return cfg.readNumEntry("VolumePercent"); | 109 | return cfg.readNumEntry("VolumePercent"); |
154 | } | 110 | } |
155 | 111 | ||
156 | int Device::getInVolume() { | ||
157 | unsigned int volume=0; | ||
158 | int mixerHandle = ::open( mixstr, O_RDWR ); | ||
159 | if ( mixerHandle >= 0 ) { | ||
160 | if(ioctl( mixerHandle, MIXER_READ(SOUND_MIXER_MIC), &volume )==-1) | ||
161 | perror("<<<<<<<<<<<<<<<ioctl(\"MIXER_READ\")"); | ||
162 | ::close( mixerHandle ); | ||
163 | } else | ||
164 | perror("open(\"/dev/mixer\")"); | ||
165 | printf("<<<<<<<<<<<<<<input volume %d\n", volume ); | ||
166 | Config cfg("qpe"); | ||
167 | cfg.setGroup("Volume"); | ||
168 | 112 | ||
169 | return cfg.readNumEntry("Mic"); | 113 | void Device::changedInVolume(int vol ) { |
114 | Config cfg("qpe"); | ||
115 | cfg.setGroup("Volume"); | ||
116 | cfg.writeEntry("Mic", QString::number(vol )); | ||
117 | QCopEnvelope( "QPE/System", "micChange(bool)" ) << false; | ||
170 | } | 118 | } |
171 | 119 | ||
172 | void Device::changedOutVolume(int vol) { | 120 | void Device::changedOutVolume(int vol) { |
173 | int level = (vol << 8) + vol; | 121 | Config cfg("qpe"); |
174 | int fd = 0; | 122 | cfg.setGroup("Volume"); |
175 | #ifdef QT_QWS_DEVFS | 123 | cfg.writeEntry("VolumePercent", QString::number( vol )); |
176 | if ((fd = open("/dev/sound/mixer", O_RDWR))>=0) { | ||
177 | #else | ||
178 | if ((fd = open("/dev/mixer", O_RDWR))>=0) { | ||
179 | #endif | ||
180 | if(ioctl(fd, MIXER_WRITE(SOUND_MIXER_VOLUME), &level) == -1) | ||
181 | perror("ioctl(\"MIXER_IN_WRITE\")"); | ||
182 | |||
183 | Config cfg("qpe"); | ||
184 | cfg.setGroup("Volume"); | ||
185 | cfg.writeEntry("VolumePercent", QString::number( vol )); | ||
186 | QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << false; | ||
187 | qDebug("changing output vol %d" ,vol ); | ||
188 | } | ||
189 | ::close(fd); | ||
190 | } | ||
191 | 124 | ||
192 | void Device::changedInVolume(int vol ) { | 125 | QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << false; |
193 | int level = (vol << 8) + vol; | 126 | |
194 | int fd = 0; | 127 | owarn << "changing output vol " << vol << oendl; |
195 | #ifdef QT_QWS_DEVFS | ||
196 | if ((fd = open("/dev/sound/mixer", O_RDWR))>=0) { | ||
197 | #else | ||
198 | if ((fd = open("/dev/mixer", O_RDWR))>=0) { | ||
199 | #endif | ||
200 | if(ioctl(fd, MIXER_WRITE(SOUND_MIXER_MIC), &level) == -1) | ||
201 | perror("ioctl(\"MIXER_IN_WRITE\")"); | ||
202 | Config cfg("qpe"); | ||
203 | cfg.setGroup("Volume"); | ||
204 | cfg.writeEntry("Mic", QString::number(vol )); | ||
205 | QCopEnvelope( "QPE/System", "micChange(bool)" ) << false; | ||
206 | qDebug("changing input volume %d",vol); | ||
207 | } | ||
208 | ::close(fd); | ||
209 | } | 128 | } |
210 | 129 | ||
211 | bool Device::selectMicInput() { | 130 | bool Device::selectMicInput() { |
212 | 131 | ||
213 | int md=0; | 132 | int md = 0; |
214 | int info=MIXER_WRITE(SOUND_MIXER_MIC); | 133 | int info = SOUND_MASK_MIC;//MIXER_WRITE(SOUND_MIXER_MIC); |
215 | #ifdef QT_QWS_DEVFS | 134 | owarn << "sectMicInput" << oendl; |
216 | md = ::open( "/dev/sound/mixer", O_RDWR ); | 135 | md = ::open( DSPSTRMIXEROUT, O_RDWR ); |
217 | #else | 136 | |
218 | md = ::open( "/dev/mixer", O_RDWR ); | 137 | if ( md <= 0) { |
219 | #endif | 138 | QString err; |
220 | if ( md == -1) | 139 | err.sprintf("open %s", DSPSTRMIXEROUT); |
221 | perror("open(\"/dev/mixer\")"); | 140 | perror(err.latin1()); |
222 | else { | 141 | } else { |
223 | if( ioctl( md, SOUND_MIXER_WRITE_RECSRC, &info) == -1) | 142 | if( ioctl( md, SOUND_MIXER_WRITE_RECSRC, &info) == -1) |
224 | perror("ioctl(\"SOUND_MIXER_WRITE_RECSRC\")"); | 143 | perror("ioctl(\"SOUND_MIXER_WRITE_RECSRC\")"); |
225 | ::close(md); | 144 | ::close(md); |
226 | return false; | 145 | return false; |
227 | } | 146 | } |
228 | ::close(md); | 147 | ::close(md); |
229 | 148 | ||
230 | return true; | 149 | return true; |
231 | } | 150 | } |
232 | 151 | ||
233 | bool Device::closeDevice( bool) { | 152 | bool Device::closeDevice( bool) { |
234 | // if(b) {//close now | ||
235 | // if (ioctl( sd, SNDCTL_DSP_RESET, 0) == -1) { | ||
236 | // perror("ioctl(\"SNDCTL_DSP_RESET\")"); | ||
237 | // } | ||
238 | // } else { //let play | ||
239 | // if (ioctl( sd, SNDCTL_DSP_SYNC, 0) == -1) { | ||
240 | // perror("ioctl(\"SNDCTL_DSP_SYNC\")"); | ||
241 | // } | ||
242 | // } | ||
243 | |||
244 | ::close( sd); //close sound device | 153 | ::close( sd); //close sound device |
245 | // sdfd=0; | ||
246 | // sd=0; | ||
247 | // qDebug( "closed dsp" ); | ||
248 | return true; | 154 | return true; |
249 | } | 155 | } |
250 | 156 | ||
251 | bool Device::setDeviceFormat( int form) { | 157 | bool Device::setDeviceFormat( int form) { |
252 | qDebug( "set device res %d: %d ",form, sd ); | 158 | qDebug( "set device res %d: %d ",form, sd ); |
253 | if (ioctl( sd, SNDCTL_DSP_SETFMT, &form)==-1) { //set format | 159 | if (ioctl( sd, SNDCTL_DSP_SETFMT, &form)==-1) { //set format |
254 | perror("ioctl(\"SNDCTL_DSP_SETFMT\")"); | 160 | perror("ioctl(\"SNDCTL_DSP_SETFMT\")"); |
255 | return false; | 161 | return false; |
256 | } | 162 | } |
257 | devRes=form; | 163 | devRes=form; |
258 | return true; | 164 | return true; |
259 | } | 165 | } |
260 | 166 | ||
261 | bool Device::setDeviceChannels( int ch) { | 167 | bool Device::setDeviceChannels( int ch) { |
262 | qDebug( "set channels %d: %d",ch ,sd); | 168 | qDebug( "set channels %d: %d",ch ,sd); |
263 | if (ioctl( sd, SNDCTL_DSP_CHANNELS, &ch)==-1) { | 169 | if (ioctl( sd, SNDCTL_DSP_CHANNELS, &ch)==-1) { |
@@ -289,52 +195,50 @@ int Device::getFormat() { | |||
289 | } | 195 | } |
290 | 196 | ||
291 | int Device::getRate() { | 197 | int Device::getRate() { |
292 | return devRate; | 198 | return devRate; |
293 | } | 199 | } |
294 | 200 | ||
295 | int Device::getChannels() { | 201 | int Device::getChannels() { |
296 | return devCh; | 202 | return devCh; |
297 | } | 203 | } |
298 | 204 | ||
299 | int Device::getDeviceFormat() { | 205 | int Device::getDeviceFormat() { |
300 | return 0; | 206 | return 0; |
301 | } | 207 | } |
302 | 208 | ||
303 | 209 | ||
304 | int Device::getDeviceRate() { | 210 | int Device::getDeviceRate() { |
305 | int dRate=0; | 211 | int dRate = 0; |
306 | if (ioctl( sd, SOUND_PCM_READ_RATE, &dRate) == -1) { | 212 | if (ioctl( sd, SOUND_PCM_READ_RATE, &dRate) == -1) { |
307 | perror("ioctl(\"SNDCTL_PCM_READ_RATE\")"); | 213 | perror("ioctl(\"SNDCTL_PCM_READ_RATE\")"); |
308 | } | 214 | } |
309 | return dRate; | 215 | return dRate; |
310 | 216 | ||
311 | } | 217 | } |
312 | 218 | ||
313 | int Device::getDeviceBits() { | 219 | int Device::getDeviceBits() { |
314 | int dBits=0; | 220 | int dBits = 0; |
315 | #ifndef QT_QWS_EBX // zaurus doesnt have this | ||
316 | if (ioctl( sd, SOUND_PCM_READ_BITS, &dBits) == -1) { | 221 | if (ioctl( sd, SOUND_PCM_READ_BITS, &dBits) == -1) { |
317 | perror("ioctl(\"SNDCTL_PCM_READ_BITS\")"); | 222 | perror("ioctl(\"SNDCTL_PCM_READ_BITS\")"); |
318 | } | 223 | } |
319 | #endif | ||
320 | return dBits; | 224 | return dBits; |
321 | } | 225 | } |
322 | 226 | ||
323 | int Device::getDeviceChannels() { | 227 | int Device::getDeviceChannels() { |
324 | int dCh=0; | 228 | int dCh = 0; |
325 | if (ioctl( sd, SOUND_PCM_READ_CHANNELS, &dCh) == -1) { | 229 | if (ioctl( sd, SOUND_PCM_READ_CHANNELS, &dCh) == -1) { |
326 | perror("ioctl(\"SNDCTL_PCM_READ_CHANNELS\")"); | 230 | perror("ioctl(\"SNDCTL_PCM_READ_CHANNELS\")"); |
327 | } | 231 | } |
328 | return dCh; | 232 | return dCh; |
329 | } | 233 | } |
330 | 234 | ||
331 | int Device::getDeviceFragSize() { | 235 | int Device::getDeviceFragSize() { |
332 | int frag_size; | 236 | int frag_size; |
333 | 237 | ||
334 | if (ioctl( sd, SNDCTL_DSP_GETBLKSIZE, &frag_size) == -1) { | 238 | if (ioctl( sd, SNDCTL_DSP_GETBLKSIZE, &frag_size) == -1) { |
335 | qDebug( "no fragsize" ); | 239 | qDebug( "no fragsize" ); |
336 | } else { | 240 | } else { |
337 | qDebug( "driver says frag size is %d",frag_size); | 241 | qDebug( "driver says frag size is %d",frag_size); |
338 | } | 242 | } |
339 | return frag_size; | 243 | return frag_size; |
340 | } | 244 | } |
@@ -346,29 +250,27 @@ bool Device::setFragSize(int frag) { | |||
346 | } | 250 | } |
347 | return true; | 251 | return true; |
348 | } | 252 | } |
349 | 253 | ||
350 | bool Device::reset() { | 254 | bool Device::reset() { |
351 | closeDevice(true); | 255 | closeDevice(true); |
352 | openDsp(); | 256 | openDsp(); |
353 | if (ioctl( sd, SNDCTL_DSP_RESET, 0) == -1) { | 257 | if (ioctl( sd, SNDCTL_DSP_RESET, 0) == -1) { |
354 | perror("ioctl(\"SNDCTL_DSP_RESET\")"); | 258 | perror("ioctl(\"SNDCTL_DSP_RESET\")"); |
355 | return false; | 259 | return false; |
356 | } | 260 | } |
357 | return true; | 261 | return true; |
358 | } | 262 | } |
359 | 263 | ||
360 | int Device::devRead(int soundDescriptor, short *buf, int size) { | 264 | int Device::devRead(int soundDescriptor, short *buf, int size) { |
361 | Q_UNUSED(soundDescriptor); | 265 | Q_UNUSED(soundDescriptor); |
362 | int number = 0; | 266 | int number = 0; |
363 | number = ::read( sd /*soundDescriptor*/, (char *)buf, size); | 267 | number = ::read( sd /*soundDescriptor*/, (char *)buf, size); |
364 | return number; | 268 | return number; |
365 | } | 269 | } |
366 | 270 | ||
367 | int Device::devWrite(int soundDescriptor, short * buf, int size) { | 271 | int Device::devWrite(int soundDescriptor, short * buf, int size) { |
368 | Q_UNUSED(soundDescriptor); | 272 | Q_UNUSED(soundDescriptor); |
369 | int bytesWritten = 0; | 273 | int bytesWritten = 0; |
370 | bytesWritten = ::write( sd /*soundDescriptor*/, buf, size); | 274 | bytesWritten = ::write( sd /*soundDescriptor*/, buf, size); |
371 | return bytesWritten; | 275 | return bytesWritten; |
372 | } | 276 | } |
373 | |||
374 | |||
diff --git a/noncore/multimedia/opierec/device.h b/noncore/multimedia/opierec/device.h index 8152e85..dbc7b00 100644 --- a/noncore/multimedia/opierec/device.h +++ b/noncore/multimedia/opierec/device.h | |||
@@ -1,48 +1,48 @@ | |||
1 | 1 | ||
2 | #ifndef DEVICE_H | 2 | #ifndef DEVICE_H |
3 | #define DEVICE_H | 3 | #define DEVICE_H |
4 | #include <qobject.h> | 4 | #include <qobject.h> |
5 | #include <sys/soundcard.h> | 5 | #include <sys/soundcard.h> |
6 | 6 | ||
7 | class Device : public QObject { | 7 | class Device : public QObject { |
8 | Q_OBJECT | 8 | Q_OBJECT |
9 | public: | 9 | public: |
10 | Device( QObject * parent=0, const char * dspStr=0, const char * mixerStr=0, bool record=0 ); | 10 | Device( QObject * parent=0, bool record=0 ); |
11 | ~Device() {}; | 11 | ~Device() {}; |
12 | bool closeDevice( bool); | 12 | bool closeDevice( bool); |
13 | int getChannels(); | 13 | int getChannels(); |
14 | int getFormat(); | 14 | int getFormat(); |
15 | int getInVolume(); | 15 | int getInVolume(); |
16 | int getOutVolume(); | 16 | int getOutVolume(); |
17 | int getRate(); | 17 | int getRate(); |
18 | int getRes(); | 18 | int getRes(); |
19 | int sd; //sound descriptor | 19 | int sd; //sound descriptor |
20 | void changedInVolume(int); | 20 | void changedInVolume(int); |
21 | void changedOutVolume(int); | 21 | void changedOutVolume(int); |
22 | bool openDsp(); | 22 | bool openDsp(); |
23 | int getDeviceFormat(); | 23 | int getDeviceFormat(); |
24 | int getDeviceRate(); | 24 | int getDeviceRate(); |
25 | int getDeviceBits(); | 25 | int getDeviceBits(); |
26 | int getDeviceChannels(); | 26 | int getDeviceChannels(); |
27 | int getDeviceFragSize(); | 27 | int getDeviceFragSize(); |
28 | bool setFragSize(int); | 28 | bool setFragSize(int); |
29 | bool setDeviceChannels(int); | 29 | bool setDeviceChannels(int); |
30 | bool setDeviceRate(int); | 30 | bool setDeviceRate(int); |
31 | bool setDeviceFormat(int); | 31 | bool setDeviceFormat(int); |
32 | bool reset(); | 32 | bool reset(); |
33 | 33 | ||
34 | int devRead(int, short *, int); | 34 | int devRead(int, short *, int); |
35 | int devWrite(int, short *, int); | 35 | int devWrite(int, short *, int); |
36 | 36 | ||
37 | private: | 37 | private: |
38 | int devRes, devCh, devRate, devForm, flags; | 38 | int devRes, devCh, devRate, devForm, flags; |
39 | char *dspstr, *mixstr; | 39 | QString dspstr, mixstr; |
40 | bool selectMicInput(); | 40 | bool selectMicInput(); |
41 | int openDevice( int ); | 41 | int openDevice( int ); |
42 | private slots: | 42 | private slots: |
43 | 43 | ||
44 | protected: | 44 | protected: |
45 | 45 | ||
46 | }; | 46 | }; |
47 | 47 | ||
48 | #endif | 48 | #endif |
diff --git a/noncore/multimedia/opierec/qtrec.cpp b/noncore/multimedia/opierec/qtrec.cpp index 6793b4e..e827083 100644 --- a/noncore/multimedia/opierec/qtrec.cpp +++ b/noncore/multimedia/opierec/qtrec.cpp | |||
@@ -1,22 +1,22 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | // qtrec.cpp | 2 | // qtrec.cpp |
3 | Created: Thu Jan 17 11:19:58 2002 | 3 | Created: Thu Jan 17 11:19:58 2002 |
4 | copyright 2002 by L.J. Potter <ljp@llornkcor.com> | 4 | copyright 2002 by L.J. Potter <ljp@llornkcor.com> |
5 | ****************************************************************************/ | 5 | ****************************************************************************/ |
6 | #define DEV_VERSION | 6 | //#define DEV_VERSION |
7 | 7 | ||
8 | #include "pixmaps.h" | 8 | #include "pixmaps.h" |
9 | #include "qtrec.h" | 9 | #include "qtrec.h" |
10 | #include "waveform.h" | 10 | #include "waveform.h" |
11 | extern "C" { | 11 | extern "C" { |
12 | #include "adpcm.h" | 12 | #include "adpcm.h" |
13 | } | 13 | } |
14 | 14 | ||
15 | /* OPIE */ | 15 | /* OPIE */ |
16 | #include <opie2/odebug.h> | 16 | #include <opie2/odebug.h> |
17 | #include <qpe/config.h> | 17 | #include <qpe/config.h> |
18 | #include <qpe/qcopenvelope_qws.h> | 18 | #include <qpe/qcopenvelope_qws.h> |
19 | #include <qpe/qpeapplication.h> | 19 | #include <qpe/qpeapplication.h> |
20 | #include <qpe/resource.h> | 20 | #include <qpe/resource.h> |
21 | #include <qpe/storage.h> | 21 | #include <qpe/storage.h> |
22 | using namespace Opie::Core; | 22 | using namespace Opie::Core; |
@@ -50,61 +50,32 @@ using namespace Opie::Core; | |||
50 | #include <sys/types.h> | 50 | #include <sys/types.h> |
51 | #include <sys/vfs.h> | 51 | #include <sys/vfs.h> |
52 | #include <unistd.h> | 52 | #include <unistd.h> |
53 | #include <sys/wait.h> | 53 | #include <sys/wait.h> |
54 | #include <sys/signal.h> | 54 | #include <sys/signal.h> |
55 | #include <pthread.h> | 55 | #include <pthread.h> |
56 | 56 | ||
57 | #ifdef PDAUDIO //ALSA | 57 | #ifdef PDAUDIO //ALSA |
58 | #include <alsa/asoundlib.h> | 58 | #include <alsa/asoundlib.h> |
59 | static int deviceSampleRates[8] = { 32000, 44100, 48000, 88200, 96000, 176400, 192000, -1 }; | 59 | static int deviceSampleRates[8] = { 32000, 44100, 48000, 88200, 96000, 176400, 192000, -1 }; |
60 | static int deviceBitRates[] = { 8, 16, 24, 32, -1 }; | 60 | static int deviceBitRates[] = { 8, 16, 24, 32, -1 }; |
61 | #else //OSS | 61 | #else //OSS |
62 | static int deviceSampleRates[6] = { 11025, 16000, 22050, 32000, 44100, -1 }; | 62 | static int deviceSampleRates[6] = { 11025, 16000, 22050, 32000, 44100, -1 }; |
63 | static int deviceBitRates[] = { 8, 16, -1 }; | 63 | static int deviceBitRates[] = { 8, 16, -1 }; |
64 | #endif | 64 | #endif |
65 | 65 | ||
66 | #if defined(QT_QWS_SL5XXX) | ||
67 | ///#if defined(QT_QWS_EBX) | ||
68 | |||
69 | #define DSPSTROUT "/dev/dsp" | ||
70 | #define DSPSTRMIXEROUT "/dev/mixer" | ||
71 | |||
72 | #ifdef SHARP | ||
73 | #define DSPSTRIN "/dev/dsp1" | ||
74 | #define DSPSTRMIXERIN "/dev/mixer1" | ||
75 | #else | ||
76 | #define DSPSTRIN "/dev/dsp" | ||
77 | #define DSPSTRMIXERIN "/dev/mixer" | ||
78 | #endif | ||
79 | |||
80 | #else | ||
81 | |||
82 | #ifdef QT_QWS_DEVFS | ||
83 | #define DSPSTROUT "/dev/sound/dsp" | ||
84 | #define DSPSTRIN "/dev/sound/dsp" | ||
85 | #define DSPSTRMIXERIN "/dev/sound/mixer" | ||
86 | #define DSPSTRMIXEROUT "/dev/sound/mixer" | ||
87 | #else | ||
88 | #define DSPSTROUT "/dev/dsp" | ||
89 | #define DSPSTRIN "/dev/dsp" | ||
90 | #define DSPSTRMIXERIN "/dev/mixer" | ||
91 | #define DSPSTRMIXEROUT "/dev/mixer" | ||
92 | #endif | ||
93 | |||
94 | #endif | ||
95 | 66 | ||
96 | //#define ZAURUS 0 | 67 | //#define ZAURUS 0 |
97 | struct adpcm_state encoder_state; | 68 | struct adpcm_state encoder_state; |
98 | struct adpcm_state decoder_state; | 69 | struct adpcm_state decoder_state; |
99 | 70 | ||
100 | typedef struct { | 71 | typedef struct { |
101 | int sampleRate; | 72 | int sampleRate; |
102 | /* int fragSize; */ | 73 | /* int fragSize; */ |
103 | /* int blockSize; */ | 74 | /* int blockSize; */ |
104 | int resolution; //bitrate | 75 | int resolution; //bitrate |
105 | int channels; //number of channels | 76 | int channels; //number of channels |
106 | int fd; //file descriptor | 77 | int fd; //file descriptor |
107 | int sd; //sound device descriptor | 78 | int sd; //sound device descriptor |
108 | int numberSamples; //total number of samples | 79 | int numberSamples; //total number of samples |
109 | int SecondsToRecord; // number of seconds that should be recorded | 80 | int SecondsToRecord; // number of seconds that should be recorded |
110 | float numberOfRecordedSeconds; //total number of samples recorded | 81 | float numberOfRecordedSeconds; //total number of samples recorded |
@@ -180,34 +151,34 @@ void quickRec() | |||
180 | odebug << "" << filePara.fileName << " " << number << "" << oendl; | 151 | odebug << "" << filePara.fileName << " " << number << "" << oendl; |
181 | stopped = true; | 152 | stopped = true; |
182 | return; | 153 | return; |
183 | } | 154 | } |
184 | //if(stereo == 2) { | 155 | //if(stereo == 2) { |
185 | // adpcm_coder( sbuf2, abuf, number/2, &encoder_state); | 156 | // adpcm_coder( sbuf2, abuf, number/2, &encoder_state); |
186 | adpcm_coder( sbuf, abuf, number/2, &encoder_state); | 157 | adpcm_coder( sbuf, abuf, number/2, &encoder_state); |
187 | 158 | ||
188 | bytesWritten = ::write( filePara.fd , (short *)abuf, number/4); | 159 | bytesWritten = ::write( filePara.fd , (short *)abuf, number/4); |
189 | 160 | ||
190 | waveform->newSamples( sbuf, number ); | 161 | waveform->newSamples( sbuf, number ); |
191 | 162 | ||
192 | total += bytesWritten; | 163 | total += bytesWritten; |
193 | filePara.numberSamples = total; | 164 | filePara.numberSamples = total; |
194 | timeSlider->setValue( total); | 165 | timeSlider->setValue( total); |
195 | 166 | ||
196 | printf("%d, bytes %d,total %d\r",number, bytesWritten, total); | 167 | printf("%d, bytes %d,total %d\r", number, bytesWritten, total); |
197 | fflush(stdout); | 168 | fflush(stdout); |
198 | 169 | ||
199 | filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate * (float)2/ filePara.channels; | 170 | filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate * (float)2/ filePara.channels; |
200 | 171 | ||
201 | qApp->processEvents(); | 172 | qApp->processEvents(); |
202 | if( total >= filePara.samplesToRecord) { | 173 | if( total >= filePara.samplesToRecord) { |
203 | stopped = true; | 174 | stopped = true; |
204 | break; | 175 | break; |
205 | } | 176 | } |
206 | } | 177 | } |
207 | } else { | 178 | } else { |
208 | // <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_PCM >>>>>>>>>>>>>>>>>>>>>> | 179 | // <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_PCM >>>>>>>>>>>>>>>>>>>>>> |
209 | odebug << "start recording WAVE_FORMAT_PCM" << oendl; | 180 | odebug << "start recording WAVE_FORMAT_PCM" << oendl; |
210 | short inbuffer[ BUFSIZE ], outbuffer[ BUFSIZE ]; | 181 | short inbuffer[ BUFSIZE ], outbuffer[ BUFSIZE ]; |
211 | memset( inbuffer, 0, BUFSIZE); | 182 | memset( inbuffer, 0, BUFSIZE); |
212 | memset( outbuffer, 0, BUFSIZE); | 183 | memset( outbuffer, 0, BUFSIZE); |
213 | 184 | ||
@@ -230,34 +201,34 @@ void quickRec() | |||
230 | 201 | ||
231 | bytesWritten = ::write( filePara.fd , inbuffer, number); | 202 | bytesWritten = ::write( filePara.fd , inbuffer, number); |
232 | waveform->newSamples( inbuffer, number ); | 203 | waveform->newSamples( inbuffer, number ); |
233 | 204 | ||
234 | if( bytesWritten < 0) { | 205 | if( bytesWritten < 0) { |
235 | perror("File writing error "); | 206 | perror("File writing error "); |
236 | stopped = true; | 207 | stopped = true; |
237 | return; | 208 | return; |
238 | } | 209 | } |
239 | 210 | ||
240 | total += bytesWritten; | 211 | total += bytesWritten; |
241 | 212 | ||
242 | filePara.numberSamples = total; | 213 | filePara.numberSamples = total; |
243 | 214 | ||
244 | if( filePara.SecondsToRecord != 0) | 215 | if( filePara.SecondsToRecord != 0) |
245 | timeSlider->setValue( total); | 216 | timeSlider->setValue( total); |
246 | printf("%d, bytes %d,total %d\r",number, bytesWritten , total); | 217 | printf("%d, bytes %d,total %d\r",number, bytesWritten , total); |
247 | fflush(stdout); | 218 | fflush(stdout); |
248 | 219 | ||
249 | filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate | 220 | filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate |
250 | / (float)2/filePara.channels; | 221 | / (float)2/filePara.channels; |
251 | qApp->processEvents(); | 222 | qApp->processEvents(); |
252 | 223 | ||
253 | if( total >= filePara.samplesToRecord) { | 224 | if( total >= filePara.samplesToRecord) { |
254 | stopped = true; | 225 | stopped = true; |
255 | break; | 226 | break; |
256 | } | 227 | } |
257 | } | 228 | } |
258 | } //end main loop | 229 | } //end main loop |
259 | 230 | ||
260 | } else { | 231 | } else { |
261 | // <<<<<<<<<<<<<<<<<<<<<<< format = AFMT_U8; | 232 | // <<<<<<<<<<<<<<<<<<<<<<< format = AFMT_U8; |
262 | unsigned char unsigned_inbuffer[ BUFSIZE ], unsigned_outbuffer[ BUFSIZE ]; | 233 | unsigned char unsigned_inbuffer[ BUFSIZE ], unsigned_outbuffer[ BUFSIZE ]; |
263 | memset( unsigned_inbuffer, 0, BUFSIZE); | 234 | memset( unsigned_inbuffer, 0, BUFSIZE); |
@@ -283,32 +254,33 @@ void quickRec() | |||
283 | total += bytesWritten; | 254 | total += bytesWritten; |
284 | filePara.numberSamples = total; | 255 | filePara.numberSamples = total; |
285 | // printf("%d, bytes %d,total %d \r",number, bytesWritten , total); | 256 | // printf("%d, bytes %d,total %d \r",number, bytesWritten , total); |
286 | // fflush(stdout); | 257 | // fflush(stdout); |
287 | if( filePara.SecondsToRecord !=0) | 258 | if( filePara.SecondsToRecord !=0) |
288 | timeSlider->setValue( total); | 259 | timeSlider->setValue( total); |
289 | 260 | ||
290 | filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate; | 261 | filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate; |
291 | 262 | ||
292 | qApp->processEvents(); | 263 | qApp->processEvents(); |
293 | if( total >= filePara.samplesToRecord) { | 264 | if( total >= filePara.samplesToRecord) { |
294 | stopped = true; | 265 | stopped = true; |
295 | break; | 266 | break; |
296 | } | 267 | } |
297 | } //end main loop | 268 | } //end main loop |
298 | } | 269 | } |
270 | printf("\n"); | ||
299 | } /// END quickRec() | 271 | } /// END quickRec() |
300 | 272 | ||
301 | 273 | ||
302 | #ifdef THREADED | 274 | #ifdef THREADED |
303 | void playIt() | 275 | void playIt() |
304 | #else | 276 | #else |
305 | void QtRec::playIt() | 277 | void QtRec::playIt() |
306 | #endif | 278 | #endif |
307 | { | 279 | { |
308 | int bytesWritten = 0; | 280 | int bytesWritten = 0; |
309 | int number = 0; | 281 | int number = 0; |
310 | int total = 0; // Total number of bytes read in so far. | 282 | int total = 0; // Total number of bytes read in so far. |
311 | if( filePara.resolution == 16 ) { //AFMT_S16_LE) { | 283 | if( filePara.resolution == 16 ) { //AFMT_S16_LE) { |
312 | if( filePara.format == WAVE_FORMAT_DVI_ADPCM) { | 284 | if( filePara.format == WAVE_FORMAT_DVI_ADPCM) { |
313 | char abuf[ BUFSIZE / 2 ]; | 285 | char abuf[ BUFSIZE / 2 ]; |
314 | short sbuf[ BUFSIZE ]; | 286 | short sbuf[ BUFSIZE ]; |
@@ -437,40 +409,33 @@ void playIt() | |||
437 | 409 | ||
438 | QtRec::QtRec( QWidget* parent, const char* name, WFlags fl ) | 410 | QtRec::QtRec( QWidget* parent, const char* name, WFlags fl ) |
439 | : QWidget( parent, name, fl ) | 411 | : QWidget( parent, name, fl ) |
440 | { | 412 | { |
441 | if ( !name ) | 413 | if ( !name ) |
442 | setName( "OpieRec" ); | 414 | setName( "OpieRec" ); |
443 | init(); | 415 | init(); |
444 | initConfig(); | 416 | initConfig(); |
445 | initConnections(); | 417 | initConnections(); |
446 | renameBox = 0; | 418 | renameBox = 0; |
447 | 419 | ||
448 | // open sound device to get volumes | 420 | // open sound device to get volumes |
449 | Config hwcfg("OpieRec"); | 421 | Config hwcfg("OpieRec"); |
450 | hwcfg.setGroup("Hardware"); | 422 | hwcfg.setGroup("Hardware"); |
451 | 423 | ||
452 | 424 | ||
453 | soundDevice = new Device( this, | 425 | soundDevice = new Device( this, false); //open play |
454 | hwcfg.readEntry( "Audio",DSPSTROUT), | ||
455 | hwcfg.readEntry( "Mixer",DSPSTRMIXEROUT), false); | ||
456 | // soundDevice = new Device( this, hwcfg.readEntry( "Audio","hw:0"), hwcfg.readEntry( "Mixer","hw:0"), false); | ||
457 | |||
458 | // soundDevice->setDeviceFormat(AFMT_S16_LE); | ||
459 | // soundDevice->setDeviceChannels(1); | ||
460 | // soundDevice->setDeviceRate( 22050); | ||
461 | 426 | ||
462 | getInVol(); | 427 | getInVol(); |
463 | getOutVol(); | 428 | getOutVol(); |
464 | 429 | ||
465 | soundDevice->closeDevice( true); | 430 | soundDevice->closeDevice( true); |
466 | soundDevice->sd = -1; | 431 | soundDevice->sd = -1; |
467 | soundDevice = 0; | 432 | soundDevice = 0; |
468 | wavFile = 0; | 433 | wavFile = 0; |
469 | // if( soundDevice) delete soundDevice; | 434 | // if( soundDevice) delete soundDevice; |
470 | QTimer::singleShot(100,this, SLOT(initIconView())); | 435 | QTimer::singleShot(100,this, SLOT(initIconView())); |
471 | 436 | ||
472 | if( autoMute) | 437 | if( autoMute) |
473 | doMute( true); | 438 | doMute( true); |
474 | // ListView1->setFocus(); | 439 | // ListView1->setFocus(); |
475 | playing = false; | 440 | playing = false; |
476 | } | 441 | } |
@@ -491,33 +456,33 @@ void QtRec::cleanUp() { | |||
491 | 456 | ||
492 | if( autoMute) | 457 | if( autoMute) |
493 | doMute(false); | 458 | doMute(false); |
494 | 459 | ||
495 | // if( wavFile) delete wavFile; | 460 | // if( wavFile) delete wavFile; |
496 | // if(soundDevice) delete soundDevice; | 461 | // if(soundDevice) delete soundDevice; |
497 | } | 462 | } |
498 | 463 | ||
499 | void QtRec::init() { | 464 | void QtRec::init() { |
500 | 465 | ||
501 | needsStereoOut = false; | 466 | needsStereoOut = false; |
502 | QPixmap image3( ( const char** ) image3_data ); | 467 | QPixmap image3( ( const char** ) image3_data ); |
503 | QPixmap image4( ( const char** ) image4_data ); | 468 | QPixmap image4( ( const char** ) image4_data ); |
504 | QPixmap image6( ( const char** ) image6_data ); | 469 | QPixmap image6( ( const char** ) image6_data ); |
505 | 470 | ||
506 | stopped = true; | 471 | stopped = true; |
507 | setCaption( tr( "OpieRecord " ) + QString::number(VERSION) ); | 472 | setCaption( tr( "OpieRecord " )); |
508 | QGridLayout *layout = new QGridLayout( this ); | 473 | QGridLayout *layout = new QGridLayout( this ); |
509 | layout->setSpacing( 2); | 474 | layout->setSpacing( 2); |
510 | layout->setMargin( 2); | 475 | layout->setMargin( 2); |
511 | 476 | ||
512 | TabWidget = new QTabWidget( this, "TabWidget" ); | 477 | TabWidget = new QTabWidget( this, "TabWidget" ); |
513 | layout->addMultiCellWidget(TabWidget, 0, 7, 0, 8); | 478 | layout->addMultiCellWidget(TabWidget, 0, 7, 0, 8); |
514 | // TabWidget->setTabShape(QTabWidget::Triangular); | 479 | // TabWidget->setTabShape(QTabWidget::Triangular); |
515 | 480 | ||
516 | ///**********<<<<<<<<<<<<>>>>>>>>>>>>*************** | 481 | ///**********<<<<<<<<<<<<>>>>>>>>>>>>*************** |
517 | tab = new QWidget( TabWidget, "tab" ); | 482 | tab = new QWidget( TabWidget, "tab" ); |
518 | 483 | ||
519 | QGridLayout *layout1 = new QGridLayout( tab); | 484 | QGridLayout *layout1 = new QGridLayout( tab); |
520 | layout1->setSpacing( 2); | 485 | layout1->setSpacing( 2); |
521 | layout1->setMargin( 2); | 486 | layout1->setMargin( 2); |
522 | 487 | ||
523 | timeSlider = new QSlider( 0,100,10,0, QSlider::Horizontal, tab, (const char *) "timeSlider" ); | 488 | timeSlider = new QSlider( 0,100,10,0, QSlider::Horizontal, tab, (const char *) "timeSlider" ); |
@@ -563,65 +528,53 @@ void QtRec::init() { | |||
563 | rewindTimer = new QTimer( this ); | 528 | rewindTimer = new QTimer( this ); |
564 | connect( rewindTimer, SIGNAL( timeout() ), | 529 | connect( rewindTimer, SIGNAL( timeout() ), |
565 | this, SLOT( rewindTimerTimeout() ) ); | 530 | this, SLOT( rewindTimerTimeout() ) ); |
566 | 531 | ||
567 | forwardTimer = new QTimer( this ); | 532 | forwardTimer = new QTimer( this ); |
568 | connect( forwardTimer, SIGNAL( timeout() ), | 533 | connect( forwardTimer, SIGNAL( timeout() ), |
569 | this, SLOT( forwardTimerTimeout() ) ); | 534 | this, SLOT( forwardTimerTimeout() ) ); |
570 | 535 | ||
571 | deleteSoundButton = new QPushButton( tab, "deleteSoundButton" ); | 536 | deleteSoundButton = new QPushButton( tab, "deleteSoundButton" ); |
572 | layout1->addMultiCellWidget( deleteSoundButton, 1, 1, 8, 8); | 537 | layout1->addMultiCellWidget( deleteSoundButton, 1, 1, 8, 8); |
573 | deleteSoundButton->setText( tr( "Del" ) ); | 538 | deleteSoundButton->setText( tr( "Del" ) ); |
574 | 539 | ||
575 | ListView1 = new QListView( tab, "IconView1" ); | 540 | ListView1 = new QListView( tab, "IconView1" ); |
576 | layout1->addMultiCellWidget( ListView1, 2, 2, 0, 8); | 541 | layout1->addMultiCellWidget( ListView1, 2, 2, 0, 8); |
577 | 542 | ||
578 | ListView1->addColumn( tr( "Name" ) ); | 543 | ListView1->addColumn( tr( "Name" ) ); |
579 | // ListView1->setColumnWidth( 0, 140); | ||
580 | ListView1->setSorting( 1, false); | 544 | ListView1->setSorting( 1, false); |
581 | ListView1->addColumn( tr( "Time" ) ); //in seconds | 545 | ListView1->addColumn( tr( "Time" ) ); //in seconds |
582 | // ListView1->setColumnWidth( 1, -1); | ||
583 | // ListView1->addColumn( tr("Location") ); | ||
584 | // ListView1->setColumnWidth( 2, -1); | ||
585 | // ListView1->addColumn( tr("Date") ); | ||
586 | // ListView1->setColumnWidth( 3, -1); | ||
587 | ListView1->setColumnWidthMode(0, QListView::Maximum); | 546 | ListView1->setColumnWidthMode(0, QListView::Maximum); |
588 | // ListView1->setColumnWidthMode(1, QListView::Maximum); | ||
589 | |||
590 | // ListView1->setColumnWidthMode( 0, QListView::Manual); | ||
591 | ListView1->setColumnAlignment( 1, QListView::AlignCenter); | 547 | ListView1->setColumnAlignment( 1, QListView::AlignCenter); |
592 | // ListView1->setColumnAlignment( 2, QListView::AlignRight); | ||
593 | // ListView1->setColumnAlignment( 3, QListView::AlignLeft); | ||
594 | ListView1->setAllColumnsShowFocus( true ); | 548 | ListView1->setAllColumnsShowFocus( true ); |
595 | QPEApplication::setStylusOperation( ListView1->viewport(), QPEApplication::RightOnHold); | 549 | QPEApplication::setStylusOperation( ListView1->viewport(), QPEApplication::RightOnHold); |
596 | 550 | ||
597 | TabWidget->insertTab( tab, tr( "Files" ) ); | 551 | TabWidget->insertTab( tab, tr( "Files" ) ); |
598 | 552 | ||
599 | ///**********<<<<<<<<<<<<>>>>>>>>>>>>*************** | 553 | ///**********<<<<<<<<<<<<>>>>>>>>>>>>*************** |
600 | tab_3 = new QWidget( TabWidget, "tab_3" ); | 554 | tab_3 = new QWidget( TabWidget, "tab_3" ); |
601 | QGridLayout *glayout3 = new QGridLayout( tab_3 ); | 555 | QGridLayout *glayout3 = new QGridLayout( tab_3 ); |
602 | glayout3->setSpacing( 2); | 556 | glayout3->setSpacing( 2); |
603 | glayout3->setMargin( 2); | 557 | glayout3->setMargin( 2); |
604 | //////////////////////////////////// | 558 | //////////////////////////////////// |
605 | sampleGroup = new QGroupBox( tab_3, "samplegroup" ); | 559 | sampleGroup = new QGroupBox( tab_3, "samplegroup" ); |
606 | sampleGroup->setTitle( tr( "Sample Rate" ) ); | 560 | sampleGroup->setTitle( tr( "Sample Rate" ) ); |
607 | sampleGroup->setFixedSize( 95,50); | 561 | sampleGroup->setFixedSize( 95,50); |
608 | 562 | ||
609 | sampleRateComboBox = new QComboBox( false, sampleGroup, "SampleRateComboBox" ); | 563 | sampleRateComboBox = new QComboBox( false, sampleGroup, "SampleRateComboBox" ); |
610 | sampleRateComboBox->setGeometry( QRect( 10, 20, 80, 25 ) ); | 564 | sampleRateComboBox->setGeometry( QRect( 10, 20, 80, 25 ) ); |
611 | //#ifndef QT_QWS_EBX | ||
612 | QString s; | 565 | QString s; |
613 | int z = 0; | 566 | int z = 0; |
614 | while( deviceSampleRates[z] != -1) { | 567 | while( deviceSampleRates[z] != -1) { |
615 | sampleRateComboBox->insertItem( s.setNum( deviceSampleRates[z], 10)); | 568 | sampleRateComboBox->insertItem( s.setNum( deviceSampleRates[z], 10)); |
616 | z++; | 569 | z++; |
617 | } | 570 | } |
618 | 571 | ||
619 | 572 | ||
620 | glayout3->addMultiCellWidget( sampleGroup, 0, 0, 0, 0); | 573 | glayout3->addMultiCellWidget( sampleGroup, 0, 0, 0, 0); |
621 | 574 | ||
622 | sizeGroup= new QGroupBox( tab_3, "sizeGroup" ); | 575 | sizeGroup= new QGroupBox( tab_3, "sizeGroup" ); |
623 | sizeGroup->setTitle( tr( "Limit Size" ) ); | 576 | sizeGroup->setTitle( tr( "Limit Size" ) ); |
624 | sizeGroup->setFixedSize( 80, 50); | 577 | sizeGroup->setFixedSize( 80, 50); |
625 | 578 | ||
626 | sizeLimitCombo = new QComboBox( false, sizeGroup, "sizeLimitCombo" ); | 579 | sizeLimitCombo = new QComboBox( false, sizeGroup, "sizeLimitCombo" ); |
627 | sizeLimitCombo ->setGeometry( QRect( 5, 20, 70, 25 ) ); | 580 | sizeLimitCombo ->setGeometry( QRect( 5, 20, 70, 25 ) ); |
@@ -704,68 +657,65 @@ void QtRec::init() { | |||
704 | Layout15->addWidget( outMuteCheckBox ); | 657 | Layout15->addWidget( outMuteCheckBox ); |
705 | 658 | ||
706 | inMuteCheckBox = new QCheckBox ( tr("mute"), tab_5 ); | 659 | inMuteCheckBox = new QCheckBox ( tr("mute"), tab_5 ); |
707 | inMuteCheckBox-> setFocusPolicy ( QWidget::NoFocus ); | 660 | inMuteCheckBox-> setFocusPolicy ( QWidget::NoFocus ); |
708 | Layout15b->addWidget( inMuteCheckBox ); | 661 | Layout15b->addWidget( inMuteCheckBox ); |
709 | 662 | ||
710 | 663 | ||
711 | Layout19a->addLayout( Layout15 ); | 664 | Layout19a->addLayout( Layout15 ); |
712 | Layout19a->addLayout( Layout15b ); | 665 | Layout19a->addLayout( Layout15b ); |
713 | 666 | ||
714 | fillDirectoryCombo(); | 667 | fillDirectoryCombo(); |
715 | 668 | ||
716 | TabWidget->insertTab( tab_3, tr( "Options" ) ); | 669 | TabWidget->insertTab( tab_3, tr( "Options" ) ); |
717 | 670 | ||
718 | TabWidget->insertTab( tab_5, tr( "Volume" ) ); | 671 | TabWidget->insertTab( tab_5, tr( "Volume" ) ); |
719 | 672 | ||
720 | |||
721 | waveform = new Waveform( this, "waveform" ); | 673 | waveform = new Waveform( this, "waveform" ); |
722 | // waveform->setSizePolicy( QSizePolicy( (QSizePolicy::SizeType)5, (QSizePolicy::SizeType)3, waveform->sizePolicy().hasHeightForWidth() ) ); | ||
723 | waveform->setMinimumSize( QSize( 0, 50 ) ); | 674 | waveform->setMinimumSize( QSize( 0, 50 ) ); |
724 | 675 | ||
725 | layout->addMultiCellWidget( waveform, 8, 8, 0, 8); | 676 | layout->addMultiCellWidget( waveform, 8, 8, 0, 8); |
726 | waveform->setBackgroundColor ( black ); | 677 | waveform->setBackgroundColor ( black ); |
727 | } | 678 | } |
728 | 679 | ||
729 | void QtRec::initIconView() { | 680 | void QtRec::initIconView() { |
730 | owarn << "initIconView" << oendl; | ||
731 | ListView1->clear(); | 681 | ListView1->clear(); |
732 | Config cfg("OpieRec"); | 682 | Config cfg("OpieRec"); |
733 | cfg.setGroup("Sounds"); | 683 | cfg.setGroup("Sounds"); |
734 | QString temp; | 684 | QString temp; |
735 | QPixmap image0( ( const char** ) image0_data ); | 685 | QPixmap image0( ( const char** ) image0_data ); |
736 | 686 | ||
737 | int nFiles = cfg.readNumEntry("NumberofFiles",0); | 687 | int nFiles = cfg.readNumEntry("NumberofFiles",0); |
738 | owarn << "init number of files " << nFiles << "" << oendl; | 688 | // owarn << "init number of files " << nFiles << "" << oendl; |
739 | 689 | ||
740 | for(int i = 1; i <= nFiles; i++) { | 690 | for(int i = 1; i <= nFiles; i++) { |
741 | 691 | ||
742 | QListViewItem * item; | 692 | QListViewItem * item; |
743 | QString fileS, mediaLocation, fileDate, filePath; | 693 | QString fileS, mediaLocation, fileDate, filePath; |
744 | 694 | ||
745 | temp.sprintf( "%d",i); | 695 | temp.sprintf( "%d",i); |
746 | temp = cfg.readEntry( temp,""); //reads currentFile | 696 | temp = cfg.readEntry( temp,""); //reads currentFile |
747 | filePath = cfg.readEntry( temp,""); //currentFileName | 697 | filePath = cfg.readEntry( temp,""); //currentFileName |
748 | 698 | ||
749 | QFileInfo info(filePath); | 699 | QFileInfo info(filePath); |
750 | fileDate = info.lastModified().toString(); | 700 | fileDate = info.lastModified().toString(); |
751 | 701 | ||
752 | fileS = cfg.readEntry( filePath, "0" );// file length in seconds | 702 | fileS = cfg.readEntry( filePath, "0" );// file length in seconds |
753 | mediaLocation = getStorage( filePath); | 703 | mediaLocation = getStorage( filePath); |
754 | if( info.exists()) { | 704 | if( info.exists()) { |
755 | owarn << "new item " << temp << oendl; | 705 | // owarn << "new item " << temp << oendl; |
756 | item = new QListViewItem( ListView1, temp, fileS /*, mediaLocation, fileDate*/); | 706 | item = new QListViewItem( ListView1, temp, fileS /*, mediaLocation, fileDate*/); |
757 | item->setPixmap( 0, image0); | 707 | item->setPixmap( 0, image0); |
758 | if( currentFileName == filePath) | 708 | if( currentFileName == filePath) |
759 | ListView1->setSelected( item, true); | 709 | ListView1->setSelected( item, true); |
760 | } | 710 | } |
761 | } | 711 | } |
762 | } | 712 | } |
763 | 713 | ||
764 | void QtRec::initConnections() { | 714 | void QtRec::initConnections() { |
765 | connect(qApp,SIGNAL(aboutToQuit()),SLOT(cleanUp())); | 715 | connect(qApp,SIGNAL(aboutToQuit()),SLOT(cleanUp())); |
766 | 716 | ||
767 | connect(toBeginningButton,SIGNAL(pressed()),this,SLOT(rewindPressed())); | 717 | connect(toBeginningButton,SIGNAL(pressed()),this,SLOT(rewindPressed())); |
768 | connect(toBeginningButton,SIGNAL(released()),this,SLOT(rewindReleased())); | 718 | connect(toBeginningButton,SIGNAL(released()),this,SLOT(rewindReleased())); |
769 | connect(toEndButton,SIGNAL(pressed()),this,SLOT(FastforwardPressed())); | 719 | connect(toEndButton,SIGNAL(pressed()),this,SLOT(FastforwardPressed())); |
770 | connect(toEndButton,SIGNAL(released()),this,SLOT(FastforwardReleased())); | 720 | connect(toEndButton,SIGNAL(released()),this,SLOT(FastforwardReleased())); |
771 | connect(deleteSoundButton,SIGNAL(released()),this,SLOT(deleteSound())); | 721 | connect(deleteSoundButton,SIGNAL(released()),this,SLOT(deleteSound())); |
@@ -843,33 +793,33 @@ void QtRec::initConfig() { | |||
843 | filePara.resolution=16; | 793 | filePara.resolution=16; |
844 | } | 794 | } |
845 | 795 | ||
846 | autoMuteCheckBox->setChecked( cfg.readBoolEntry("useAutoMute",0)); | 796 | autoMuteCheckBox->setChecked( cfg.readBoolEntry("useAutoMute",0)); |
847 | if( autoMuteCheckBox->isChecked()) | 797 | if( autoMuteCheckBox->isChecked()) |
848 | slotAutoMute(true); | 798 | slotAutoMute(true); |
849 | else | 799 | else |
850 | slotAutoMute(false); | 800 | slotAutoMute(false); |
851 | 801 | ||
852 | Config cofg( "qpe"); | 802 | Config cofg( "qpe"); |
853 | cofg.setGroup( "Volume"); | 803 | cofg.setGroup( "Volume"); |
854 | outMuteCheckBox->setChecked( cofg.readBoolEntry( "Mute",0)); | 804 | outMuteCheckBox->setChecked( cofg.readBoolEntry( "Mute",0)); |
855 | inMuteCheckBox->setChecked( cofg.readBoolEntry( "MicMute",0)); | 805 | inMuteCheckBox->setChecked( cofg.readBoolEntry( "MicMute",0)); |
856 | } | 806 | } |
857 | 807 | ||
858 | void QtRec::stop() { | 808 | void QtRec::stop() { |
859 | owarn << "STOP" << oendl; | 809 | // owarn << "STOP" << oendl; |
860 | setRecordButton(false); | 810 | setRecordButton(false); |
861 | 811 | ||
862 | if( !recording) | 812 | if( !recording) |
863 | endPlaying(); | 813 | endPlaying(); |
864 | else | 814 | else |
865 | endRecording(); | 815 | endRecording(); |
866 | timeSlider->setValue(0); | 816 | timeSlider->setValue(0); |
867 | } | 817 | } |
868 | 818 | ||
869 | void QtRec::doPlayBtn() { | 819 | void QtRec::doPlayBtn() { |
870 | 820 | ||
871 | if(!stopped) { | 821 | if(!stopped) { |
872 | // playLabel2->setText(tr("Play")); | 822 | // playLabel2->setText(tr("Play")); |
873 | stop(); | 823 | stop(); |
874 | } else { | 824 | } else { |
875 | if(ListView1->currentItem() == 0) return; | 825 | if(ListView1->currentItem() == 0) return; |
@@ -1048,36 +998,32 @@ bool QtRec::setupAudio( bool b) { | |||
1048 | sampleformat = SND_PCM_FORMAT_U8; | 998 | sampleformat = SND_PCM_FORMAT_U8; |
1049 | filePara.resolution = 8; | 999 | filePara.resolution = 8; |
1050 | } | 1000 | } |
1051 | #else | 1001 | #else |
1052 | // we want to play | 1002 | // we want to play |
1053 | if( filePara.resolution == 16 || compressionCheckBox->isChecked() ) { | 1003 | if( filePara.resolution == 16 || compressionCheckBox->isChecked() ) { |
1054 | sampleformat = AFMT_S16_LE; | 1004 | sampleformat = AFMT_S16_LE; |
1055 | filePara.resolution = 16; | 1005 | filePara.resolution = 16; |
1056 | } else { | 1006 | } else { |
1057 | sampleformat = AFMT_U8; | 1007 | sampleformat = AFMT_U8; |
1058 | filePara.resolution = 8; | 1008 | filePara.resolution = 8; |
1059 | } | 1009 | } |
1060 | #endif | 1010 | #endif |
1061 | 1011 | ||
1062 | stereo = filePara.channels; | 1012 | stereo = filePara.channels; |
1063 | flags = O_WRONLY; | 1013 | flags = O_WRONLY; |
1064 | Config hwcfg("OpieRec"); | ||
1065 | hwcfg.setGroup("Hardware"); | ||
1066 | dspString = hwcfg.readEntry( "Audio", DSPSTROUT); | ||
1067 | mixerString = hwcfg.readEntry( "Mixer", DSPSTRMIXEROUT); | ||
1068 | recording = false; | 1014 | recording = false; |
1069 | } else { // we want to record | 1015 | } else { // we want to record |
1070 | 1016 | ||
1071 | #ifdef PDAUDIO //ALSA | 1017 | #ifdef PDAUDIO //ALSA |
1072 | if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16") | 1018 | if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16") |
1073 | sampleformat = SND_PCM_FORMAT_S16; | 1019 | sampleformat = SND_PCM_FORMAT_S16; |
1074 | else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "24") | 1020 | else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "24") |
1075 | sampleformat = SND_PCM_FORMAT_S24; | 1021 | sampleformat = SND_PCM_FORMAT_S24; |
1076 | else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "32") | 1022 | else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "32") |
1077 | sampleformat = SND_PCM_FORMAT_S32; | 1023 | sampleformat = SND_PCM_FORMAT_S32; |
1078 | else | 1024 | else |
1079 | sampleformat = SND_PCM_FORMAT_U8; | 1025 | sampleformat = SND_PCM_FORMAT_U8; |
1080 | 1026 | ||
1081 | #else | 1027 | #else |
1082 | if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16") | 1028 | if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16") |
1083 | sampleformat = AFMT_S16_LE; | 1029 | sampleformat = AFMT_S16_LE; |
@@ -1085,45 +1031,41 @@ bool QtRec::setupAudio( bool b) { | |||
1085 | sampleformat = AFMT_U8; | 1031 | sampleformat = AFMT_U8; |
1086 | 1032 | ||
1087 | if( !compressionCheckBox->isChecked()) { | 1033 | if( !compressionCheckBox->isChecked()) { |
1088 | filePara.format = WAVE_FORMAT_PCM; | 1034 | filePara.format = WAVE_FORMAT_PCM; |
1089 | // odebug << "WAVE_FORMAT_PCM" << oendl; | 1035 | // odebug << "WAVE_FORMAT_PCM" << oendl; |
1090 | } else { | 1036 | } else { |
1091 | filePara.format = WAVE_FORMAT_DVI_ADPCM; | 1037 | filePara.format = WAVE_FORMAT_DVI_ADPCM; |
1092 | sampleformat = AFMT_S16_LE; | 1038 | sampleformat = AFMT_S16_LE; |
1093 | // odebug << "WAVE_FORMAT_DVI_ADPCM" << oendl; | 1039 | // odebug << "WAVE_FORMAT_DVI_ADPCM" << oendl; |
1094 | } | 1040 | } |
1095 | #endif | 1041 | #endif |
1096 | 1042 | ||
1097 | stereo = filePara.channels; | 1043 | stereo = filePara.channels; |
1098 | // filePara.sampleRate = sampleRateComboBox->currentText().toInt( &ok,10);//44100; | 1044 | // filePara.sampleRate = sampleRateComboBox->currentText().toInt( &ok,10);//44100; |
1099 | flags= O_RDWR; | 1045 | flags= O_RDWR; |
1100 | // flags= O_RDONLY; | 1046 | // flags= O_RDONLY; |
1101 | Config hwcfg("OpieRec"); | ||
1102 | hwcfg.setGroup("Hardware"); | ||
1103 | dspString = hwcfg.readEntry( "Audio", DSPSTRIN); | ||
1104 | mixerString = hwcfg.readEntry( "Mixer", DSPSTRMIXERIN); | ||
1105 | recording = true; | 1047 | recording = true; |
1106 | } | 1048 | } |
1107 | 1049 | ||
1108 | // if(soundDevice) delete soundDevice; | 1050 | // if(soundDevice) delete soundDevice; |
1109 | odebug << "<<<<<<<<<<<<<<<<<<<open dsp " << filePara.sampleRate << " " << filePara.channels << " " << sampleformat << "" << oendl; | 1051 | odebug << "<<<<<<<<<<<<<<<<<<<open dsp " << filePara.sampleRate << " " << filePara.channels << " " << sampleformat << "" << oendl; |
1110 | owarn << "change waveform settings" << oendl; | 1052 | // owarn << "change waveform settings" << oendl; |
1111 | waveform->changeSettings( filePara.sampleRate, filePara.channels ); | 1053 | waveform->changeSettings( filePara.sampleRate, filePara.channels ); |
1112 | 1054 | ||
1113 | soundDevice = new Device( this, dspString, mixerString, b); | 1055 | soundDevice = new Device( this, b); //open rec |
1114 | // soundDevice->openDsp(); | 1056 | // soundDevice->openDsp(); |
1115 | soundDevice->reset(); | 1057 | soundDevice->reset(); |
1116 | 1058 | ||
1117 | odebug << "device has been made " << soundDevice->sd << "" << oendl; | 1059 | odebug << "device has been made " << soundDevice->sd << "" << oendl; |
1118 | 1060 | ||
1119 | ////////////////// <<<<<<<<<<<<>>>>>>>>>>>> | 1061 | ////////////////// <<<<<<<<<<<<>>>>>>>>>>>> |
1120 | soundDevice->setDeviceFormat( sampleformat); | 1062 | soundDevice->setDeviceFormat( sampleformat); |
1121 | soundDevice->setDeviceChannels( filePara.channels); | 1063 | soundDevice->setDeviceChannels( filePara.channels); |
1122 | soundDevice->setDeviceRate( filePara.sampleRate); | 1064 | soundDevice->setDeviceRate( filePara.sampleRate); |
1123 | soundDevice->getDeviceFragSize(); | 1065 | soundDevice->getDeviceFragSize(); |
1124 | #ifdef QT_QWS_EBX | 1066 | #ifdef QT_QWS_EBX |
1125 | int frag = FRAGSIZE; | 1067 | int frag = FRAGSIZE; |
1126 | soundDevice->setFragSize( frag); | 1068 | soundDevice->setFragSize( frag); |
1127 | soundDevice->getDeviceFragSize(); | 1069 | soundDevice->getDeviceFragSize(); |
1128 | #endif | 1070 | #endif |
1129 | ///////////////// | 1071 | ///////////////// |
@@ -1268,77 +1210,72 @@ void QtRec::newSound() { | |||
1268 | if( !rec()) { | 1210 | if( !rec()) { |
1269 | endRecording(); | 1211 | endRecording(); |
1270 | deleteSound(); | 1212 | deleteSound(); |
1271 | } | 1213 | } |
1272 | } | 1214 | } |
1273 | 1215 | ||
1274 | void QtRec::itClick(QListViewItem *item) { | 1216 | void QtRec::itClick(QListViewItem *item) { |
1275 | currentFile = item->text(0); | 1217 | currentFile = item->text(0); |
1276 | setCaption("OpieRecord "+currentFile); | 1218 | setCaption("OpieRecord "+currentFile); |
1277 | } | 1219 | } |
1278 | 1220 | ||
1279 | void QtRec::deleteSound() { | 1221 | void QtRec::deleteSound() { |
1280 | Config cfg("OpieRec"); | 1222 | Config cfg("OpieRec"); |
1281 | cfg.setGroup("Sounds"); | 1223 | cfg.setGroup("Sounds"); |
1282 | if( ListView1->currentItem() == NULL) | 1224 | if( ListView1->currentItem() == NULL) |
1283 | return; | 1225 | return; |
1284 | #ifndef DEV_VERSION | 1226 | // #ifndef DEV_VERSION |
1285 | switch ( QMessageBox::warning(this,tr("Delete"), | 1227 | // switch ( QMessageBox::warning(this,tr("Delete"), |
1286 | tr("Do you really want to <font size=+2><B>DELETE</B></font>\nthe selected file?"), | 1228 | // tr("Do you really want to <font size=+2><B>DELETE</B></font>\nthe selected file?"), |
1287 | tr("Yes"),tr("No"),0,1,1) ) { | 1229 | // tr("Yes"),tr("No"),0,1,1) ) { |
1288 | case 0: | 1230 | // case 0: |
1289 | #endif | 1231 | // #endif |
1290 | { | 1232 | // { |
1291 | QString file = ListView1->currentItem()->text(0); | 1233 | QString file = ListView1->currentItem()->text(0); |
1292 | QString fileName; | 1234 | QString fileName; |
1293 | fileName = cfg.readEntry( file, ""); | 1235 | fileName = cfg.readEntry( file, ""); |
1294 | QFile f( fileName); | 1236 | QFile f( fileName); |
1295 | if( f.exists()) | 1237 | if( f.exists()) |
1296 | if( !f.remove()) | 1238 | if( !f.remove()) |
1297 | QMessageBox::message( tr("Error"), tr("Could not remove file.")); | 1239 | QMessageBox::message( tr("Error"), tr("Could not remove file.")); |
1298 | 1240 | ||
1299 | int nFiles = cfg.readNumEntry( "NumberofFiles",0); | 1241 | int nFiles = cfg.readNumEntry( "NumberofFiles",0); |
1300 | bool found = false; | 1242 | bool found = false; |
1301 | for(int i=0;i<nFiles+1;i++) { | 1243 | for(int i=0;i<nFiles+1;i++) { |
1302 | 1244 | ||
1303 | if( cfg.readEntry( QString::number(i),"").find( file,0,true) != -1) { | 1245 | if( cfg.readEntry( QString::number(i),"").find( file,0,true) != -1) { |
1304 | found = true; | 1246 | found = true; |
1305 | cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),"")); | 1247 | cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),"")); |
1306 | } | 1248 | } |
1307 | if(found) | 1249 | if(found) |
1308 | cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),"")); | 1250 | cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),"")); |
1309 | } | 1251 | } |
1310 | 1252 | ||
1311 | cfg.removeEntry( cfg.readEntry( file)); | 1253 | cfg.removeEntry( cfg.readEntry( file)); |
1312 | cfg.removeEntry( file); | 1254 | cfg.removeEntry( file); |
1313 | cfg.writeEntry( "NumberofFiles", nFiles-1); | 1255 | cfg.writeEntry( "NumberofFiles", nFiles-1); |
1314 | cfg.write(); | 1256 | cfg.write(); |
1315 | 1257 | ||
1316 | ListView1->takeItem( ListView1->currentItem() ); | 1258 | ListView1->takeItem( ListView1->currentItem() ); |
1317 | delete ListView1->currentItem(); | 1259 | delete ListView1->currentItem(); |
1318 | 1260 | ||
1319 | ListView1->clear(); | 1261 | ListView1->clear(); |
1320 | ListView1->setSelected( ListView1->firstChild(), true); | 1262 | ListView1->setSelected( ListView1->firstChild(), true); |
1321 | initIconView(); | 1263 | initIconView(); |
1322 | update(); | 1264 | update(); |
1323 | } | 1265 | setCaption( tr( "OpieRecord " )); |
1324 | #ifndef DEV_VERSION | ||
1325 | }; | ||
1326 | #endif | ||
1327 | setCaption( tr( "OpieRecord " ) + QString::number(VERSION) ); | ||
1328 | |||
1329 | } | 1266 | } |
1330 | 1267 | ||
1331 | void QtRec::keyPressEvent( QKeyEvent *e) { | 1268 | void QtRec::keyPressEvent( QKeyEvent *e) { |
1332 | 1269 | ||
1333 | switch ( e->key() ) { | 1270 | switch ( e->key() ) { |
1334 | // case Key_F1: | 1271 | // case Key_F1: |
1335 | // if(stopped && !recording) | 1272 | // if(stopped && !recording) |
1336 | // newSound(); | 1273 | // newSound(); |
1337 | // else | 1274 | // else |
1338 | // stop(); | 1275 | // stop(); |
1339 | // break; | 1276 | // break; |
1340 | // case Key_F2: { | 1277 | // case Key_F2: { |
1341 | // if( !e->isAutoRepeat()) | 1278 | // if( !e->isAutoRepeat()) |
1342 | // rewindPressed(); | 1279 | // rewindPressed(); |
1343 | // } | 1280 | // } |
1344 | // break; | 1281 | // break; |
@@ -1430,32 +1367,33 @@ void QtRec::keyReleaseEvent( QKeyEvent *e) { | |||
1430 | // start(); | 1367 | // start(); |
1431 | // odebug << "Down" << oendl; | 1368 | // odebug << "Down" << oendl; |
1432 | // newSound(); | 1369 | // newSound(); |
1433 | break; | 1370 | break; |
1434 | case Key_Left: | 1371 | case Key_Left: |
1435 | odebug << "Left" << oendl; | 1372 | odebug << "Left" << oendl; |
1436 | rewindReleased(); | 1373 | rewindReleased(); |
1437 | break; | 1374 | break; |
1438 | case Key_Right: | 1375 | case Key_Right: |
1439 | odebug << "Right" << oendl; | 1376 | odebug << "Right" << oendl; |
1440 | FastforwardReleased(); | 1377 | FastforwardReleased(); |
1441 | break; | 1378 | break; |
1442 | } | 1379 | } |
1443 | } | 1380 | } |
1444 | 1381 | ||
1445 | void QtRec::endRecording() { | 1382 | void QtRec::endRecording() { |
1383 | |||
1446 | monitoring = false; | 1384 | monitoring = false; |
1447 | recording = false; | 1385 | recording = false; |
1448 | stopped = true; | 1386 | stopped = true; |
1449 | waveform->reset(); | 1387 | waveform->reset(); |
1450 | setRecordButton( false); | 1388 | setRecordButton( false); |
1451 | 1389 | ||
1452 | toBeginningButton->setEnabled( true); | 1390 | toBeginningButton->setEnabled( true); |
1453 | toEndButton->setEnabled( true); | 1391 | toEndButton->setEnabled( true); |
1454 | 1392 | ||
1455 | killTimers(); | 1393 | killTimers(); |
1456 | 1394 | ||
1457 | if(autoMute) | 1395 | if(autoMute) |
1458 | doMute( true); | 1396 | doMute( true); |
1459 | 1397 | ||
1460 | soundDevice->closeDevice( true); | 1398 | soundDevice->closeDevice( true); |
1461 | 1399 | ||
@@ -1490,132 +1428,134 @@ void QtRec::endRecording() { | |||
1490 | 1428 | ||
1491 | QString time; | 1429 | QString time; |
1492 | time.sprintf("%.2f", filePara.numberOfRecordedSeconds); | 1430 | time.sprintf("%.2f", filePara.numberOfRecordedSeconds); |
1493 | cfg.writeEntry( wavFile->currentFileName, time ); | 1431 | cfg.writeEntry( wavFile->currentFileName, time ); |
1494 | odebug << "writing config numberOfRecordedSeconds "+time << oendl; | 1432 | odebug << "writing config numberOfRecordedSeconds "+time << oendl; |
1495 | 1433 | ||
1496 | cfg.write(); | 1434 | cfg.write(); |
1497 | odebug << "finished recording" << oendl; | 1435 | odebug << "finished recording" << oendl; |
1498 | // timeLabel->setText(""); | 1436 | // timeLabel->setText(""); |
1499 | } | 1437 | } |
1500 | 1438 | ||
1501 | // if(soundDevice) delete soundDevice; | 1439 | // if(soundDevice) delete soundDevice; |
1502 | 1440 | ||
1503 | timeSlider->setValue(0); | 1441 | timeSlider->setValue(0); |
1504 | initIconView(); | 1442 | initIconView(); |
1505 | selectItemByName( currentFile); | 1443 | selectItemByName( currentFile); |
1444 | setCaption( tr( "OpieRecord " )); | ||
1445 | |||
1506 | } | 1446 | } |
1507 | 1447 | ||
1508 | void QtRec::endPlaying() { | 1448 | void QtRec::endPlaying() { |
1509 | monitoring = false; | 1449 | monitoring = false; |
1510 | recording = false; | 1450 | recording = false; |
1511 | playing = false; | 1451 | playing = false; |
1512 | stopped = true; | 1452 | stopped = true; |
1513 | waveform->reset(); | 1453 | waveform->reset(); |
1514 | // errorStop(); | 1454 | // errorStop(); |
1515 | odebug << "end playing" << oendl; | 1455 | odebug << "end playing" << oendl; |
1516 | setRecordButton( false); | 1456 | setRecordButton( false); |
1517 | 1457 | ||
1518 | toBeginningButton->setEnabled( true); | 1458 | toBeginningButton->setEnabled( true); |
1519 | toEndButton->setEnabled( true); | 1459 | toEndButton->setEnabled( true); |
1520 | 1460 | ||
1521 | if(autoMute) | 1461 | if(autoMute) |
1522 | doMute( true); | 1462 | doMute( true); |
1523 | 1463 | ||
1524 | soundDevice->closeDevice( false); | 1464 | soundDevice->closeDevice( false); |
1525 | soundDevice->sd = -1; | 1465 | soundDevice->sd = -1; |
1526 | // if(soundDevice) delete soundDevice; | 1466 | // if(soundDevice) delete soundDevice; |
1527 | odebug << "file and sound device closed" << oendl; | 1467 | odebug << "file and sound device closed" << oendl; |
1528 | // timeLabel->setText(""); | 1468 | // timeLabel->setText(""); |
1529 | total = 0; | 1469 | total = 0; |
1530 | filePara.numberSamples = 0; | 1470 | filePara.numberSamples = 0; |
1531 | filePara.sd = -1; | 1471 | filePara.sd = -1; |
1532 | // wavFile->closeFile(); | 1472 | // wavFile->closeFile(); |
1533 | filePara.fd = 0; | 1473 | filePara.fd = 0; |
1534 | // if(wavFile) delete wavFile; //this crashes | 1474 | // if(wavFile) delete wavFile; //this crashes |
1535 | 1475 | ||
1536 | odebug << "track closed" << oendl; | 1476 | odebug << "track closed" << oendl; |
1537 | killTimers(); | 1477 | killTimers(); |
1538 | owarn << "reset slider" << oendl; | 1478 | // owarn << "reset slider" << oendl; |
1539 | timeSlider->setValue(0); | 1479 | timeSlider->setValue(0); |
1540 | 1480 | ||
1541 | // if(soundDevice) delete soundDevice; | 1481 | // if(soundDevice) delete soundDevice; |
1542 | 1482 | ||
1543 | } | 1483 | } |
1544 | 1484 | ||
1545 | bool QtRec::openPlayFile() { | 1485 | bool QtRec::openPlayFile() { |
1546 | 1486 | ||
1547 | qApp->processEvents(); | 1487 | qApp->processEvents(); |
1548 | if( currentFile.isEmpty()) { | 1488 | if( currentFile.isEmpty()) { |
1549 | QMessageBox::message(tr("Opierec"),tr("Please select file to play")); | 1489 | QMessageBox::message(tr("Opierec"),tr("Please select file to play")); |
1550 | endPlaying(); | 1490 | endPlaying(); |
1551 | return false; | 1491 | return false; |
1552 | } | 1492 | } |
1553 | QString currentFileName; | 1493 | QString currentFileName; |
1554 | Config cfg("OpieRec"); | 1494 | Config cfg("OpieRec"); |
1555 | cfg.setGroup("Sounds"); | 1495 | cfg.setGroup("Sounds"); |
1556 | int nFiles = cfg.readNumEntry( "NumberofFiles", 0); | 1496 | int nFiles = cfg.readNumEntry( "NumberofFiles", 0); |
1557 | for(int i=0;i<nFiles+1;i++) { //look for file | 1497 | for(int i=0;i<nFiles+1;i++) { //look for file |
1558 | if( cfg.readEntry( QString::number(i),"").find( currentFile,0,true) != -1) { | 1498 | if( cfg.readEntry( QString::number(i),"").find( currentFile,0,true) != -1) { |
1559 | currentFileName = cfg.readEntry( currentFile, "" ); | 1499 | currentFileName = cfg.readEntry( currentFile, "" ); |
1560 | odebug << "opening for play: " + currentFileName << oendl; | 1500 | odebug << "opening for play: " + currentFileName << oendl; |
1561 | } | 1501 | } |
1562 | } | 1502 | } |
1563 | wavFile = new WavFile(this, | 1503 | wavFile = new WavFile(this, |
1564 | currentFileName, | 1504 | currentFileName, |
1565 | false); | 1505 | false); |
1566 | filePara.fd = wavFile->wavHandle(); | 1506 | filePara.fd = wavFile->wavHandle(); |
1567 | if(filePara.fd == -1) { | 1507 | if(filePara.fd == -1) { |
1568 | // if(!track.open(IO_ReadOnly)) { | 1508 | // if(!track.open(IO_ReadOnly)) { |
1569 | QString errorMsg = (QString)strerror(errno); | 1509 | QString errorMsg = (QString)strerror(errno); |
1570 | monitoring = false; | 1510 | monitoring = false; |
1571 | setCaption( tr( "OpieRecord " ) + QString::number(VERSION) ); | 1511 | setCaption( tr( "OpieRecord " )); |
1572 | QMessageBox::message(tr("Note"), tr("Could not open audio file.\n") | 1512 | QMessageBox::message(tr("Note"), tr("Could not open audio file.\n") |
1573 | + errorMsg + "\n" + currentFile); | 1513 | + errorMsg + "\n" + currentFile); |
1574 | return false; | 1514 | return false; |
1575 | } else { | 1515 | } else { |
1576 | 1516 | ||
1577 | filePara.numberSamples = wavFile->getNumberSamples(); | 1517 | filePara.numberSamples = wavFile->getNumberSamples(); |
1578 | filePara.format = wavFile->getFormat(); | 1518 | filePara.format = wavFile->getFormat(); |
1579 | filePara.sampleRate = wavFile->getSampleRate(); | 1519 | filePara.sampleRate = wavFile->getSampleRate(); |
1580 | filePara.resolution = wavFile->getResolution(); | 1520 | filePara.resolution = wavFile->getResolution(); |
1581 | filePara.channels = wavFile->getChannels(); | 1521 | filePara.channels = wavFile->getChannels(); |
1582 | timeSlider->setPageStep(1); | 1522 | timeSlider->setPageStep(1); |
1583 | monitoring = true; | 1523 | monitoring = true; |
1584 | 1524 | ||
1585 | odebug << "file " << filePara.fd << ", samples " << filePara.numberSamples << " " << filePara.sampleRate << "" << oendl; | 1525 | odebug << "file " << filePara.fd << ", samples " << filePara.numberSamples << " " << filePara.sampleRate << "" << oendl; |
1586 | int sec = (int) (( filePara.numberSamples / filePara.sampleRate) / filePara.channels) / ( filePara.channels*( filePara.resolution/8)); | 1526 | int sec = (int) (( filePara.numberSamples / filePara.sampleRate) / filePara.channels) / ( filePara.channels*( filePara.resolution/8)); |
1587 | 1527 | ||
1588 | owarn << "seconds " << sec << "" << oendl; | 1528 | // owarn << "seconds " << sec << "" << oendl; |
1589 | 1529 | ||
1590 | timeSlider->setRange(0, filePara.numberSamples ); | 1530 | timeSlider->setRange(0, filePara.numberSamples ); |
1591 | } | 1531 | } |
1592 | 1532 | ||
1593 | return true; | 1533 | return true; |
1594 | } | 1534 | } |
1595 | 1535 | ||
1596 | void QtRec::listPressed( int mouse, QListViewItem *item, const QPoint &, int ) { | 1536 | void QtRec::listPressed( int mouse, QListViewItem *item, const QPoint &, int ) { |
1597 | if(item == NULL ) | 1537 | if(item == NULL ) |
1598 | return; | 1538 | return; |
1599 | switch (mouse) { | 1539 | switch (mouse) { |
1600 | case 1: { | 1540 | case 1: { |
1601 | if( renameBox != 0 ) //tricky | 1541 | if( renameBox != 0 ) //tricky |
1602 | cancelRename(); | 1542 | cancelRename(); |
1603 | 1543 | ||
1604 | currentFile = item->text(0); | 1544 | currentFile = item->text(0); |
1605 | setCaption( "OpieRecord " + currentFile); | 1545 | // setCaption( "OpieRecord " + currentFile); |
1606 | } | 1546 | } |
1607 | break; | 1547 | break; |
1608 | case 2: | 1548 | case 2: |
1609 | showListMenu(item); | 1549 | showListMenu(item); |
1610 | ListView1->clearSelection(); | 1550 | ListView1->clearSelection(); |
1611 | break; | 1551 | break; |
1612 | }; | 1552 | }; |
1613 | } | 1553 | } |
1614 | 1554 | ||
1615 | void QtRec::showListMenu(QListViewItem * item) { | 1555 | void QtRec::showListMenu(QListViewItem * item) { |
1616 | if(item == NULL) | 1556 | if(item == NULL) |
1617 | return; | 1557 | return; |
1618 | QPopupMenu *m = new QPopupMenu(this); | 1558 | QPopupMenu *m = new QPopupMenu(this); |
1619 | m->insertItem( tr("Play"), this, SLOT( doMenuPlay() )); | 1559 | m->insertItem( tr("Play"), this, SLOT( doMenuPlay() )); |
1620 | if(Ir::supported()) m->insertItem( tr( "Send with Ir" ), this, SLOT( doBeam() )); | 1560 | if(Ir::supported()) m->insertItem( tr( "Send with Ir" ), this, SLOT( doBeam() )); |
1621 | m->insertItem( tr( "Rename" ), this, SLOT( doRename() )); | 1561 | m->insertItem( tr( "Rename" ), this, SLOT( doRename() )); |
@@ -1839,37 +1779,32 @@ void QtRec::timerEvent( QTimerEvent * ) { | |||
1839 | // timeSlider->setValue( filePara.numberOfRecordedSeconds); | 1779 | // timeSlider->setValue( filePara.numberOfRecordedSeconds); |
1840 | 1780 | ||
1841 | if( stopped && playing) { | 1781 | if( stopped && playing) { |
1842 | stop(); | 1782 | stop(); |
1843 | } | 1783 | } |
1844 | 1784 | ||
1845 | if( stopped && recording ){ | 1785 | if( stopped && recording ){ |
1846 | stop(); | 1786 | stop(); |
1847 | } | 1787 | } |
1848 | 1788 | ||
1849 | if( recording && filePara.SecondsToRecord < secCount && filePara.SecondsToRecord != 0) { | 1789 | if( recording && filePara.SecondsToRecord < secCount && filePara.SecondsToRecord != 0) { |
1850 | stop(); | 1790 | stop(); |
1851 | } | 1791 | } |
1852 | 1792 | ||
1853 | odebug << "" << secCount << "" << oendl; | 1793 | odebug << "" << secCount << "" << oendl; |
1854 | QString timeString; | 1794 | QString timeString; |
1855 | #ifdef DEV_VERSION | ||
1856 | QString msg; | ||
1857 | msg.sprintf("%d, %d, %d", filePara.sampleRate, filePara.channels, filePara.resolution); | ||
1858 | setCaption( msg +" :: "+QString::number(secCount)); | ||
1859 | #endif | ||
1860 | 1795 | ||
1861 | timeString.sprintf("%d", secCount); | 1796 | timeString.sprintf("%d", secCount); |
1862 | // timeLabel->setText( timeString + " seconds"); | 1797 | // timeLabel->setText( timeString + " seconds"); |
1863 | 1798 | ||
1864 | secCount++; | 1799 | secCount++; |
1865 | } | 1800 | } |
1866 | 1801 | ||
1867 | void QtRec::changeTimeSlider(int index) { | 1802 | void QtRec::changeTimeSlider(int index) { |
1868 | if( ListView1->currentItem() == 0 || !wavFile->track.isOpen()) return; | 1803 | if( ListView1->currentItem() == 0 || !wavFile->track.isOpen()) return; |
1869 | odebug << "Slider moved to " << index << "" << oendl; | 1804 | odebug << "Slider moved to " << index << "" << oendl; |
1870 | paused = true; | 1805 | paused = true; |
1871 | stopped = true; | 1806 | stopped = true; |
1872 | 1807 | ||
1873 | sliderPos=index; | 1808 | sliderPos=index; |
1874 | 1809 | ||
1875 | QString timeString; | 1810 | QString timeString; |
diff --git a/noncore/multimedia/opierec/waveform.cpp b/noncore/multimedia/opierec/waveform.cpp index 7c9a25f..d1838e1 100644 --- a/noncore/multimedia/opierec/waveform.cpp +++ b/noncore/multimedia/opierec/waveform.cpp | |||
@@ -31,33 +31,33 @@ Waveform::Waveform( QWidget *parent, const char *name, WFlags fl ) | |||
31 | { | 31 | { |
32 | pixmap = 0; | 32 | pixmap = 0; |
33 | windowSize = 100; | 33 | windowSize = 100; |
34 | samplesPerPixel = 8000 / (5 * windowSize); | 34 | samplesPerPixel = 8000 / (5 * windowSize); |
35 | currentValue = 0; | 35 | currentValue = 0; |
36 | numSamples = 0; | 36 | numSamples = 0; |
37 | windowPosn = 0; | 37 | windowPosn = 0; |
38 | window = 0; | 38 | window = 0; |
39 | } | 39 | } |
40 | 40 | ||
41 | 41 | ||
42 | void Waveform::changeSettings( int frequency, int channels ) | 42 | void Waveform::changeSettings( int frequency, int channels ) |
43 | { | 43 | { |
44 | makePixmap(); | 44 | makePixmap(); |
45 | // owarn << "change waveform " << frequency << ", " << channels << "" << oendl; | 45 | // owarn << "change waveform " << frequency << ", " << channels << "" << oendl; |
46 | samplesPerPixel = frequency * channels / (5 * windowSize); | 46 | samplesPerPixel = frequency * channels / (5 * windowSize); |
47 | owarn << "Waveform::changeSettings " << samplesPerPixel << "" << oendl; | 47 | // owarn << "Waveform::changeSettings " << samplesPerPixel << "" << oendl; |
48 | if ( !samplesPerPixel ) | 48 | if ( !samplesPerPixel ) |
49 | samplesPerPixel = 1; | 49 | samplesPerPixel = 1; |
50 | currentValue = 0; | 50 | currentValue = 0; |
51 | numSamples = 0; | 51 | numSamples = 0; |
52 | windowPosn = 0; | 52 | windowPosn = 0; |
53 | draw(); | 53 | draw(); |
54 | } | 54 | } |
55 | 55 | ||
56 | 56 | ||
57 | Waveform::~Waveform() | 57 | Waveform::~Waveform() |
58 | { | 58 | { |
59 | if ( window ) | 59 | if ( window ) |
60 | delete[] window; | 60 | delete[] window; |
61 | if ( pixmap ) | 61 | if ( pixmap ) |
62 | delete pixmap; | 62 | delete pixmap; |
63 | } | 63 | } |