summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opierec/device.cpp16
-rw-r--r--noncore/multimedia/opierec/opierec.pro1
-rw-r--r--noncore/multimedia/opierec/qtrec.cpp123
-rw-r--r--noncore/multimedia/opierec/wavFile.cpp62
4 files changed, 105 insertions, 97 deletions
diff --git a/noncore/multimedia/opierec/device.cpp b/noncore/multimedia/opierec/device.cpp
index e7e0f4b..a76665e 100644
--- a/noncore/multimedia/opierec/device.cpp
+++ b/noncore/multimedia/opierec/device.cpp
@@ -1,216 +1,220 @@
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> 8#include <opie2/odebug.h>
9 9
10/* STD */ 10/* STD */
11#include <fcntl.h> 11#include <fcntl.h>
12#include <stdio.h> 12#include <stdio.h>
13#include <stdlib.h> 13#include <stdlib.h>
14#include <sys/ioctl.h> 14#include <sys/ioctl.h>
15#include <sys/soundcard.h> 15#include <sys/soundcard.h>
16#include <unistd.h> 16#include <unistd.h>
17#include <sys/wait.h> 17#include <sys/wait.h>
18#include <unistd.h> 18#include <unistd.h>
19#include <errno.h> 19#include <errno.h>
20 20
21//extern QtRec *qperec; 21//extern QtRec *qperec;
22#if defined(QT_QWS_SL5XXX) 22#if defined(QT_QWS_SL5XXX)
23///#if defined(QT_QWS_EBX) 23///#if defined(QT_QWS_EBX)
24 24
25#define DSPSTROUT "/dev/dsp" 25#define DSPSTROUT "/dev/dsp"
26#define DSPSTRMIXEROUT "/dev/mixer" 26#define DSPSTRMIXEROUT "/dev/mixer"
27 27
28#ifdef SHARP 28#ifdef SHARP
29#define DSPSTRIN "/dev/dsp1" 29#define DSPSTRIN "/dev/dsp1"
30#define DSPSTRMIXERIN "/dev/mixer1" 30#define DSPSTRMIXERIN "/dev/mixer1"
31#else 31#else
32#define DSPSTRIN "/dev/dsp" 32#define DSPSTRIN "/dev/dsp"
33#define DSPSTRMIXERIN "/dev/mixer" 33#define DSPSTRMIXERIN "/dev/mixer"
34#endif 34#endif
35 35
36#else 36#else
37 37
38#ifdef QT_QWS_DEVFS 38#ifdef QT_QWS_DEVFS
39#define DSPSTROUT "/dev/sound/dsp" 39#define DSPSTROUT "/dev/sound/dsp"
40#define DSPSTRIN "/dev/sound/dsp" 40#define DSPSTRIN "/dev/sound/dsp"
41#define DSPSTRMIXERIN "/dev/sound/mixer" 41#define DSPSTRMIXERIN "/dev/sound/mixer"
42#define DSPSTRMIXEROUT "/dev/sound/mixer" 42#define DSPSTRMIXEROUT "/dev/sound/mixer"
43#else 43#else
44#define DSPSTROUT "/dev/dsp" 44#define DSPSTROUT "/dev/dsp"
45#define DSPSTRIN "/dev/dsp" 45#define DSPSTRIN "/dev/dsp"
46#define DSPSTRMIXERIN "/dev/mixer" 46#define DSPSTRMIXERIN "/dev/mixer"
47#define DSPSTRMIXEROUT "/dev/mixer" 47#define DSPSTRMIXEROUT "/dev/mixer"
48#endif 48#endif
49 49
50#endif 50#endif
51 51
52Device::Device( QObject * parent, bool record ) 52Device::Device( QObject * parent, bool record )
53 : QObject( parent) 53 : QObject( parent)
54{ 54{
55// dspstr = dsp; 55// dspstr = dsp;
56 devForm = -1; 56 devForm = -1;
57 devCh = -1; 57 devCh = -1;
58 devRate = -1; 58 devRate = -1;
59 59
60 if( !record){ //playing 60 if( !record){ //playing
61 owarn << "setting up DSP for playing" << oendl; 61 owarn << "New Sound device DSP for playing" << oendl;
62 flags = O_WRONLY; 62 flags = O_RDWR;
63// flags = O_WRONLY;
63 } else { //recording 64 } else { //recording
64 owarn << "setting up DSP for recording" << oendl; 65 owarn << "New Sound device DSP for recording" << oendl;
65 flags = O_RDWR; 66 flags = O_RDWR;
66// flags = O_RDONLY; 67// flags = O_RDONLY;
67 selectMicInput(); 68 selectMicInput();
68 } 69 }
69} 70}
70 71
71bool Device::openDsp() { 72bool Device::openDsp() {
73 qWarning("Device::openDsp()");
72 if( openDevice( flags) == -1) { 74 if( openDevice( flags) == -1) {
73 perror("<<<<<<<<<<<<<<ioctl(\"Open device\")"); 75 perror("<<<<<<<<<<<<<<ioctl(\"Open device\")");
74 return false; 76 return false;
75 } 77 }
76 return true; 78 return true;
77} 79}
78 80
79int Device::openDevice( int flags) { 81int Device::openDevice( int flags) {
80 owarn << "Opening"<< dspstr; 82 owarn << "Opening sound device:"<< DSPSTROUT << oendl;
81 83
82 if (( sd = ::open( DSPSTROUT, flags)) == -1) { 84 if (( sd = ::open( DSPSTROUT, O_RDWR)) == -1) {
83 perror("open(\"/dev/dsp\")"); 85 perror("open(\"/dev/dsp\")\n");
84 QString errorMsg="Could not open audio device\n /dev/dsp\n" 86 QString errorMsg="Could not open audio device\n /dev/dsp\n"
85 +(QString)strerror(errno); 87 +(QString)strerror(errno);
86 qDebug( "XXXXXXXXXXXXXXXXXXXXXXX "+errorMsg ); 88 qDebug( "XXXXXXXXXXXXXXXXXXXXXXX "+errorMsg );
87 return -1; 89 return -1;
88 } 90 }
89 91
90 if(ioctl(sd,SNDCTL_DSP_RESET,0)<0){ 92 if(ioctl(sd,SNDCTL_DSP_RESET,0)<0){
91 perror("ioctl RESET"); 93 perror("ioctl RESET");
92 } 94 }
95 qWarning("opened!");
93 return sd; 96 return sd;
94} 97}
95 98
96int Device::getInVolume() { 99int Device::getInVolume() {
97 unsigned int volume = 0; 100 unsigned int volume = 0;
98 Config cfg("qpe"); 101 Config cfg("qpe");
99 cfg.setGroup("Volume"); 102 cfg.setGroup("Volume");
100 103
101 return cfg.readNumEntry("Mic"); 104 return cfg.readNumEntry("Mic");
102} 105}
103 106
104int Device::getOutVolume( ) { 107int Device::getOutVolume( ) {
105 unsigned int volume; 108 unsigned int volume;
106 Config cfg("qpe"); 109 Config cfg("qpe");
107 cfg.setGroup("Volume"); 110 cfg.setGroup("Volume");
108 111
109 return cfg.readNumEntry("VolumePercent"); 112 return cfg.readNumEntry("VolumePercent");
110} 113}
111 114
112 115
113void Device::changedInVolume(int vol ) { 116void Device::changedInVolume(int vol ) {
114 Config cfg("qpe"); 117 Config cfg("qpe");
115 cfg.setGroup("Volume"); 118 cfg.setGroup("Volume");
116 cfg.writeEntry("Mic", QString::number(vol )); 119 cfg.writeEntry("Mic", QString::number(vol ));
117 QCopEnvelope( "QPE/System", "micChange(bool)" ) << false; 120 QCopEnvelope( "QPE/System", "micChange(bool)" ) << false;
118} 121}
119 122
120void Device::changedOutVolume(int vol) { 123void Device::changedOutVolume(int vol) {
121 Config cfg("qpe"); 124 Config cfg("qpe");
122 cfg.setGroup("Volume"); 125 cfg.setGroup("Volume");
123 cfg.writeEntry("VolumePercent", QString::number( vol )); 126 cfg.writeEntry("VolumePercent", QString::number( vol ));
124 127
125 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << false; 128 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << false;
126 129
127 owarn << "changing output vol " << vol << oendl; 130 owarn << "changing output vol " << vol << oendl;
128} 131}
129 132
130bool Device::selectMicInput() { 133bool Device::selectMicInput() {
131 134
132 int md = 0; 135 int md = 0;
133 int info = SOUND_MASK_MIC;//MIXER_WRITE(SOUND_MIXER_MIC); 136 int info = SOUND_MASK_MIC;//MIXER_WRITE(SOUND_MIXER_MIC);
134 owarn << "sectMicInput" << oendl; 137 owarn << "sectMicInput" << oendl;
135 md = ::open( DSPSTRMIXEROUT, O_RDWR ); 138 md = ::open( DSPSTRMIXEROUT, O_RDWR );
136 139
137 if ( md <= 0) { 140 if ( md <= 0) {
138 QString err; 141 QString err;
139 err.sprintf("open %s", DSPSTRMIXEROUT); 142 err.sprintf("open %s", DSPSTRMIXEROUT);
140 perror(err.latin1()); 143 perror(err.latin1());
141 } else { 144 } else {
142 if( ioctl( md, SOUND_MIXER_WRITE_RECSRC, &info) == -1) 145 if( ioctl( md, SOUND_MIXER_WRITE_RECSRC, &info) == -1)
143 perror("ioctl(\"SOUND_MIXER_WRITE_RECSRC\")"); 146 perror("ioctl(\"SOUND_MIXER_WRITE_RECSRC\")");
144 ::close(md); 147 ::close(md);
145 return false; 148 return false;
146 } 149 }
147 ::close(md); 150 ::close(md);
148 151
149 return true; 152 return true;
150} 153}
151 154
152bool Device::closeDevice( bool) { 155bool Device::closeDevice( bool) {
156 if(sd)
153 ::close( sd); //close sound device 157 ::close( sd); //close sound device
154 return true; 158 return true;
155} 159}
156 160
157bool Device::setDeviceFormat( int form) { 161bool Device::setDeviceFormat( int form) {
158 qDebug( "set device res %d: %d ",form, sd ); 162 qDebug( "set device res %d: %d ",form, sd );
159 if (ioctl( sd, SNDCTL_DSP_SETFMT, &form)==-1) { //set format 163 if (ioctl( sd, SNDCTL_DSP_SETFMT, &form)==-1) { //set format
160 perror("ioctl(\"SNDCTL_DSP_SETFMT\")"); 164 perror("ioctl(\"SNDCTL_DSP_SETFMT\")");
161 return false; 165 return false;
162 } 166 }
163 devRes=form; 167 devRes=form;
164 return true; 168 return true;
165} 169}
166 170
167bool Device::setDeviceChannels( int ch) { 171bool Device::setDeviceChannels( int ch) {
168 qDebug( "set channels %d: %d",ch ,sd); 172 qDebug( "set channels %d: %d",ch ,sd);
169 if (ioctl( sd, SNDCTL_DSP_CHANNELS, &ch)==-1) { 173 if (ioctl( sd, SNDCTL_DSP_CHANNELS, &ch)==-1) {
170 perror("ioctl(\"SNDCTL_DSP_CHANNELS\")"); 174 perror("ioctl(\"SNDCTL_DSP_CHANNELS\")");
171 return false; 175 return false;
172 } 176 }
173 devCh=ch; 177 devCh=ch;
174 return true; 178 return true;
175} 179}
176 180
177bool Device::setDeviceRate( int rate) { 181bool Device::setDeviceRate( int rate) {
178 qDebug( "set rate %d: %d",rate,sd); 182 qDebug( "set rate %d: %d",rate,sd);
179 if (ioctl( sd, SNDCTL_DSP_SPEED, &rate) == -1) { 183 if (ioctl( sd, SNDCTL_DSP_SPEED, &rate) == -1) {
180 perror("ioctl(\"SNDCTL_DSP_SPEED\")"); 184 perror("ioctl(\"SNDCTL_DSP_SPEED\")");
181 return false; 185 return false;
182 } 186 }
183 187
184 devRate=rate; 188 devRate=rate;
185 189
186 return true; 190 return true;
187} 191}
188 192
189int Device::getRes() { 193int Device::getRes() {
190 return devRes; 194 return devRes;
191} 195}
192 196
193int Device::getFormat() { 197int Device::getFormat() {
194 return devForm; 198 return devForm;
195} 199}
196 200
197int Device::getRate() { 201int Device::getRate() {
198 return devRate; 202 return devRate;
199} 203}
200 204
201int Device::getChannels() { 205int Device::getChannels() {
202 return devCh; 206 return devCh;
203} 207}
204 208
205int Device::getDeviceFormat() { 209int Device::getDeviceFormat() {
206 return 0; 210 return 0;
207} 211}
208 212
209 213
210int Device::getDeviceRate() { 214int Device::getDeviceRate() {
211 int dRate = 0; 215 int dRate = 0;
212 if (ioctl( sd, SOUND_PCM_READ_RATE, &dRate) == -1) { 216 if (ioctl( sd, SOUND_PCM_READ_RATE, &dRate) == -1) {
213 perror("ioctl(\"SNDCTL_PCM_READ_RATE\")"); 217 perror("ioctl(\"SNDCTL_PCM_READ_RATE\")");
214 } 218 }
215 return dRate; 219 return dRate;
216 220
diff --git a/noncore/multimedia/opierec/opierec.pro b/noncore/multimedia/opierec/opierec.pro
index 6a5838a..6008bf7 100644
--- a/noncore/multimedia/opierec/opierec.pro
+++ b/noncore/multimedia/opierec/opierec.pro
@@ -1,38 +1,39 @@
1CONFIG = qt quick-app 1CONFIG = qt quick-app
2HEADERS = adpcm.h \ 2HEADERS = adpcm.h \
3 pixmaps.h \ 3 pixmaps.h \
4 helpwindow.h \ 4 helpwindow.h \
5 qtrec.h \ 5 qtrec.h \
6 device.h \ 6 device.h \
7 wavFile.h \ 7 wavFile.h \
8 waveform.h 8 waveform.h
9SOURCES = adpcm.c \ 9SOURCES = adpcm.c \
10 helpwindow.cpp \ 10 helpwindow.cpp \
11 main.cpp \ 11 main.cpp \
12 qtrec.cpp \ 12 qtrec.cpp \
13 device.cpp \ 13 device.cpp \
14 wavFile.cpp \ 14 wavFile.cpp \
15 waveform.cpp 15 waveform.cpp
16INTERFACES = 16INTERFACES =
17 17
18contains(CONFIG, pdaudio) { 18contains(CONFIG, pdaudio) {
19# LIBS += -L/opt/buildroot-opie/output/staging/target/lib -lqpe -lpthread -ljpeg -lpng -lz 19# LIBS += -L/opt/buildroot-opie/output/staging/target/lib -lqpe -lpthread -ljpeg -lpng -lz
20 LIBS += -L$(QPEDIR)/lib -lqpe -lpthread -ljpeg -lpng -lz -lopiecore2 20 LIBS += -L$(QPEDIR)/lib -lqpe -lpthread -ljpeg -lpng -lz -lopiecore2
21 INCLUDEPATH += $(QPEDIR)/include 21 INCLUDEPATH += $(QPEDIR)/include
22 DEPENDPATH += $(QPEDIR)/include 22 DEPENDPATH += $(QPEDIR)/include
23 DEFINES += PDAUDIO 23 DEFINES += PDAUDIO
24 DEFINES += THREADED 24 DEFINES += THREADED
25 TARGET = qperec 25 TARGET = qperec
26 26
27# DESTDIR=$(QPEDIR)/bin 27# DESTDIR=$(QPEDIR)/bin
28} 28}
29 29
30!contains(CONFIG, pdaudio) { 30!contains(CONFIG, pdaudio) {
31 INCLUDEPATH += $(OPIEDIR)/include 31 INCLUDEPATH += $(OPIEDIR)/include
32 DEPENDPATH += $(OPIEDIR)/include 32 DEPENDPATH += $(OPIEDIR)/include
33 LIBS += -lqpe -lopiecore2 -lpthread 33 LIBS += -lqpe -lopiecore2 -lpthread
34 DEFINES += THREADED
34 TARGET = opierec 35 TARGET = opierec
35 include( $(OPIEDIR)/include.pro ) 36 include( $(OPIEDIR)/include.pro )
36} 37}
37 38
38 39
diff --git a/noncore/multimedia/opierec/qtrec.cpp b/noncore/multimedia/opierec/qtrec.cpp
index e827083..9b761aa 100644
--- a/noncore/multimedia/opierec/qtrec.cpp
+++ b/noncore/multimedia/opierec/qtrec.cpp
@@ -56,444 +56,446 @@ using namespace Opie::Core;
56 56
57#ifdef PDAUDIO //ALSA 57#ifdef PDAUDIO //ALSA
58#include <alsa/asoundlib.h> 58#include <alsa/asoundlib.h>
59static int deviceSampleRates[8] = { 32000, 44100, 48000, 88200, 96000, 176400, 192000, -1 }; 59static int deviceSampleRates[8] = { 32000, 44100, 48000, 88200, 96000, 176400, 192000, -1 };
60static int deviceBitRates[] = { 8, 16, 24, 32, -1 }; 60static int deviceBitRates[] = { 8, 16, 24, 32, -1 };
61#else //OSS 61#else //OSS
62static int deviceSampleRates[6] = { 11025, 16000, 22050, 32000, 44100, -1 }; 62static int deviceSampleRates[6] = { 11025, 16000, 22050, 32000, 44100, -1 };
63static int deviceBitRates[] = { 8, 16, -1 }; 63static int deviceBitRates[] = { 8, 16, -1 };
64#endif 64#endif
65 65
66 66
67//#define ZAURUS 0 67//#define ZAURUS 0
68struct adpcm_state encoder_state; 68struct adpcm_state encoder_state;
69struct adpcm_state decoder_state; 69struct adpcm_state decoder_state;
70 70
71typedef struct { 71typedef struct {
72 int sampleRate; 72 int sampleRate;
73 /* int fragSize; */ 73 /* int fragSize; */
74 /* int blockSize; */ 74 /* int blockSize; */
75 int resolution; //bitrate 75 int resolution; //bitrate
76 int channels; //number of channels 76 int channels; //number of channels
77 int fd; //file descriptor 77 int fd; //file descriptor
78 int sd; //sound device descriptor 78 int sd; //sound device descriptor
79 int numberSamples; //total number of samples 79 int numberSamples; //total number of samples
80 int SecondsToRecord; // number of seconds that should be recorded 80 int SecondsToRecord; // number of seconds that should be recorded
81 float numberOfRecordedSeconds; //total number of samples recorded 81 float numberOfRecordedSeconds; //total number of samples recorded
82 int samplesToRecord; //number of samples to be recorded 82 int samplesToRecord; //number of samples to be recorded
83 int inVol; //input volume 83 int inVol; //input volume
84 int outVol; //output volume 84 int outVol; //output volume
85 int format; //wavfile format PCM.. ADPCM 85 int format; //wavfile format PCM.. ADPCM
86 const char *fileName; //name of fiel to be played/recorded 86 const char *fileName; //name of fiel to be played/recorded
87} fileParameters; 87} fileParameters;
88 88
89fileParameters filePara; 89fileParameters filePara;
90 90
91bool monitoring, recording, playing; 91bool monitoring, recording, playing;
92bool stopped; 92bool stopped;
93QLabel *timeLabel; 93QLabel *timeLabel;
94QSlider *timeSlider; 94QSlider *timeSlider;
95int sd; 95int sd;
96 96
97Waveform* waveform; 97Waveform* waveform;
98Device *soundDevice; 98Device *soundDevice;
99 99
100 100
101#ifdef THREADED 101#ifdef THREADED
102void quickRec() 102void quickRec()
103#else 103#else
104 void QtRec::quickRec() 104 void QtRec::quickRec()
105#endif 105#endif
106{ 106{
107 107
108 odebug << ( filePara.numberSamples/filePara.sampleRate * filePara.channels ) << oendl; 108 odebug << ( filePara.numberSamples/filePara.sampleRate * filePara.channels ) << oendl;
109 odebug << "samples " << filePara.numberSamples << ", rate " << filePara.sampleRate 109 odebug << "samples " << filePara.numberSamples << ", rate " << filePara.sampleRate
110 << ", channels " << filePara.channels << oendl; 110 << ", channels " << filePara.channels << oendl;
111 111
112 int total = 0; // Total number of bytes read in so far. 112 int total = 0; // Total number of bytes read in so far.
113 int bytesWritten, number; 113 int bytesWritten, number;
114 114
115 bytesWritten = 0; 115 bytesWritten = 0;
116 number = 0; 116 number = 0;
117 QString num; 117 QString num;
118 int level = 0; 118 int level = 0;
119 int threshold = 0; 119 int threshold = 0;
120 int bits = filePara.resolution; 120 int bits = filePara.resolution;
121 odebug << "bits " << bits << "" << oendl; 121 odebug << "bits " << bits << "" << oendl;
122 122
123 if( filePara.resolution == 16 ) { //AFMT_S16_LE) 123 if( filePara.resolution == 16 ) { //AFMT_S16_LE)
124 odebug << "AFMT_S16_LE size " << filePara.SecondsToRecord << "" << oendl; 124 odebug << "AFMT_S16_LE size " << filePara.SecondsToRecord << "" << oendl;
125 odebug << "samples to record " << filePara.samplesToRecord << "" << oendl; 125 odebug << "samples to record " << filePara.samplesToRecord << "" << oendl;
126 odebug << "" << filePara.sd << "" << oendl; 126 odebug << "" << filePara.sd << "" << oendl;
127 level = 7; 127 level = 7;
128 threshold = 0; 128 threshold = 0;
129 129
130 if( filePara.format == WAVE_FORMAT_DVI_ADPCM) { 130 if( filePara.format == WAVE_FORMAT_DVI_ADPCM) {
131 odebug << "start recording WAVE_FORMAT_DVI_ADPCM" << oendl; 131 odebug << "start recording WAVE_FORMAT_DVI_ADPCM" << oendl;
132// <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_DVI_ADPCM >>>>>>>>>>>>>>>>>>>>>> 132// <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_DVI_ADPCM >>>>>>>>>>>>>>>>>>>>>>
133 char abuf[ BUFSIZE/2 ]; 133 char abuf[ BUFSIZE/2 ];
134 short sbuf[ BUFSIZE ]; 134 short sbuf[ BUFSIZE ];
135 short sbuf2[ BUFSIZE ]; 135 short sbuf2[ BUFSIZE ];
136 memset( abuf, 0, BUFSIZE/2); 136 memset( abuf, 0, BUFSIZE/2);
137 memset( sbuf, 0, BUFSIZE); 137 memset( sbuf, 0, BUFSIZE);
138 memset( sbuf2, 0, BUFSIZE); 138 memset( sbuf2, 0, BUFSIZE);
139 139
140 for(;;) { 140 for(;;) {
141 if ( stopped) { 141 if ( stopped) {
142 odebug << "quickRec:: stopped" << oendl; 142 odebug << "quickRec:: stopped" << oendl;
143 break; 143 break;
144 } 144 }
145 145
146// number=::read( filePara.sd, sbuf, BUFSIZE); 146// number=::read( filePara.sd, sbuf, BUFSIZE);
147 number = soundDevice->devRead( filePara.sd, sbuf, BUFSIZE); 147 number = soundDevice->devRead( filePara.sd, sbuf, BUFSIZE);
148 148
149 if(number <= 0) { 149 if(number <= 0) {
150 perror("recording error "); 150 perror("recording error ");
151 odebug << "" << filePara.fileName << " " << number << "" << oendl; 151 odebug << "" << filePara.fileName << " " << number << "" << oendl;
152 stopped = true; 152 stopped = true;
153 return; 153 return;
154 } 154 }
155 //if(stereo == 2) { 155 //if(stereo == 2) {
156// adpcm_coder( sbuf2, abuf, number/2, &encoder_state); 156// adpcm_coder( sbuf2, abuf, number/2, &encoder_state);
157 adpcm_coder( sbuf, abuf, number/2, &encoder_state); 157 adpcm_coder( sbuf, abuf, number/2, &encoder_state);
158 158
159 bytesWritten = ::write( filePara.fd , (short *)abuf, number/4); 159 bytesWritten = ::write( filePara.fd , abuf, number/4);
160 160
161 waveform->newSamples( sbuf, number ); 161 waveform->newSamples( sbuf, number );
162 162
163 total += bytesWritten; 163 total += bytesWritten;
164 filePara.numberSamples = total; 164 filePara.numberSamples = total;
165 timeSlider->setValue( total); 165 timeSlider->setValue( total);
166 166
167 printf("%d, bytes %d,total %d\r", number, bytesWritten, total); 167 printf("%d, bytes %d,total %d\r", number, bytesWritten, total);
168 fflush(stdout); 168 fflush(stdout);
169 169
170 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate * (float)2/ filePara.channels; 170 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate * (float)2;/// filePara.channels;
171 171
172 qApp->processEvents(); 172 qApp->processEvents();
173 if( total >= filePara.samplesToRecord) { 173 if( total >= filePara.samplesToRecord) {
174 stopped = true; 174 stopped = true;
175 break; 175 break;
176 } 176 }
177 } 177 }
178 } else { 178 } else {
179 // <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_PCM >>>>>>>>>>>>>>>>>>>>>> 179 // <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_PCM >>>>>>>>>>>>>>>>>>>>>>
180 odebug << "start recording WAVE_FORMAT_PCM" << oendl; 180 odebug << "start recording WAVE_FORMAT_PCM" << oendl;
181 short inbuffer[ BUFSIZE ], outbuffer[ BUFSIZE ]; 181 short inbuffer[ BUFSIZE ], outbuffer[ BUFSIZE ];
182 memset( inbuffer, 0, BUFSIZE); 182 memset( inbuffer, 0, BUFSIZE);
183 memset( outbuffer, 0, BUFSIZE); 183 memset( outbuffer, 0, BUFSIZE);
184 184
185 for(;;) { 185 for(;;) {
186 if ( stopped) { 186 if ( stopped) {
187 odebug << "quickRec:: stopped" << oendl; 187 odebug << "quickRec:: stopped" << oendl;
188 stopped = true; 188 stopped = true;
189 break; // stop if playing was set to false 189 break; // stop if playing was set to false
190 return; 190 return;
191 } 191 }
192 192
193 number = soundDevice->devRead( soundDevice->sd /*filePara.sd*/, (short *)inbuffer, BUFSIZE); 193 number = soundDevice->devRead( soundDevice->sd /*filePara.sd*/, (short *)inbuffer, BUFSIZE);
194 194
195 if( number <= 0) { 195 if( number <= 0) {
196 perror( "recording error "); 196 perror( "recording error ");
197 odebug << filePara.fileName << oendl; 197 odebug << filePara.fileName << oendl;
198 stopped = true; 198 stopped = true;
199 return; 199 return;
200 } 200 }
201 201
202 bytesWritten = ::write( filePara.fd , inbuffer, number); 202 bytesWritten = ::write( filePara.fd , inbuffer, number);
203 waveform->newSamples( inbuffer, number ); 203 waveform->newSamples( inbuffer, number );
204 204
205 if( bytesWritten < 0) { 205 if( bytesWritten < 0) {
206 perror("File writing error "); 206 perror("File writing error ");
207 stopped = true; 207 stopped = true;
208 return; 208 return;
209 } 209 }
210 210
211 total += bytesWritten; 211 total += bytesWritten;
212 212
213 filePara.numberSamples = total; 213 filePara.numberSamples = total;
214 214
215 if( filePara.SecondsToRecord != 0) 215 if( filePara.SecondsToRecord != 0)
216 timeSlider->setValue( total); 216 timeSlider->setValue( total);
217 printf("%d, bytes %d,total %d\r",number, bytesWritten , total); 217 printf("%d, bytes %d,total %d\r",number, bytesWritten , total);
218 fflush(stdout); 218 fflush(stdout);
219 219
220 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate 220 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate
221 / (float)2/filePara.channels; 221 / (float)2/filePara.channels;
222 qApp->processEvents(); 222 qApp->processEvents();
223 223
224 if( total >= filePara.samplesToRecord) { 224 if( total >= filePara.samplesToRecord) {
225 stopped = true; 225 stopped = true;
226 break; 226 break;
227 } 227 }
228 } 228 }
229 } //end main loop 229 } //end main loop
230 230
231 } else { 231 } else {
232// <<<<<<<<<<<<<<<<<<<<<<< format = AFMT_U8; 232// <<<<<<<<<<<<<<<<<<<<<<< format = AFMT_U8;
233 unsigned char unsigned_inbuffer[ BUFSIZE ], unsigned_outbuffer[ BUFSIZE ]; 233 unsigned char unsigned_inbuffer[ BUFSIZE ], unsigned_outbuffer[ BUFSIZE ];
234 memset( unsigned_inbuffer, 0, BUFSIZE); 234 memset( unsigned_inbuffer, 0, BUFSIZE);
235 memset( unsigned_outbuffer, 0, BUFSIZE); 235 memset( unsigned_outbuffer, 0, BUFSIZE);
236 236
237 for(;;) { 237 for(;;) {
238 if ( stopped) { 238 if ( stopped) {
239 odebug << "quickRec:: stopped" << oendl; 239 odebug << "quickRec:: stopped" << oendl;
240 break; // stop if playing was set to false 240 break; // stop if playing was set to false
241 } 241 }
242 242
243 number = ::read( soundDevice->sd /*filePara.sd*/ , unsigned_inbuffer, BUFSIZE); 243 number = ::read( soundDevice->sd /*filePara.sd*/ , unsigned_inbuffer, BUFSIZE);
244 bytesWritten = ::write( filePara.fd , unsigned_inbuffer, number); 244 bytesWritten = ::write( filePara.fd , unsigned_inbuffer, number);
245 waveform->newSamples( (const short *) unsigned_inbuffer, number ); 245 waveform->newSamples( (const short *) unsigned_inbuffer, number );
246 246
247 if(bytesWritten < 0) { 247 if(bytesWritten < 0) {
248 stopped = true; 248 stopped = true;
249 QMessageBox::message("Note","<p>There was a problem writing to the file</p>"); 249 QMessageBox::message("Note","<p>There was a problem writing to the file</p>");
250 perror("File writing error "); 250 perror("File writing error ");
251 return; 251 return;
252 } 252 }
253 253
254 total += bytesWritten; 254 total += bytesWritten;
255 filePara.numberSamples = total; 255 filePara.numberSamples = total;
256 // printf("%d, bytes %d,total %d \r",number, bytesWritten , total); 256 // printf("%d, bytes %d,total %d \r",number, bytesWritten , total);
257 // fflush(stdout); 257 // fflush(stdout);
258 if( filePara.SecondsToRecord !=0) 258 if( filePara.SecondsToRecord !=0)
259 timeSlider->setValue( total); 259 timeSlider->setValue( total);
260 260
261 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate; 261 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate;
262 262
263 qApp->processEvents(); 263 qApp->processEvents();
264 if( total >= filePara.samplesToRecord) { 264 if( total >= filePara.samplesToRecord) {
265 stopped = true; 265 stopped = true;
266 break; 266 break;
267 } 267 }
268 } //end main loop 268 } //end main loop
269 } 269 }
270 printf("\n"); 270 printf("\n");
271} /// END quickRec() 271} /// END quickRec()
272 272
273 273
274#ifdef THREADED 274#ifdef THREADED
275void playIt() 275void playIt()
276#else 276#else
277 void QtRec::playIt() 277 void QtRec::playIt()
278#endif 278#endif
279{ 279{
280 int bytesWritten = 0; 280 int bytesWritten = 0;
281 int number = 0; 281 int number = 0;
282 int total = 0; // Total number of bytes read in so far. 282 int total = 0; // Total number of bytes read in so far.
283 if( filePara.resolution == 16 ) { //AFMT_S16_LE) { 283 if( filePara.resolution == 16 ) { //AFMT_S16_LE) {
284 if( filePara.format == WAVE_FORMAT_DVI_ADPCM) { 284 if( filePara.format == WAVE_FORMAT_DVI_ADPCM) {
285 char abuf[ BUFSIZE / 2 ]; 285 char abuf[ BUFSIZE / 2 ];
286 short sbuf[ BUFSIZE ]; 286 short sbuf[ BUFSIZE ];
287 short sbuf2[ BUFSIZE * 2 ]; 287 short sbuf2[ BUFSIZE * 2 ];
288 memset( abuf, 0, BUFSIZE / 2); 288 memset( abuf, 0, BUFSIZE / 2);
289 memset( sbuf, 0, BUFSIZE); 289 memset( sbuf, 0, BUFSIZE);
290 memset( sbuf2, 0, BUFSIZE * 2); 290 memset( sbuf2, 0, BUFSIZE * 2);
291// <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_DVI_ADPCM >>>>>>>>>>>>>>>>>>>>>> 291// <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_DVI_ADPCM >>>>>>>>>>>>>>>>>>>>>>
292 for(;;) { // play loop 292 for(;;) { // play loop
293 if ( stopped) { 293 if ( stopped) {
294 break; 294 break;
295 return; 295 return;
296 }// stop if playing was set to false 296 }// stop if playing was set to false
297 297
298 number = ::read( filePara.fd, abuf, BUFSIZE / 2); 298 number = ::read( filePara.fd, abuf, BUFSIZE / 2);
299 adpcm_decoder( abuf, sbuf, number * 2, &decoder_state); 299 adpcm_decoder( abuf, sbuf, number * 2, &decoder_state);
300 300
301// for (int i=0;i< number * 2; 2 * i++) { //2*i is left channel 301// for (int i=0;i< number * 2; 2 * i++) { //2*i is left channel
302// sbuf2[i+1]=sbuf2[i]=sbuf[i]; 302// sbuf2[i+1]=sbuf2[i]=sbuf[i];
303// } 303// }
304 bytesWritten = write ( filePara.sd, sbuf, number * 4); 304 bytesWritten = write ( soundDevice->sd , sbuf, number * 4);
305 waveform->newSamples( (const short *)sbuf, number *4); 305
306 waveform->newSamples( sbuf, number );
307
306 // if(filePara.channels==1) 308 // if(filePara.channels==1)
307 // total += bytesWritten/2; //mono 309 // total += bytesWritten/2; //mono
308 // else 310 // else
309 total += bytesWritten; 311 total += bytesWritten;
310 filePara.numberSamples = total/4; 312 filePara.numberSamples = total/4;
311 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate / 2; 313 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate / 2;
312 314
313 timeSlider->setValue( total/4); 315 timeSlider->setValue( total/4);
314// timeString.sprintf("%.2f", filePara.numberOfRecordedSeconds); 316// timeString.sprintf("%.2f", filePara.numberOfRecordedSeconds);
315// if(filePara.numberOfRecordedSeconds>1) 317// if(filePara.numberOfRecordedSeconds>1)
316// timeLabel->setText( timeString+ tr(" seconds")); 318// timeLabel->setText( timeString+ tr(" seconds"));
317// printf("playing number %d, bytes %d, total %d\n",number, bytesWritten, total/4); 319// printf("playing number %d, bytes %d, total %d\n",number, bytesWritten, total/4);
318// fflush(stdout); 320// fflush(stdout);
319 321
320 qApp->processEvents(); 322 qApp->processEvents();
321 323
322 if( /*total >= filePara.numberSamples || */ bytesWritten == 0) { 324 if( /*total >= filePara.numberSamples || */ bytesWritten == 0) {
323// if( total >= filePara.numberSamples ){//|| secCount > filePara.numberOfRecordedSeconds ) { 325// if( total >= filePara.numberSamples ){//|| secCount > filePara.numberOfRecordedSeconds ) {
324 stopped = true; 326 stopped = true;
325 break; 327 break;
326 } 328 }
327 } 329 }
328 } else { 330 } else {
329 // <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_PCM >>>>>>>>>>>>>>>>>>>>>> 331 // <<<<<<<<<<<<<<<<<<<<<<<<<<< WAVE_FORMAT_PCM >>>>>>>>>>>>>>>>>>>>>>
330 short inbuffer[ BUFSIZE ], outbuffer[ BUFSIZE ]; 332 short inbuffer[ BUFSIZE ], outbuffer[ BUFSIZE ];
331 memset( inbuffer, 0, BUFSIZE); 333 memset( inbuffer, 0, BUFSIZE);
332 memset( outbuffer, 0, BUFSIZE); 334 memset( outbuffer, 0, BUFSIZE);
333 335
334 for(;;) { // play loop 336 for(;;) { // play loop
335 if ( stopped) { 337 if ( stopped) {
336 break; 338 break;
337 return; 339 return;
338 } 340 }
339// stop if playing was set to false 341// stop if playing was set to false
340 number = ::read( filePara.fd, inbuffer, BUFSIZE); 342 number = ::read( filePara.fd, inbuffer, BUFSIZE);
341// for (int i=0;i< number * 2; 2 * i++) { //2*i is left channel 343// for (int i=0;i< number * 2; 2 * i++) { //2*i is left channel
342// // for (int i=0;i< number ; i++) { //2*i is left channel 344// // for (int i=0;i< number ; i++) { //2*i is left channel
343// outbuffer[i+1]= outbuffer[i]=inbuffer[i]; 345// outbuffer[i+1]= outbuffer[i]=inbuffer[i];
344// } 346// }
345 bytesWritten = ::write( filePara.sd, inbuffer, number); 347 bytesWritten = ::write( soundDevice->sd, inbuffer, number);
346 waveform->newSamples( inbuffer, number); 348 waveform->newSamples( inbuffer, number);
347 //-------------->>>> out to device 349 //-------------->>>> out to device
348 // total+=bytesWritten; 350 // total+=bytesWritten;
349 // if(filePara.channels==1) 351 // if(filePara.channels==1)
350 // total += bytesWritten/2; //mono 352 // total += bytesWritten/2; //mono
351 // else 353 // else
352 total += bytesWritten; 354 total += bytesWritten;
353 timeSlider->setValue( total); 355 timeSlider->setValue( total);
354 356
355 filePara.numberSamples = total; 357 filePara.numberSamples = total;
356 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate / (float)2; 358 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate / (float)2;
357 359
358// timeString.sprintf("%.2f",filePara.numberOfRecordedSeconds); 360// timeString.sprintf("%.2f",filePara.numberOfRecordedSeconds);
359// timeLabel->setText( timeString + tr(" seconds")); 361// timeLabel->setText( timeString + tr(" seconds"));
360 362
361 qApp->processEvents(); 363 qApp->processEvents();
362 364
363 if( /*total >= filePara.numberSamples || */ bytesWritten == 0) { 365 if( /*total >= filePara.numberSamples || */ bytesWritten == 0) {
364 owarn << "Jane! Stop this crazy thing!" << oendl; 366 owarn << "Jane! Stop this crazy thing!" << oendl;
365 stopped = true; 367 stopped = true;
366// playing = false; 368// playing = false;
367 break; 369 break;
368 } 370 }
369 } 371 }
370// printf("\nplaying number %d, bytes %d, total %d\r",number, bytesWritten, total); 372// printf("\nplaying number %d, bytes %d, total %d\r",number, bytesWritten, total);
371// fflush(stdout); 373// fflush(stdout);
372 } //end loop 374 } //end loop
373 } else { 375 } else {
374/////////////////////////////// format = AFMT_U8; 376/////////////////////////////// format = AFMT_U8;
375 unsigned char unsigned_inbuffer[ BUFSIZE ]; //, unsigned_outbuffer[BUFSIZE]; 377 unsigned char unsigned_inbuffer[ BUFSIZE ]; //, unsigned_outbuffer[BUFSIZE];
376 memset( unsigned_inbuffer, 0, BUFSIZE); 378 memset( unsigned_inbuffer, 0, BUFSIZE);
377 for(;;) { 379 for(;;) {
378// main loop 380// main loop
379 if (stopped) { 381 if (stopped) {
380 break; // stop if playing was set to false 382 break; // stop if playing was set to false
381 return; 383 return;
382 } 384 }
383 number = ::read( filePara.fd, unsigned_inbuffer, BUFSIZE); 385 number = ::read( filePara.fd, unsigned_inbuffer, BUFSIZE);
384//data = (val >> 8) ^ 0x80; 386//data = (val >> 8) ^ 0x80;
385 // unsigned_outbuffer = (unsigned_inbuffer >> 8) ^ 0x80; 387 // unsigned_outbuffer = (unsigned_inbuffer >> 8) ^ 0x80;
386 bytesWritten = write ( filePara.sd, unsigned_inbuffer, number); 388 bytesWritten = write ( filePara.sd, unsigned_inbuffer, number);
387 waveform->newSamples( (const short *)unsigned_inbuffer, bytesWritten ); 389 waveform->newSamples( (const short *)unsigned_inbuffer, bytesWritten );
388 total += bytesWritten; 390 total += bytesWritten;
389 391
390 timeSlider->setValue( total); 392 timeSlider->setValue( total);
391 filePara.numberSamples = total; 393 filePara.numberSamples = total;
392 394
393 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate; 395 filePara.numberOfRecordedSeconds = (float)total / (float)filePara.sampleRate;
394// timeString.sprintf("%.2f",filePara.numberOfRecordedSeconds); 396// timeString.sprintf("%.2f",filePara.numberOfRecordedSeconds);
395// timeLabel->setText( timeString + tr(" seconds")); 397// timeLabel->setText( timeString + tr(" seconds"));
396 qApp->processEvents(); 398 qApp->processEvents();
397 399
398 if( /*total >= filePara.numberSamples || */ bytesWritten == 0) { 400 if( /*total >= filePara.numberSamples || */ bytesWritten == 0) {
399// if( total >= filePara.numberSamples ) { 401// if( total >= filePara.numberSamples ) {
400 stopped = true; 402 stopped = true;
401 break; 403 break;
402 } 404 }
403// printf("Writing number %d, bytes %d, total %d, numberSamples %d\r",number, bytesWritten , total, filePara.numberSamples); 405// printf("Writing number %d, bytes %d, total %d, numberSamples %d\r",number, bytesWritten , total, filePara.numberSamples);
404// fflush(stdout); 406// fflush(stdout);
405 } 407 }
406 } 408 }
407} 409}
408 410
409 411
410QtRec::QtRec( QWidget* parent, const char* name, WFlags fl ) 412QtRec::QtRec( QWidget* parent, const char* name, WFlags fl )
411 : QWidget( parent, name, fl ) 413 : QWidget( parent, name, fl )
412{ 414{
413 if ( !name ) 415 if ( !name )
414 setName( "OpieRec" ); 416 setName( "OpieRec" );
415 init(); 417 init();
416 initConfig(); 418 initConfig();
417 initConnections(); 419 initConnections();
418 renameBox = 0; 420 renameBox = 0;
419 421
420// open sound device to get volumes 422// open sound device to get volumes
421 Config hwcfg("OpieRec"); 423 Config hwcfg("OpieRec");
422 hwcfg.setGroup("Hardware"); 424 hwcfg.setGroup("Hardware");
423 425
424 426
425 soundDevice = new Device( this, false); //open play 427 soundDevice = new Device( this, false); //open play
426 428
427 getInVol(); 429 getInVol();
428 getOutVol(); 430 getOutVol();
429 431
430 soundDevice->closeDevice( true); 432 soundDevice->closeDevice( true);
431 soundDevice->sd = -1; 433 soundDevice->sd = -1;
432 soundDevice = 0; 434 soundDevice = 0;
433 wavFile = 0; 435 wavFile = 0;
434// if( soundDevice) delete soundDevice; 436// if( soundDevice) delete soundDevice;
435 QTimer::singleShot(100,this, SLOT(initIconView())); 437 QTimer::singleShot(100,this, SLOT(initIconView()));
436 438
437 if( autoMute) 439 if( autoMute)
438 doMute( true); 440 doMute( true);
439 // ListView1->setFocus(); 441 // ListView1->setFocus();
440 playing = false; 442 playing = false;
441} 443}
442 444
443QtRec::~QtRec() { 445QtRec::~QtRec() {
444// if( soundDevice) delete soundDevice; 446// if( soundDevice) delete soundDevice;
445 447
446} 448}
447 449
448void QtRec::cleanUp() { 450void QtRec::cleanUp() {
449 451
450 if( !stopped) { 452 if( !stopped) {
451 stopped = true; 453 stopped = true;
452 endRecording(); 454 endRecording();
453 } 455 }
454 456
455 ListView1->clear(); 457 ListView1->clear();
456 458
457 if( autoMute) 459 if( autoMute)
458 doMute(false); 460 doMute(false);
459 461
460// if( wavFile) delete wavFile; 462// if( wavFile) delete wavFile;
461// if(soundDevice) delete soundDevice; 463// if(soundDevice) delete soundDevice;
462} 464}
463 465
464void QtRec::init() { 466void QtRec::init() {
465 467
466 needsStereoOut = false; 468 needsStereoOut = false;
467 QPixmap image3( ( const char** ) image3_data ); 469 QPixmap image3( ( const char** ) image3_data );
468 QPixmap image4( ( const char** ) image4_data ); 470 QPixmap image4( ( const char** ) image4_data );
469 QPixmap image6( ( const char** ) image6_data ); 471 QPixmap image6( ( const char** ) image6_data );
470 472
471 stopped = true; 473 stopped = true;
472 setCaption( tr( "OpieRecord " )); 474 setCaption( tr( "OpieRecord " ));
473 QGridLayout *layout = new QGridLayout( this ); 475 QGridLayout *layout = new QGridLayout( this );
474 layout->setSpacing( 2); 476 layout->setSpacing( 2);
475 layout->setMargin( 2); 477 layout->setMargin( 2);
476 478
477 TabWidget = new QTabWidget( this, "TabWidget" ); 479 TabWidget = new QTabWidget( this, "TabWidget" );
478 layout->addMultiCellWidget(TabWidget, 0, 7, 0, 8); 480 layout->addMultiCellWidget(TabWidget, 0, 7, 0, 8);
479// TabWidget->setTabShape(QTabWidget::Triangular); 481// TabWidget->setTabShape(QTabWidget::Triangular);
480 482
481 ///**********<<<<<<<<<<<<>>>>>>>>>>>>*************** 483 ///**********<<<<<<<<<<<<>>>>>>>>>>>>***************
482 tab = new QWidget( TabWidget, "tab" ); 484 tab = new QWidget( TabWidget, "tab" );
483 485
484 QGridLayout *layout1 = new QGridLayout( tab); 486 QGridLayout *layout1 = new QGridLayout( tab);
485 layout1->setSpacing( 2); 487 layout1->setSpacing( 2);
486 layout1->setMargin( 2); 488 layout1->setMargin( 2);
487 489
488 timeSlider = new QSlider( 0,100,10,0, QSlider::Horizontal, tab, (const char *) "timeSlider" ); 490 timeSlider = new QSlider( 0,100,10,0, QSlider::Horizontal, tab, (const char *) "timeSlider" );
489 layout1->addMultiCellWidget( timeSlider, 1, 1, 0, 3); 491 layout1->addMultiCellWidget( timeSlider, 1, 1, 0, 3);
490 492
491 // timeLabel = new QLabel( tab, "TimeLabel" ); 493 // timeLabel = new QLabel( tab, "TimeLabel" );
492 // layout1->addMultiCellWidget( timeLabel, 0, 0, 0, 3); 494 // layout1->addMultiCellWidget( timeLabel, 0, 0, 0, 3);
493 495
494 // playLabel2 = new QLabel(tab, "PlayLabel2" ); 496 // playLabel2 = new QLabel(tab, "PlayLabel2" );
495 // playLabel2->setText(tr("Play") ); 497 // playLabel2->setText(tr("Play") );
496 // playLabel2->setFixedHeight( 18); 498 // playLabel2->setFixedHeight( 18);
497 // layout1->addMultiCellWidget( playLabel2, 0, 0, 4, 4); 499 // layout1->addMultiCellWidget( playLabel2, 0, 0, 4, 4);
498 500
499 Stop_PushButton = new QPushButton( tab, "Stop_PushButton" ); 501 Stop_PushButton = new QPushButton( tab, "Stop_PushButton" );
@@ -727,130 +729,130 @@ void QtRec::initConnections() {
727 connect(OutputSlider,SIGNAL(sliderReleased()),this,SLOT(changedOutVolume())); 729 connect(OutputSlider,SIGNAL(sliderReleased()),this,SLOT(changedOutVolume()));
728 connect(InputSlider,SIGNAL(sliderReleased()),this,SLOT(changedInVolume())); 730 connect(InputSlider,SIGNAL(sliderReleased()),this,SLOT(changedInVolume()));
729 731
730 connect(sampleRateComboBox,SIGNAL(activated(int)),this,SLOT(changesamplerateCombo(int))); 732 connect(sampleRateComboBox,SIGNAL(activated(int)),this,SLOT(changesamplerateCombo(int)));
731 connect(bitRateComboBox,SIGNAL(activated(int)),this,SLOT(changebitrateCombo(int))); 733 connect(bitRateComboBox,SIGNAL(activated(int)),this,SLOT(changebitrateCombo(int)));
732 connect(directoryComboBox,SIGNAL(activated(int)),this,SLOT(changeDirCombo(int))); 734 connect(directoryComboBox,SIGNAL(activated(int)),this,SLOT(changeDirCombo(int)));
733 connect(sizeLimitCombo,SIGNAL(activated(int)),this,SLOT(changeSizeLimitCombo(int))); 735 connect(sizeLimitCombo,SIGNAL(activated(int)),this,SLOT(changeSizeLimitCombo(int)));
734 736
735 connect(stereoCheckBox,SIGNAL(toggled(bool)),this,SLOT(changeStereoCheck(bool))); 737 connect(stereoCheckBox,SIGNAL(toggled(bool)),this,SLOT(changeStereoCheck(bool)));
736 connect(outMuteCheckBox,SIGNAL(toggled(bool)),this,SLOT(doVolMuting(bool))); 738 connect(outMuteCheckBox,SIGNAL(toggled(bool)),this,SLOT(doVolMuting(bool)));
737 connect(inMuteCheckBox,SIGNAL(toggled(bool)),this,SLOT(doMicMuting(bool))); 739 connect(inMuteCheckBox,SIGNAL(toggled(bool)),this,SLOT(doMicMuting(bool)));
738 740
739 connect(ListView1,SIGNAL(doubleClicked(QListViewItem*)),this,SLOT(itClick(QListViewItem*))); 741 connect(ListView1,SIGNAL(doubleClicked(QListViewItem*)),this,SLOT(itClick(QListViewItem*)));
740 connect(ListView1,SIGNAL(mouseButtonPressed(int,QListViewItem*,const QPoint&,int)),this,SLOT(listPressed(int,QListViewItem*,const QPoint&,int))); 742 connect(ListView1,SIGNAL(mouseButtonPressed(int,QListViewItem*,const QPoint&,int)),this,SLOT(listPressed(int,QListViewItem*,const QPoint&,int)));
741 743
742 connect(timeSlider,SIGNAL(sliderMoved(int)),this,SLOT(changeTimeSlider(int))); 744 connect(timeSlider,SIGNAL(sliderMoved(int)),this,SLOT(changeTimeSlider(int)));
743 connect(timeSlider,SIGNAL(sliderPressed()),this,SLOT(timeSliderPressed())); 745 connect(timeSlider,SIGNAL(sliderPressed()),this,SLOT(timeSliderPressed()));
744 connect(timeSlider,SIGNAL(sliderReleased()),this,SLOT(timeSliderReleased())); 746 connect(timeSlider,SIGNAL(sliderReleased()),this,SLOT(timeSliderReleased()));
745 747
746 connect(compressionCheckBox,SIGNAL(toggled(bool)),this,SLOT(compressionSelected(bool))); 748 connect(compressionCheckBox,SIGNAL(toggled(bool)),this,SLOT(compressionSelected(bool)));
747 connect(autoMuteCheckBox,SIGNAL(toggled(bool)),this,SLOT(slotAutoMute(bool))); 749 connect(autoMuteCheckBox,SIGNAL(toggled(bool)),this,SLOT(slotAutoMute(bool)));
748} 750}
749 751
750void QtRec::initConfig() { 752void QtRec::initConfig() {
751 int index, fred, i; 753 int index, fred, i;
752 Config cfg("OpieRec"); 754 Config cfg("OpieRec");
753 cfg.setGroup("Settings"); 755 cfg.setGroup("Settings");
754 756
755 index = cfg.readNumEntry("samplerate",22050); 757 index = cfg.readNumEntry("samplerate",22050);
756 bool ok; 758 bool ok;
757 759
758 for(int ws=0;ws<sampleRateComboBox->count();ws++) { 760 for(int ws=0;ws<sampleRateComboBox->count();ws++) {
759 fred = sampleRateComboBox->text(ws).toInt(&ok, 10); 761 fred = sampleRateComboBox->text(ws).toInt(&ok, 10);
760 if( index == fred) { 762 if( index == fred) {
761 filePara.sampleRate = fred; 763 filePara.sampleRate = fred;
762 sampleRateComboBox->setCurrentItem(ws); 764 sampleRateComboBox->setCurrentItem(ws);
763 } 765 }
764 } 766 }
765 767
766 i = cfg.readNumEntry("bitrate",16); 768 i = cfg.readNumEntry("bitrate",16);
767 if(i == 16) 769 if(i == 16)
768 bitRateComboBox->setCurrentItem( 1); 770 bitRateComboBox->setCurrentItem( 1);
769 else if(i == 24) 771 else if(i == 24)
770 bitRateComboBox->setCurrentItem( 2); 772 bitRateComboBox->setCurrentItem( 2);
771 else if(i == 32) 773 else if(i == 32)
772 bitRateComboBox->setCurrentItem( 3); 774 bitRateComboBox->setCurrentItem( 3);
773 else 775 else
774 bitRateComboBox->setCurrentItem( 0); 776 bitRateComboBox->setCurrentItem( 0);
775 777
776 filePara.resolution = i; 778 filePara.resolution = i;
777 779
778 i = cfg.readNumEntry("sizeLimit", 5 ); 780 i = cfg.readNumEntry("sizeLimit", 5 );
779 QString temp; 781 QString temp;
780 sizeLimitCombo->setCurrentItem((i/5)); 782 sizeLimitCombo->setCurrentItem((i/5));
781 783
782 stereoCheckBox->setChecked( cfg.readBoolEntry("stereo", 1)); 784 stereoCheckBox->setChecked( cfg.readBoolEntry("stereo", 1));
783 if( stereoCheckBox->isChecked()) { 785 if( stereoCheckBox->isChecked()) {
784 filePara.channels = 2; 786 filePara.channels = 2;
785 } else { 787 } else {
786 filePara.channels = 1; 788 filePara.channels = 1;
787 } 789 }
788 790
789 compressionCheckBox->setChecked( cfg.readBoolEntry("wavCompression",1)); 791 compressionCheckBox->setChecked( cfg.readBoolEntry("wavCompression",1));
790 if( compressionCheckBox->isChecked()) { 792 if( compressionCheckBox->isChecked()) {
793 bitRateComboBox->setCurrentItem(1);
791 bitRateComboBox->setEnabled(false); 794 bitRateComboBox->setEnabled(false);
792 bitRateComboBox->setCurrentItem(0);
793 filePara.resolution=16; 795 filePara.resolution=16;
794 } 796 }
795 797
796 autoMuteCheckBox->setChecked( cfg.readBoolEntry("useAutoMute",0)); 798 autoMuteCheckBox->setChecked( cfg.readBoolEntry("useAutoMute",0));
797 if( autoMuteCheckBox->isChecked()) 799 if( autoMuteCheckBox->isChecked())
798 slotAutoMute(true); 800 slotAutoMute(true);
799 else 801 else
800 slotAutoMute(false); 802 slotAutoMute(false);
801 803
802 Config cofg( "qpe"); 804 Config cofg( "qpe");
803 cofg.setGroup( "Volume"); 805 cofg.setGroup( "Volume");
804 outMuteCheckBox->setChecked( cofg.readBoolEntry( "Mute",0)); 806 outMuteCheckBox->setChecked( cofg.readBoolEntry( "Mute",0));
805 inMuteCheckBox->setChecked( cofg.readBoolEntry( "MicMute",0)); 807 inMuteCheckBox->setChecked( cofg.readBoolEntry( "MicMute",0));
806} 808}
807 809
808void QtRec::stop() { 810void QtRec::stop() {
809 // owarn << "STOP" << oendl; 811 // owarn << "STOP" << oendl;
810 setRecordButton(false); 812 setRecordButton(false);
811 813
812 if( !recording) 814 if( !recording)
813 endPlaying(); 815 endPlaying();
814 else 816 else
815 endRecording(); 817 endRecording();
816 timeSlider->setValue(0); 818 timeSlider->setValue(0);
817} 819}
818 820
819void QtRec::doPlayBtn() { 821void QtRec::doPlayBtn() {
820 822
821 if(!stopped) { 823 if(!stopped) {
822 // playLabel2->setText(tr("Play")); 824 // playLabel2->setText(tr("Play"));
823 stop(); 825 stop();
824 } else { 826 } else {
825 if(ListView1->currentItem() == 0) return; 827 if(ListView1->currentItem() == 0) return;
826 // playLabel2->setText(tr("Stop")); 828 // playLabel2->setText(tr("Stop"));
827 currentFile = ListView1->currentItem()->text(0); 829 currentFile = ListView1->currentItem()->text(0);
828 start(); 830 start();
829 } 831 }
830} 832}
831 833
832void QtRec::start() { //play 834void QtRec::start() { //play
833 if( stopped) { 835 if( stopped) {
834 QPixmap image3( ( const char** ) image3_data ); 836 QPixmap image3( ( const char** ) image3_data );
835 Stop_PushButton->setPixmap( image3 ); 837 Stop_PushButton->setPixmap( image3 );
836 Stop_PushButton->setDown( true); 838 Stop_PushButton->setDown( true);
837 stopped = false; 839 stopped = false;
838 paused = false; 840 paused = false;
839 secCount = 1; 841 secCount = 1;
840 842
841 if( openPlayFile()) 843 if( openPlayFile())
842 if( setupAudio( false)) //recording is false 844 if( setupAudio( false)) //recording is false
843 doPlay(); 845 doPlay();
844 } 846 }
845} 847}
846 848
847bool QtRec::rec() { //record 849bool QtRec::rec() { //record
848 QString timeString; 850 QString timeString;
849 timeString.sprintf("%.0f", 0.0); 851 timeString.sprintf("%.0f", 0.0);
850 // timeLabel->setText( timeString+ " seconds"); 852 // timeLabel->setText( timeString+ " seconds");
851 if(!stopped) { 853 if(!stopped) {
852 monitoring = true; 854 monitoring = true;
853 return false; 855 return false;
854 } else { 856 } else {
855 secCount = 1; 857 secCount = 1;
856 // playLabel2->setText(tr("Stop")); 858 // playLabel2->setText(tr("Stop"));
@@ -987,129 +989,129 @@ bool QtRec::setupAudio( bool b) {
987#ifdef PDAUDIO //ALSA 989#ifdef PDAUDIO //ALSA
988 if( filePara.resolution == 16 || compressionCheckBox->isChecked() ) { 990 if( filePara.resolution == 16 || compressionCheckBox->isChecked() ) {
989 sampleformat = SND_PCM_FORMAT_S16; 991 sampleformat = SND_PCM_FORMAT_S16;
990 filePara.resolution = 16; 992 filePara.resolution = 16;
991 } else if( filePara.resolution == 24 || compressionCheckBox->isChecked() ) { 993 } else if( filePara.resolution == 24 || compressionCheckBox->isChecked() ) {
992 sampleformat = SND_PCM_FORMAT_S24; 994 sampleformat = SND_PCM_FORMAT_S24;
993 filePara.resolution = 24; 995 filePara.resolution = 24;
994 } else if( filePara.resolution == 32 || compressionCheckBox->isChecked() ) { 996 } else if( filePara.resolution == 32 || compressionCheckBox->isChecked() ) {
995 sampleformat = SND_PCM_FORMAT_S32; 997 sampleformat = SND_PCM_FORMAT_S32;
996 filePara.resolution = 32; 998 filePara.resolution = 32;
997 } else { 999 } else {
998 sampleformat = SND_PCM_FORMAT_U8; 1000 sampleformat = SND_PCM_FORMAT_U8;
999 filePara.resolution = 8; 1001 filePara.resolution = 8;
1000 } 1002 }
1001#else 1003#else
1002// we want to play 1004// we want to play
1003 if( filePara.resolution == 16 || compressionCheckBox->isChecked() ) { 1005 if( filePara.resolution == 16 || compressionCheckBox->isChecked() ) {
1004 sampleformat = AFMT_S16_LE; 1006 sampleformat = AFMT_S16_LE;
1005 filePara.resolution = 16; 1007 filePara.resolution = 16;
1006 } else { 1008 } else {
1007 sampleformat = AFMT_U8; 1009 sampleformat = AFMT_U8;
1008 filePara.resolution = 8; 1010 filePara.resolution = 8;
1009 } 1011 }
1010#endif 1012#endif
1011 1013
1012 stereo = filePara.channels; 1014 stereo = filePara.channels;
1013 flags = O_WRONLY; 1015 flags = O_WRONLY;
1014 recording = false; 1016 recording = false;
1015 } else { // we want to record 1017 } else { // we want to record
1016 1018
1017#ifdef PDAUDIO //ALSA 1019#ifdef PDAUDIO //ALSA
1018 if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16") 1020 if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16")
1019 sampleformat = SND_PCM_FORMAT_S16; 1021 sampleformat = SND_PCM_FORMAT_S16;
1020 else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "24") 1022 else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "24")
1021 sampleformat = SND_PCM_FORMAT_S24; 1023 sampleformat = SND_PCM_FORMAT_S24;
1022 else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "32") 1024 else if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "32")
1023 sampleformat = SND_PCM_FORMAT_S32; 1025 sampleformat = SND_PCM_FORMAT_S32;
1024 else 1026 else
1025 sampleformat = SND_PCM_FORMAT_U8; 1027 sampleformat = SND_PCM_FORMAT_U8;
1026 1028
1027#else 1029#else
1028 if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16") 1030 if( !bitRateComboBox->isEnabled() || bitRateComboBox->currentText() == "16")
1029 sampleformat = AFMT_S16_LE; 1031 sampleformat = AFMT_S16_LE;
1030 else 1032 else
1031 sampleformat = AFMT_U8; 1033 sampleformat = AFMT_U8;
1032 1034
1033 if( !compressionCheckBox->isChecked()) { 1035 if( !compressionCheckBox->isChecked()) {
1034 filePara.format = WAVE_FORMAT_PCM; 1036 filePara.format = WAVE_FORMAT_PCM;
1035// odebug << "WAVE_FORMAT_PCM" << oendl; 1037// odebug << "WAVE_FORMAT_PCM" << oendl;
1036 } else { 1038 } else {
1037 filePara.format = WAVE_FORMAT_DVI_ADPCM; 1039 filePara.format = WAVE_FORMAT_DVI_ADPCM;
1038 sampleformat = AFMT_S16_LE; 1040 sampleformat = AFMT_S16_LE;
1039// odebug << "WAVE_FORMAT_DVI_ADPCM" << oendl; 1041// odebug << "WAVE_FORMAT_DVI_ADPCM" << oendl;
1040 } 1042 }
1041#endif 1043#endif
1042 1044
1043 stereo = filePara.channels; 1045 stereo = filePara.channels;
1044// filePara.sampleRate = sampleRateComboBox->currentText().toInt( &ok,10);//44100; 1046// filePara.sampleRate = sampleRateComboBox->currentText().toInt( &ok,10);//44100;
1045 flags= O_RDWR; 1047 flags= O_RDWR;
1046// flags= O_RDONLY; 1048// flags= O_RDONLY;
1047 recording = true; 1049 recording = true;
1048 } 1050 }
1049 1051
1050 // if(soundDevice) delete soundDevice; 1052 // if(soundDevice) delete soundDevice;
1051 odebug << "<<<<<<<<<<<<<<<<<<<open dsp " << filePara.sampleRate << " " << filePara.channels << " " << sampleformat << "" << oendl; 1053 owarn << "<<<<<<<<<<<<<<<<<<<open dsp " << filePara.sampleRate << " " << filePara.channels << " " << sampleformat << "" << oendl;
1052 // owarn << "change waveform settings" << oendl; 1054 // owarn << "change waveform settings" << oendl;
1053 waveform->changeSettings( filePara.sampleRate, filePara.channels ); 1055 waveform->changeSettings( filePara.sampleRate, filePara.channels );
1054 1056
1055 soundDevice = new Device( this, b); //open rec 1057 soundDevice = new Device( this, b); //open rec
1056// soundDevice->openDsp(); 1058// soundDevice->openDsp();
1057 soundDevice->reset(); 1059 soundDevice->reset();
1058 1060
1059 odebug << "device has been made " << soundDevice->sd << "" << oendl; 1061 odebug << "device has been made " << soundDevice->sd << "" << oendl;
1060 1062
1061 ////////////////// <<<<<<<<<<<<>>>>>>>>>>>> 1063 ////////////////// <<<<<<<<<<<<>>>>>>>>>>>>
1062 soundDevice->setDeviceFormat( sampleformat); 1064 soundDevice->setDeviceFormat( sampleformat);
1063 soundDevice->setDeviceChannels( filePara.channels); 1065 soundDevice->setDeviceChannels( filePara.channels);
1064 soundDevice->setDeviceRate( filePara.sampleRate); 1066 soundDevice->setDeviceRate( filePara.sampleRate);
1065 soundDevice->getDeviceFragSize(); 1067 soundDevice->getDeviceFragSize();
1066#ifdef QT_QWS_EBX 1068#ifdef QT_QWS_EBX
1067 int frag = FRAGSIZE; 1069 int frag = FRAGSIZE;
1068 soundDevice->setFragSize( frag); 1070 soundDevice->setFragSize( frag);
1069 soundDevice->getDeviceFragSize(); 1071 soundDevice->getDeviceFragSize();
1070#endif 1072#endif
1071 ///////////////// 1073 /////////////////
1072 filePara.sd = soundDevice->sd; 1074 filePara.sd = soundDevice->sd;
1073 1075
1074 if ( filePara.sd == -1) { 1076 if ( filePara.sd == -1) {
1075 1077
1076 monitoring = false; 1078 monitoring = false;
1077 stopped = true; 1079 stopped = true;
1078 update(); 1080 update();
1079 setCaption( tr( "OpieRecord " )+ QString::number(VERSION) ); 1081 setCaption( tr( "OpieRecord " )+ QString::number(VERSION) );
1080 return false; 1082 return false;
1081 } 1083 }
1082 if(autoMute) 1084 if(autoMute)
1083 doMute(false); 1085 doMute(false);
1084 1086
1085 return true; 1087 return true;
1086} 1088}
1087 1089
1088 1090
1089bool QtRec::setUpFile() { //setup file for recording 1091bool QtRec::setUpFile() { //setup file for recording
1090// odebug << "Setting up wavfile" << oendl; 1092// odebug << "Setting up wavfile" << oendl;
1091// if(wavFile) delete wavFile; 1093// if(wavFile) delete wavFile;
1092 wavFile = new WavFile( this, (const QString &)"", 1094 wavFile = new WavFile( this, (const QString &)"",
1093 true, 1095 true,
1094 filePara.sampleRate, 1096 filePara.sampleRate,
1095 filePara.channels, 1097 filePara.channels,
1096 filePara.resolution, 1098 filePara.resolution,
1097 filePara.format); 1099 filePara.format);
1098 1100
1099 filePara.fd = wavFile->wavHandle(); 1101 filePara.fd = wavFile->wavHandle();
1100 if(filePara.fd == -1) { 1102 if(filePara.fd == -1) {
1101 return false; 1103 return false;
1102 } else { 1104 } else {
1103// filePara.channels=1; 1105// filePara.channels=1;
1104 } 1106 }
1105 return true; 1107 return true;
1106} 1108}
1107 1109
1108/// <<<<<<<<<<<<<<<< PLAY >>>>>>>>>>>>>>>>>>> 1110/// <<<<<<<<<<<<<<<< PLAY >>>>>>>>>>>>>>>>>>>
1109bool QtRec::doPlay() { 1111bool QtRec::doPlay() {
1110 1112
1111 if( !paused) { 1113 if( !paused) {
1112 total = 0; 1114 total = 0;
1113 filePara.numberOfRecordedSeconds = 0; 1115 filePara.numberOfRecordedSeconds = 0;
1114 } else { 1116 } else {
1115 paused = false; 1117 paused = false;
@@ -1169,160 +1171,160 @@ void QtRec::changesamplerateCombo(int i) {
1169 cfg.setGroup("Settings"); 1171 cfg.setGroup("Settings");
1170 int rate=0; 1172 int rate=0;
1171 bool ok; 1173 bool ok;
1172 rate = sampleRateComboBox->text(i).toInt(&ok, 10); 1174 rate = sampleRateComboBox->text(i).toInt(&ok, 10);
1173 cfg.writeEntry( "samplerate",rate); 1175 cfg.writeEntry( "samplerate",rate);
1174 filePara.sampleRate=rate; 1176 filePara.sampleRate=rate;
1175 odebug << "Change sample rate " << rate << "" << oendl; 1177 odebug << "Change sample rate " << rate << "" << oendl;
1176 cfg.write(); 1178 cfg.write();
1177} 1179}
1178 1180
1179 1181
1180void QtRec::changeDirCombo(int index) { 1182void QtRec::changeDirCombo(int index) {
1181 Config cfg("OpieRec"); 1183 Config cfg("OpieRec");
1182 cfg.setGroup("Settings"); 1184 cfg.setGroup("Settings");
1183 QString sName = directoryComboBox->text(index); 1185 QString sName = directoryComboBox->text(index);
1184 1186
1185 StorageInfo storageInfo; 1187 StorageInfo storageInfo;
1186 const QList<FileSystem> &fs = storageInfo.fileSystems(); 1188 const QList<FileSystem> &fs = storageInfo.fileSystems();
1187 QListIterator<FileSystem> it ( fs ); 1189 QListIterator<FileSystem> it ( fs );
1188 QString storage; 1190 QString storage;
1189 for( ; it.current(); ++it ){ 1191 for( ; it.current(); ++it ){
1190 if( sName == (*it)->name()+" "+ (*it)->path() || 1192 if( sName == (*it)->name()+" "+ (*it)->path() ||
1191 (*it)->name() == sName ) { 1193 (*it)->name() == sName ) {
1192 const QString path = (*it)->path(); 1194 const QString path = (*it)->path();
1193 recDir = path; 1195 recDir = path;
1194 cfg.writeEntry("directory", recDir); 1196 cfg.writeEntry("directory", recDir);
1195 odebug << "new rec dir "+recDir << oendl; 1197 odebug << "new rec dir "+recDir << oendl;
1196 } 1198 }
1197 } 1199 }
1198 cfg.write(); 1200 cfg.write();
1199} 1201}
1200 1202
1201 1203
1202void QtRec::changeSizeLimitCombo(int) { 1204void QtRec::changeSizeLimitCombo(int) {
1203 Config cfg("OpieRec"); 1205 Config cfg("OpieRec");
1204 cfg.setGroup("Settings"); 1206 cfg.setGroup("Settings");
1205 cfg.writeEntry("sizeLimit", getCurrentSizeLimit() ); 1207 cfg.writeEntry("sizeLimit", getCurrentSizeLimit() );
1206 cfg.write(); 1208 cfg.write();
1207} 1209}
1208 1210
1209void QtRec::newSound() { 1211void QtRec::newSound() {
1210 if( !rec()) { 1212 if( !rec()) {
1211 endRecording(); 1213 endRecording();
1212 deleteSound(); 1214 deleteSound();
1213 } 1215 }
1214} 1216}
1215 1217
1216void QtRec::itClick(QListViewItem *item) { 1218void QtRec::itClick(QListViewItem *item) {
1217 currentFile = item->text(0); 1219 currentFile = item->text(0);
1218 setCaption("OpieRecord "+currentFile); 1220 setCaption("OpieRecord "+currentFile);
1219} 1221}
1220 1222
1221void QtRec::deleteSound() { 1223void QtRec::deleteSound() {
1222 Config cfg("OpieRec"); 1224 Config cfg("OpieRec");
1223 cfg.setGroup("Sounds"); 1225 cfg.setGroup("Sounds");
1224 if( ListView1->currentItem() == NULL) 1226 if( ListView1->currentItem() == NULL)
1225 return; 1227 return;
1226// #ifndef DEV_VERSION 1228// #ifndef DEV_VERSION
1227 // switch ( QMessageBox::warning(this,tr("Delete"), 1229 // switch ( QMessageBox::warning(this,tr("Delete"),
1228 // tr("Do you really want to <font size=+2><B>DELETE</B></font>\nthe selected file?"), 1230 // tr("Do you really want to <font size=+2><B>DELETE</B></font>\nthe selected file?"),
1229 // tr("Yes"),tr("No"),0,1,1) ) { 1231 // tr("Yes"),tr("No"),0,1,1) ) {
1230 // case 0: 1232 // case 0:
1231// #endif 1233// #endif
1232 // { 1234 // {
1233 QString file = ListView1->currentItem()->text(0); 1235 QString file = ListView1->currentItem()->text(0);
1234 QString fileName; 1236 QString fileName;
1235 fileName = cfg.readEntry( file, ""); 1237 fileName = cfg.readEntry( file, "");
1236 QFile f( fileName); 1238 QFile f( fileName);
1237 if( f.exists()) 1239 if( f.exists())
1238 if( !f.remove()) 1240 if( !f.remove())
1239 QMessageBox::message( tr("Error"), tr("Could not remove file.")); 1241 QMessageBox::message( tr("Error"), tr("Could not remove file."));
1240 1242
1241 int nFiles = cfg.readNumEntry( "NumberofFiles",0); 1243 int nFiles = cfg.readNumEntry( "NumberofFiles",0);
1242 bool found = false; 1244 bool found = false;
1243 for(int i=0;i<nFiles+1;i++) { 1245 for(int i=0;i<nFiles+1;i++) {
1244 1246
1245 if( cfg.readEntry( QString::number(i),"").find( file,0,true) != -1) { 1247 if( cfg.readEntry( QString::number(i),"").find( file,0,true) != -1) {
1246 found = true; 1248 found = true;
1247 cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),"")); 1249 cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),""));
1248 } 1250 }
1249 if(found) 1251 if(found)
1250 cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),"")); 1252 cfg.writeEntry( QString::number(i), cfg.readEntry( QString::number(i+1),""));
1251 } 1253 }
1252 1254
1253 cfg.removeEntry( cfg.readEntry( file)); 1255 cfg.removeEntry( cfg.readEntry( file));
1254 cfg.removeEntry( file); 1256 cfg.removeEntry( file);
1255 cfg.writeEntry( "NumberofFiles", nFiles-1); 1257 cfg.writeEntry( "NumberofFiles", nFiles-1);
1256 cfg.write(); 1258 cfg.write();
1257 1259
1258 ListView1->takeItem( ListView1->currentItem() ); 1260 ListView1->takeItem( ListView1->currentItem() );
1259 delete ListView1->currentItem(); 1261 delete ListView1->currentItem();
1260 1262
1261 ListView1->clear(); 1263 ListView1->clear();
1262 ListView1->setSelected( ListView1->firstChild(), true); 1264 ListView1->setSelected( ListView1->firstChild(), true);
1263 initIconView(); 1265 initIconView();
1264 update(); 1266 update();
1265 setCaption( tr( "OpieRecord " )); 1267 setCaption( tr( "OpieRecord " ));
1266} 1268}
1267 1269
1268void QtRec::keyPressEvent( QKeyEvent *e) { 1270void QtRec::keyPressEvent( QKeyEvent *e) {
1269 1271
1270 switch ( e->key() ) { 1272 switch ( e->key() ) {
1271 // case Key_F1: 1273 // case Key_F1:
1272 // if(stopped && !recording) 1274 // if(stopped && !recording)
1273 // newSound(); 1275 // newSound();
1274 // else 1276 // else
1275 // stop(); 1277 // stop();
1276 // break; 1278 // break;
1277 // case Key_F2: { 1279 // case Key_F2: {
1278 // if( !e->isAutoRepeat()) 1280 // if( !e->isAutoRepeat())
1279 // rewindPressed(); 1281 // rewindPressed();
1280 // } 1282 // }
1281 // break; 1283 // break;
1282 // case Key_F3: { 1284 // case Key_F3: {
1283 // if( !e->isAutoRepeat()) 1285 // if( !e->isAutoRepeat())
1284 // FastforwardPressed(); 1286 // FastforwardPressed();
1285 // } 1287 // }
1286 // break; 1288 // break;
1287 1289
1288 ////////////////////////////// Zaurus keys 1290 ////////////////////////////// Zaurus keys
1289 case Key_F9: //activity 1291 case Key_F9: //activity
1290 break; 1292 break;
1291 case Key_F10: //contacts 1293 case Key_F10: //contacts
1292 break; 1294 break;
1293 case Key_F11: //menu 1295 case Key_F11: //menu
1294 break; 1296 break;
1295 case Key_F12: //home 1297 case Key_F12: //home
1296 break; 1298 break;
1297 case Key_F13: //mail 1299 case Key_F13: //mail
1298 break; 1300 break;
1299 case Key_Space: 1301 case Key_Space:
1300 break; 1302 break;
1301 case Key_Delete: 1303 case Key_Delete:
1302 break; 1304 break;
1303 case Key_Up: 1305 case Key_Up:
1304 // stop(); 1306 // stop();
1305 break; 1307 break;
1306 case Key_Down: 1308 case Key_Down:
1307 // newSound(); 1309 // newSound();
1308 break; 1310 break;
1309 case Key_Left: { 1311 case Key_Left: {
1310 odebug << "rewinding" << oendl; 1312 odebug << "rewinding" << oendl;
1311 if( !e->isAutoRepeat()) 1313 if( !e->isAutoRepeat())
1312 rewindPressed(); 1314 rewindPressed();
1313 } 1315 }
1314 break; 1316 break;
1315 case Key_Right: { 1317 case Key_Right: {
1316 if( !e->isAutoRepeat()) 1318 if( !e->isAutoRepeat())
1317 FastforwardPressed(); 1319 FastforwardPressed();
1318 } 1320 }
1319 break; 1321 break;
1320 } 1322 }
1321} 1323}
1322 1324
1323void QtRec::keyReleaseEvent( QKeyEvent *e) { 1325void QtRec::keyReleaseEvent( QKeyEvent *e) {
1324 switch ( e->key() ) { 1326 switch ( e->key() ) {
1325 // case Key_F1: 1327 // case Key_F1:
1326 // if(stopped && !recording) 1328 // if(stopped && !recording)
1327 // newSound(); 1329 // newSound();
1328 // else 1330 // else
@@ -1348,206 +1350,206 @@ void QtRec::keyReleaseEvent( QKeyEvent *e) {
1348 else 1350 else
1349 stop(); 1351 stop();
1350 break; 1352 break;
1351 case Key_F13: //mail 1353 case Key_F13: //mail
1352 break; 1354 break;
1353 case Key_Space: 1355 case Key_Space:
1354 if(stopped && !recording) 1356 if(stopped && !recording)
1355 newSound(); 1357 newSound();
1356 else 1358 else
1357 stop(); 1359 stop();
1358 break; 1360 break;
1359 case Key_Delete: 1361 case Key_Delete:
1360 deleteSound(); 1362 deleteSound();
1361 break; 1363 break;
1362 case Key_Up: 1364 case Key_Up:
1363 // stop(); 1365 // stop();
1364 odebug << "Up" << oendl; 1366 odebug << "Up" << oendl;
1365 break; 1367 break;
1366 case Key_Down: 1368 case Key_Down:
1367 // start(); 1369 // start();
1368 // odebug << "Down" << oendl; 1370 // odebug << "Down" << oendl;
1369 // newSound(); 1371 // newSound();
1370 break; 1372 break;
1371 case Key_Left: 1373 case Key_Left:
1372 odebug << "Left" << oendl; 1374 odebug << "Left" << oendl;
1373 rewindReleased(); 1375 rewindReleased();
1374 break; 1376 break;
1375 case Key_Right: 1377 case Key_Right:
1376 odebug << "Right" << oendl; 1378 odebug << "Right" << oendl;
1377 FastforwardReleased(); 1379 FastforwardReleased();
1378 break; 1380 break;
1379 } 1381 }
1380} 1382}
1381 1383
1382void QtRec::endRecording() { 1384void QtRec::endRecording() {
1383 1385
1384 monitoring = false; 1386 monitoring = false;
1385 recording = false; 1387 recording = false;
1386 stopped = true; 1388 stopped = true;
1387 waveform->reset(); 1389 waveform->reset();
1388 setRecordButton( false); 1390 setRecordButton( false);
1389 1391
1390 toBeginningButton->setEnabled( true); 1392 toBeginningButton->setEnabled( true);
1391 toEndButton->setEnabled( true); 1393 toEndButton->setEnabled( true);
1392 1394
1393 killTimers(); 1395 killTimers();
1394 1396
1395 if(autoMute) 1397 if(autoMute)
1396 doMute( true); 1398 doMute( true);
1397 1399
1398 soundDevice->closeDevice( true); 1400 soundDevice->closeDevice( true);
1399 1401
1400 if( wavFile->track.isOpen()) { 1402 if( wavFile->track.isOpen()) {
1401 wavFile->adjustHeaders( filePara.fd, filePara.numberSamples); 1403 wavFile->adjustHeaders( filePara.fd, filePara.numberSamples);
1402 // soundDevice->sd=-1; 1404 // soundDevice->sd=-1;
1403 filePara.numberSamples = 0; 1405 filePara.numberSamples = 0;
1404 // filePara.sd=-1; 1406 // filePara.sd=-1;
1405 wavFile->closeFile(); 1407 wavFile->closeFile();
1406 filePara.fd=0; 1408 filePara.fd=0;
1407 1409
1408 if( wavFile->isTempFile()) { 1410 if( wavFile->isTempFile()) {
1409// move tmp file to regular file 1411// move tmp file to regular file
1410 QString cmd; 1412 QString cmd;
1411 cmd.sprintf("mv "+ wavFile->trackName() + " " + wavFile->currentFileName); 1413 cmd.sprintf("mv "+ wavFile->trackName() + " " + wavFile->currentFileName);
1412 odebug << "moving tmp file to "+currentFileName << oendl; 1414 odebug << "moving tmp file to "+currentFileName << oendl;
1413 system( cmd.latin1()); 1415 system( cmd.latin1());
1414 } 1416 }
1415 1417
1416 odebug << "Just moved " + wavFile->currentFileName << oendl; 1418 odebug << "Just moved " + wavFile->currentFileName << oendl;
1417 Config cfg("OpieRec"); 1419 Config cfg("OpieRec");
1418 cfg.setGroup("Sounds"); 1420 cfg.setGroup("Sounds");
1419 1421
1420 int nFiles = cfg.readNumEntry( "NumberofFiles",0); 1422 int nFiles = cfg.readNumEntry( "NumberofFiles",0);
1421 1423
1422 currentFile = QFileInfo( wavFile->currentFileName).fileName(); 1424 currentFile = QFileInfo( wavFile->currentFileName).fileName();
1423 currentFile = currentFile.left( currentFile.length() - 4); 1425 currentFile = currentFile.left( currentFile.length() - 4);
1424 1426
1425 cfg.writeEntry( "NumberofFiles", nFiles + 1); 1427 cfg.writeEntry( "NumberofFiles", nFiles + 1);
1426 cfg.writeEntry( QString::number( nFiles + 1), currentFile); 1428 cfg.writeEntry( QString::number( nFiles + 1), currentFile);
1427 cfg.writeEntry( currentFile, wavFile->currentFileName); 1429 cfg.writeEntry( currentFile, wavFile->currentFileName);
1428 1430
1429 QString time; 1431 QString time;
1430 time.sprintf("%.2f", filePara.numberOfRecordedSeconds); 1432 time.sprintf("%.2f", filePara.numberOfRecordedSeconds);
1431 cfg.writeEntry( wavFile->currentFileName, time ); 1433 cfg.writeEntry( wavFile->currentFileName, time );
1432 odebug << "writing config numberOfRecordedSeconds "+time << oendl; 1434 odebug << "writing config numberOfRecordedSeconds "+time << oendl;
1433 1435
1434 cfg.write(); 1436 cfg.write();
1435 odebug << "finished recording" << oendl; 1437 odebug << "finished recording" << oendl;
1436 // timeLabel->setText(""); 1438 // timeLabel->setText("");
1437 } 1439 }
1438 1440
1439// if(soundDevice) delete soundDevice; 1441// if(soundDevice) delete soundDevice;
1440 1442
1441 timeSlider->setValue(0); 1443 timeSlider->setValue(0);
1442 initIconView(); 1444 initIconView();
1443 selectItemByName( currentFile); 1445 selectItemByName( currentFile);
1444 setCaption( tr( "OpieRecord " )); 1446 setCaption( tr( "OpieRecord " ));
1445 1447
1446} 1448}
1447 1449
1448void QtRec::endPlaying() { 1450void QtRec::endPlaying() {
1449 monitoring = false; 1451 monitoring = false;
1450 recording = false; 1452 recording = false;
1451 playing = false; 1453 playing = false;
1452 stopped = true; 1454 stopped = true;
1453 waveform->reset(); 1455 waveform->reset();
1454// errorStop(); 1456// errorStop();
1455 odebug << "end playing" << oendl; 1457 odebug << "end playing" << oendl;
1456 setRecordButton( false); 1458 setRecordButton( false);
1457 1459
1458 toBeginningButton->setEnabled( true); 1460 toBeginningButton->setEnabled( true);
1459 toEndButton->setEnabled( true); 1461 toEndButton->setEnabled( true);
1460 1462
1461 if(autoMute) 1463 if(autoMute)
1462 doMute( true); 1464 doMute( true);
1463 1465
1464 soundDevice->closeDevice( false); 1466 soundDevice->closeDevice( false);
1465 soundDevice->sd = -1; 1467 soundDevice->sd = -1;
1466 // if(soundDevice) delete soundDevice; 1468 // if(soundDevice) delete soundDevice;
1467 odebug << "file and sound device closed" << oendl; 1469 odebug << "file and sound device closed" << oendl;
1468 // timeLabel->setText(""); 1470 // timeLabel->setText("");
1469 total = 0; 1471 total = 0;
1470 filePara.numberSamples = 0; 1472 filePara.numberSamples = 0;
1471 filePara.sd = -1; 1473 filePara.sd = -1;
1472// wavFile->closeFile(); 1474// wavFile->closeFile();
1473 filePara.fd = 0; 1475 filePara.fd = 0;
1474// if(wavFile) delete wavFile; //this crashes 1476// if(wavFile) delete wavFile; //this crashes
1475 1477
1476 odebug << "track closed" << oendl; 1478 odebug << "track closed" << oendl;
1477 killTimers(); 1479 killTimers();
1478 // owarn << "reset slider" << oendl; 1480 // owarn << "reset slider" << oendl;
1479 timeSlider->setValue(0); 1481 timeSlider->setValue(0);
1480 1482
1481// if(soundDevice) delete soundDevice; 1483// if(soundDevice) delete soundDevice;
1482 1484
1483} 1485}
1484 1486
1485bool QtRec::openPlayFile() { 1487bool QtRec::openPlayFile() {
1486 1488 qWarning("opening file");
1487 qApp->processEvents(); 1489 qApp->processEvents();
1488 if( currentFile.isEmpty()) { 1490 if( currentFile.isEmpty()) {
1489 QMessageBox::message(tr("Opierec"),tr("Please select file to play")); 1491 QMessageBox::message(tr("Opierec"),tr("Please select file to play"));
1490 endPlaying(); 1492 endPlaying();
1491 return false; 1493 return false;
1492 } 1494 }
1493 QString currentFileName; 1495 QString currentFileName;
1494 Config cfg("OpieRec"); 1496 Config cfg("OpieRec");
1495 cfg.setGroup("Sounds"); 1497 cfg.setGroup("Sounds");
1496 int nFiles = cfg.readNumEntry( "NumberofFiles", 0); 1498 int nFiles = cfg.readNumEntry( "NumberofFiles", 0);
1497 for(int i=0;i<nFiles+1;i++) { //look for file 1499 for(int i=0;i<nFiles+1;i++) { //look for file
1498 if( cfg.readEntry( QString::number(i),"").find( currentFile,0,true) != -1) { 1500 if( cfg.readEntry( QString::number(i),"").find( currentFile,0,true) != -1) {
1499 currentFileName = cfg.readEntry( currentFile, "" ); 1501 currentFileName = cfg.readEntry( currentFile, "" );
1500 odebug << "opening for play: " + currentFileName << oendl; 1502 odebug << "opening for play: " + currentFileName << oendl;
1501 } 1503 }
1502 } 1504 }
1503 wavFile = new WavFile(this, 1505 wavFile = new WavFile(this,
1504 currentFileName, 1506 currentFileName,
1505 false); 1507 false);
1506 filePara.fd = wavFile->wavHandle(); 1508 filePara.fd = wavFile->wavHandle();
1507 if(filePara.fd == -1) { 1509 if(filePara.fd == -1) {
1508 // if(!track.open(IO_ReadOnly)) { 1510 // if(!track.open(IO_ReadOnly)) {
1509 QString errorMsg = (QString)strerror(errno); 1511 QString errorMsg = (QString)strerror(errno);
1510 monitoring = false; 1512 monitoring = false;
1511 setCaption( tr( "OpieRecord " )); 1513 setCaption( tr( "OpieRecord " ));
1512 QMessageBox::message(tr("Note"), tr("Could not open audio file.\n") 1514 QMessageBox::message(tr("Note"), tr("Could not open audio file.\n")
1513 + errorMsg + "\n" + currentFile); 1515 + errorMsg + "\n" + currentFile);
1514 return false; 1516 return false;
1515 } else { 1517 } else {
1516 1518
1517 filePara.numberSamples = wavFile->getNumberSamples(); 1519 filePara.numberSamples = wavFile->getNumberSamples();
1518 filePara.format = wavFile->getFormat(); 1520 filePara.format = wavFile->getFormat();
1519 filePara.sampleRate = wavFile->getSampleRate(); 1521 filePara.sampleRate = wavFile->getSampleRate();
1520 filePara.resolution = wavFile->getResolution(); 1522 filePara.resolution = wavFile->getResolution();
1521 filePara.channels = wavFile->getChannels(); 1523 filePara.channels = wavFile->getChannels();
1522 timeSlider->setPageStep(1); 1524 timeSlider->setPageStep(1);
1523 monitoring = true; 1525 monitoring = true;
1524 1526
1525 odebug << "file " << filePara.fd << ", samples " << filePara.numberSamples << " " << filePara.sampleRate << "" << oendl; 1527 odebug << "file " << filePara.fd << ", samples " << filePara.numberSamples << " " << filePara.sampleRate << "" << oendl;
1526 int sec = (int) (( filePara.numberSamples / filePara.sampleRate) / filePara.channels) / ( filePara.channels*( filePara.resolution/8)); 1528 int sec = (int) (( filePara.numberSamples / filePara.sampleRate) / filePara.channels) / ( filePara.channels*( filePara.resolution/8));
1527 1529
1528 // owarn << "seconds " << sec << "" << oendl; 1530 // owarn << "seconds " << sec << "" << oendl;
1529 1531
1530 timeSlider->setRange(0, filePara.numberSamples ); 1532 timeSlider->setRange(0, filePara.numberSamples );
1531 } 1533 }
1532 1534
1533 return true; 1535 return true;
1534} 1536}
1535 1537
1536void QtRec::listPressed( int mouse, QListViewItem *item, const QPoint &, int ) { 1538void QtRec::listPressed( int mouse, QListViewItem *item, const QPoint &, int ) {
1537 if(item == NULL ) 1539 if(item == NULL )
1538 return; 1540 return;
1539 switch (mouse) { 1541 switch (mouse) {
1540 case 1: { 1542 case 1: {
1541 if( renameBox != 0 ) //tricky 1543 if( renameBox != 0 ) //tricky
1542 cancelRename(); 1544 cancelRename();
1543 1545
1544 currentFile = item->text(0); 1546 currentFile = item->text(0);
1545 // setCaption( "OpieRecord " + currentFile); 1547 // setCaption( "OpieRecord " + currentFile);
1546 } 1548 }
1547 break; 1549 break;
1548 case 2: 1550 case 2:
1549 showListMenu(item); 1551 showListMenu(item);
1550 ListView1->clearSelection(); 1552 ListView1->clearSelection();
1551 break; 1553 break;
1552 }; 1554 };
1553} 1555}
@@ -1665,272 +1667,273 @@ void QtRec::cancelRename() {
1665 bool resetFocus = ListView1->viewport()->focusProxy() == renameBox; 1667 bool resetFocus = ListView1->viewport()->focusProxy() == renameBox;
1666 delete renameBox; 1668 delete renameBox;
1667 renameBox = 0; 1669 renameBox = 0;
1668 if ( resetFocus ) { 1670 if ( resetFocus ) {
1669 ListView1->viewport()->setFocusProxy( ListView1 ); 1671 ListView1->viewport()->setFocusProxy( ListView1 );
1670 ListView1->setFocus(); 1672 ListView1->setFocus();
1671 } 1673 }
1672} 1674}
1673 1675
1674bool QtRec::eventFilter( QObject * o, QEvent * e ) { 1676bool QtRec::eventFilter( QObject * o, QEvent * e ) {
1675 if ( o->inherits( "QLineEdit" ) ) { 1677 if ( o->inherits( "QLineEdit" ) ) {
1676 if ( e->type() == QEvent::KeyPress ) { 1678 if ( e->type() == QEvent::KeyPress ) {
1677 QKeyEvent *ke = (QKeyEvent*)e; 1679 QKeyEvent *ke = (QKeyEvent*)e;
1678 if ( ke->key() == Key_Return || 1680 if ( ke->key() == Key_Return ||
1679 ke->key() == Key_Enter ) { 1681 ke->key() == Key_Enter ) {
1680 okRename(); 1682 okRename();
1681 return true; 1683 return true;
1682 } else if ( ke->key() == Key_Escape ) { 1684 } else if ( ke->key() == Key_Escape ) {
1683 cancelRename(); 1685 cancelRename();
1684 return true; 1686 return true;
1685 } 1687 }
1686 } else if ( e->type() == QEvent::FocusOut ) { 1688 } else if ( e->type() == QEvent::FocusOut ) {
1687 cancelRename(); 1689 cancelRename();
1688 return true; 1690 return true;
1689 } 1691 }
1690 } 1692 }
1691 return QWidget::eventFilter( o, e ); 1693 return QWidget::eventFilter( o, e );
1692} 1694}
1693 1695
1694 1696
1695int QtRec::getCurrentSizeLimit() { 1697int QtRec::getCurrentSizeLimit() {
1696 return sizeLimitCombo->currentItem() * 5; 1698 return sizeLimitCombo->currentItem() * 5;
1697} 1699}
1698 1700
1699void QtRec::timerBreak() { 1701void QtRec::timerBreak() {
1700 endPlaying(); 1702 endPlaying();
1701} 1703}
1702 1704
1703void QtRec::doVolMuting(bool b) { 1705void QtRec::doVolMuting(bool b) {
1704 Config cfg( "qpe" ); 1706 Config cfg( "qpe" );
1705 cfg. setGroup( "Volume" ); 1707 cfg. setGroup( "Volume" );
1706 cfg.writeEntry( "Mute",b); 1708 cfg.writeEntry( "Mute",b);
1707 cfg.write(); 1709 cfg.write();
1708 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << b; 1710 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << b;
1709} 1711}
1710 1712
1711void QtRec::doMicMuting(bool b) { 1713void QtRec::doMicMuting(bool b) {
1712 // odebug << "mic mute" << oendl; 1714 // odebug << "mic mute" << oendl;
1713 Config cfg( "qpe" ); 1715 Config cfg( "qpe" );
1714 cfg. setGroup( "Volume" ); 1716 cfg. setGroup( "Volume" );
1715 cfg.writeEntry( "MicMute",b); 1717 cfg.writeEntry( "MicMute",b);
1716 cfg.write(); 1718 cfg.write();
1717 QCopEnvelope( "QPE/System", "micChange(bool)" ) << b; 1719 QCopEnvelope( "QPE/System", "micChange(bool)" ) << b;
1718} 1720}
1719 1721
1720void QtRec::compressionSelected(bool b) { 1722void QtRec::compressionSelected(bool b) {
1721 Config cfg("OpieRec"); 1723 Config cfg("OpieRec");
1722 cfg.setGroup("Settings"); 1724 cfg.setGroup("Settings");
1723 cfg.writeEntry("wavCompression", b); 1725 cfg.writeEntry("wavCompression", b);
1724 cfg.writeEntry("bitrate", 16); 1726 cfg.writeEntry("bitrate", 16);
1725 filePara.resolution = 16; 1727 filePara.resolution = 16;
1726 cfg.write(); 1728 cfg.write();
1727 1729
1728 if(b) { 1730 if(b) {
1729 bitRateComboBox->setEnabled( false); 1731 qWarning("set adpcm");
1730 bitRateComboBox->setCurrentItem( 1); 1732 bitRateComboBox->setCurrentItem( 1);
1733 bitRateComboBox->setEnabled( false);
1731 filePara.resolution = 16; 1734 filePara.resolution = 16;
1732 } else{ 1735 } else{
1733 bitRateComboBox->setEnabled( true); 1736 bitRateComboBox->setEnabled( true);
1734 } 1737 }
1735} 1738}
1736 1739
1737long QtRec::checkDiskSpace(const QString &path) { 1740long QtRec::checkDiskSpace(const QString &path) {
1738 1741
1739 struct statfs fs; 1742 struct statfs fs;
1740 1743
1741 if ( !statfs( path.latin1(), &fs ) ) { 1744 if ( !statfs( path.latin1(), &fs ) ) {
1742 1745
1743 int blkSize = fs.f_bsize; 1746 int blkSize = fs.f_bsize;
1744 int availBlks = fs.f_bavail; 1747 int availBlks = fs.f_bavail;
1745 1748
1746 long mult = blkSize / 1024; 1749 long mult = blkSize / 1024;
1747 long div = 1024 / blkSize; 1750 long div = 1024 / blkSize;
1748 1751
1749 if ( !mult ) mult = 1; 1752 if ( !mult ) mult = 1;
1750 if ( !div ) div = 1; 1753 if ( !div ) div = 1;
1751 1754
1752 return availBlks * mult / div; 1755 return availBlks * mult / div;
1753 } 1756 }
1754 return -1; 1757 return -1;
1755} 1758}
1756 1759
1757// short f_fstyp; /* File system type */ 1760// short f_fstyp; /* File system type */
1758// long f_bsize; /* Block size */ 1761// long f_bsize; /* Block size */
1759// long f_frsize; /* Fragment size */ 1762// long f_frsize; /* Fragment size */
1760// long f_blocks; /* Total number of blocks*/ 1763// long f_blocks; /* Total number of blocks*/
1761// long f_bfree; /* Count of free blocks */ 1764// long f_bfree; /* Count of free blocks */
1762// long f_files; /* Total number of file nodes */ 1765// long f_files; /* Total number of file nodes */
1763// long f_ffree; /* Count of free file nodes */ 1766// long f_ffree; /* Count of free file nodes */
1764// char f_fname[6]; /* Volumename */ 1767// char f_fname[6]; /* Volumename */
1765// char f_fpack[6]; /* Pack name */ 1768// char f_fpack[6]; /* Pack name */
1766 1769
1767void QtRec::receive( const QCString &msg, const QByteArray & ) { 1770void QtRec::receive( const QCString &msg, const QByteArray & ) {
1768 odebug << "Voicerecord received message "+msg << oendl; 1771 odebug << "Voicerecord received message "+msg << oendl;
1769 1772
1770} 1773}
1771 1774
1772 1775
1773///////////////////////////// timerEvent 1776///////////////////////////// timerEvent
1774void QtRec::timerEvent( QTimerEvent * ) { 1777void QtRec::timerEvent( QTimerEvent * ) {
1775 1778
1776// if(!recording) 1779// if(!recording)
1777// timeSlider->setValue( secCount); 1780// timeSlider->setValue( secCount);
1778// else 1781// else
1779// timeSlider->setValue( filePara.numberOfRecordedSeconds); 1782// timeSlider->setValue( filePara.numberOfRecordedSeconds);
1780 1783
1781 if( stopped && playing) { 1784 if( stopped && playing) {
1782 stop(); 1785 stop();
1783 } 1786 }
1784 1787
1785 if( stopped && recording ){ 1788 if( stopped && recording ){
1786 stop(); 1789 stop();
1787 } 1790 }
1788 1791
1789 if( recording && filePara.SecondsToRecord < secCount && filePara.SecondsToRecord != 0) { 1792 if( recording && filePara.SecondsToRecord < secCount && filePara.SecondsToRecord != 0) {
1790 stop(); 1793 stop();
1791 } 1794 }
1792 1795
1793 odebug << "" << secCount << "" << oendl; 1796 odebug << "" << secCount << "" << oendl;
1794 QString timeString; 1797 QString timeString;
1795 1798
1796 timeString.sprintf("%d", secCount); 1799 timeString.sprintf("%d", secCount);
1797 // timeLabel->setText( timeString + " seconds"); 1800 // timeLabel->setText( timeString + " seconds");
1798 1801
1799 secCount++; 1802 secCount++;
1800} 1803}
1801 1804
1802void QtRec::changeTimeSlider(int index) { 1805void QtRec::changeTimeSlider(int index) {
1803 if( ListView1->currentItem() == 0 || !wavFile->track.isOpen()) return; 1806 if( ListView1->currentItem() == 0 || !wavFile->track.isOpen()) return;
1804 odebug << "Slider moved to " << index << "" << oendl; 1807 odebug << "Slider moved to " << index << "" << oendl;
1805 paused = true; 1808 paused = true;
1806 stopped = true; 1809 stopped = true;
1807 1810
1808 sliderPos=index; 1811 sliderPos=index;
1809 1812
1810 QString timeString; 1813 QString timeString;
1811 filePara.numberOfRecordedSeconds = (float)sliderPos / (float)filePara.sampleRate * (float)2; 1814 filePara.numberOfRecordedSeconds = (float)sliderPos / (float)filePara.sampleRate * (float)2;
1812 timeString.sprintf( "%.2f", filePara.numberOfRecordedSeconds); 1815 timeString.sprintf( "%.2f", filePara.numberOfRecordedSeconds);
1813 secCount = (int)filePara.numberOfRecordedSeconds; 1816 secCount = (int)filePara.numberOfRecordedSeconds;
1814 // timeLabel->setText( timeString + tr(" seconds")); 1817 // timeLabel->setText( timeString + tr(" seconds"));
1815} 1818}
1816 1819
1817void QtRec::timeSliderPressed() { 1820void QtRec::timeSliderPressed() {
1818 if( ListView1->currentItem() == 0) return; 1821 if( ListView1->currentItem() == 0) return;
1819 odebug << "slider pressed" << oendl; 1822 odebug << "slider pressed" << oendl;
1820 paused = true; 1823 paused = true;
1821 stopped = true; 1824 stopped = true;
1822} 1825}
1823 1826
1824void QtRec::timeSliderReleased() { 1827void QtRec::timeSliderReleased() {
1825 if( ListView1->currentItem() == 0) return; 1828 if( ListView1->currentItem() == 0) return;
1826 sliderPos = timeSlider->value(); 1829 sliderPos = timeSlider->value();
1827 1830
1828 odebug << "slider released " << sliderPos << "" << oendl; 1831 odebug << "slider released " << sliderPos << "" << oendl;
1829 stopped = false; 1832 stopped = false;
1830 int newPos = lseek( filePara.fd, sliderPos, SEEK_SET); 1833 int newPos = lseek( filePara.fd, sliderPos, SEEK_SET);
1831 total = newPos*4; 1834 total = newPos*4;
1832 filePara.numberOfRecordedSeconds = (float)sliderPos / (float)filePara.sampleRate * (float)2; 1835 filePara.numberOfRecordedSeconds = (float)sliderPos / (float)filePara.sampleRate * (float)2;
1833 1836
1834 doPlay(); 1837 doPlay();
1835} 1838}
1836 1839
1837void QtRec::rewindPressed() { 1840void QtRec::rewindPressed() {
1838 if( ListView1->currentItem() == 0) return; 1841 if( ListView1->currentItem() == 0) return;
1839 if( !wavFile->track.isOpen()) { 1842 if( !wavFile->track.isOpen()) {
1840 if( !openPlayFile() ) 1843 if( !openPlayFile() )
1841 return; 1844 return;
1842 else 1845 else
1843 if( !setupAudio( false)) 1846 if( !setupAudio( false))
1844 return; 1847 return;
1845 } else { 1848 } else {
1846 killTimers(); 1849 killTimers();
1847 paused = true; 1850 paused = true;
1848 stopped = true; 1851 stopped = true;
1849 rewindTimer->start( 50, false); 1852 rewindTimer->start( 50, false);
1850 } 1853 }
1851} 1854}
1852 1855
1853void QtRec::rewindTimerTimeout() { 1856void QtRec::rewindTimerTimeout() {
1854 int sliderValue = timeSlider->value(); 1857 int sliderValue = timeSlider->value();
1855 sliderValue = sliderValue - ( filePara.numberSamples / 100); 1858 sliderValue = sliderValue - ( filePara.numberSamples / 100);
1856 // if(toBeginningButton->isDown()) 1859 // if(toBeginningButton->isDown())
1857 timeSlider->setValue( sliderValue ) ; 1860 timeSlider->setValue( sliderValue ) ;
1858 odebug << "" << sliderValue << "" << oendl; 1861 odebug << "" << sliderValue << "" << oendl;
1859 QString timeString; 1862 QString timeString;
1860 filePara.numberOfRecordedSeconds = (float)sliderValue / (float)filePara.sampleRate * (float)2; 1863 filePara.numberOfRecordedSeconds = (float)sliderValue / (float)filePara.sampleRate * (float)2;
1861 timeString.sprintf( "%.2f", filePara.numberOfRecordedSeconds); 1864 timeString.sprintf( "%.2f", filePara.numberOfRecordedSeconds);
1862 // timeLabel->setText( timeString+ tr(" seconds")); 1865 // timeLabel->setText( timeString+ tr(" seconds"));
1863} 1866}
1864 1867
1865void QtRec::rewindReleased() { 1868void QtRec::rewindReleased() {
1866 rewindTimer->stop(); 1869 rewindTimer->stop();
1867 if( wavFile->track.isOpen()) { 1870 if( wavFile->track.isOpen()) {
1868 sliderPos=timeSlider->value(); 1871 sliderPos=timeSlider->value();
1869 stopped = false; 1872 stopped = false;
1870 int newPos = lseek( filePara.fd, sliderPos, SEEK_SET); 1873 int newPos = lseek( filePara.fd, sliderPos, SEEK_SET);
1871 total = newPos * 4; 1874 total = newPos * 4;
1872 odebug << "rewind released " << total << "" << oendl; 1875 odebug << "rewind released " << total << "" << oendl;
1873 startTimer( 1000); 1876 startTimer( 1000);
1874 doPlay(); 1877 doPlay();
1875 } 1878 }
1876} 1879}
1877 1880
1878void QtRec::FastforwardPressed() { 1881void QtRec::FastforwardPressed() {
1879 if( ListView1->currentItem() == 0) return; 1882 if( ListView1->currentItem() == 0) return;
1880 if( !wavFile->track.isOpen()) 1883 if( !wavFile->track.isOpen())
1881 if( !openPlayFile() ) 1884 if( !openPlayFile() )
1882 return; 1885 return;
1883 else 1886 else
1884 if( !setupAudio( false)) 1887 if( !setupAudio( false))
1885 return; 1888 return;
1886 killTimers(); 1889 killTimers();
1887 1890
1888 paused = true; 1891 paused = true;
1889 stopped = true; 1892 stopped = true;
1890 forwardTimer->start(50, false); 1893 forwardTimer->start(50, false);
1891} 1894}
1892 1895
1893 1896
1894void QtRec::forwardTimerTimeout() { 1897void QtRec::forwardTimerTimeout() {
1895 int sliderValue = timeSlider->value(); 1898 int sliderValue = timeSlider->value();
1896 sliderValue = sliderValue + ( filePara.numberSamples / 100); 1899 sliderValue = sliderValue + ( filePara.numberSamples / 100);
1897 1900
1898 // if(toEndButton->isDown()) 1901 // if(toEndButton->isDown())
1899 timeSlider->setValue( sliderValue); 1902 timeSlider->setValue( sliderValue);
1900 1903
1901 QString timeString; 1904 QString timeString;
1902 filePara.numberOfRecordedSeconds = (float)sliderValue / (float)filePara.sampleRate * (float)2; 1905 filePara.numberOfRecordedSeconds = (float)sliderValue / (float)filePara.sampleRate * (float)2;
1903 timeString.sprintf( "%.2f", filePara.numberOfRecordedSeconds); 1906 timeString.sprintf( "%.2f", filePara.numberOfRecordedSeconds);
1904 // timeLabel->setText( timeString+ tr(" seconds")); 1907 // timeLabel->setText( timeString+ tr(" seconds"));
1905} 1908}
1906 1909
1907void QtRec::FastforwardReleased() { 1910void QtRec::FastforwardReleased() {
1908 forwardTimer->stop(); 1911 forwardTimer->stop();
1909 if( wavFile->track.isOpen()) { 1912 if( wavFile->track.isOpen()) {
1910 sliderPos=timeSlider->value(); 1913 sliderPos=timeSlider->value();
1911 stopped = false; 1914 stopped = false;
1912 int newPos = lseek( filePara.fd, sliderPos, SEEK_SET); 1915 int newPos = lseek( filePara.fd, sliderPos, SEEK_SET);
1913 total = newPos * 4; 1916 total = newPos * 4;
1914 filePara.numberOfRecordedSeconds = (float)sliderPos / (float)filePara.sampleRate * (float)2; 1917 filePara.numberOfRecordedSeconds = (float)sliderPos / (float)filePara.sampleRate * (float)2;
1915 startTimer( 1000); 1918 startTimer( 1000);
1916 doPlay(); 1919 doPlay();
1917 } 1920 }
1918} 1921}
1919 1922
1920 1923
1921QString QtRec::getStorage(const QString &fileName) { 1924QString QtRec::getStorage(const QString &fileName) {
1922 1925
1923 StorageInfo storageInfo; 1926 StorageInfo storageInfo;
1924 const QList<FileSystem> &fs = storageInfo.fileSystems(); 1927 const QList<FileSystem> &fs = storageInfo.fileSystems();
1925 QListIterator<FileSystem> it ( fs ); 1928 QListIterator<FileSystem> it ( fs );
1926 QString storage; 1929 QString storage;
1927 for( ; it.current(); ++it ){ 1930 for( ; it.current(); ++it ){
1928 const QString name = ( *it)->name(); 1931 const QString name = ( *it)->name();
1929 const QString path = ( *it)->path(); 1932 const QString path = ( *it)->path();
1930 const QString disk = ( *it)->disk(); 1933 const QString disk = ( *it)->disk();
1931 if( fileName.find( path,0,true) != -1) 1934 if( fileName.find( path,0,true) != -1)
1932 storage = name; 1935 storage = name;
1933 // const QString options = (*it)->options(); 1936 // const QString options = (*it)->options();
1934 // if( name.find( tr("Internal"),0,true) == -1) { 1937 // if( name.find( tr("Internal"),0,true) == -1) {
1935 // storageComboBox->insertItem( name +" -> "+disk); 1938 // storageComboBox->insertItem( name +" -> "+disk);
1936 // odebug << name << oendl; 1939 // odebug << name << oendl;
diff --git a/noncore/multimedia/opierec/wavFile.cpp b/noncore/multimedia/opierec/wavFile.cpp
index 80453e1..b53c416 100644
--- a/noncore/multimedia/opierec/wavFile.cpp
+++ b/noncore/multimedia/opierec/wavFile.cpp
@@ -1,306 +1,306 @@
1//wavFile.cpp 1//wavFile.cpp
2#include "wavFile.h" 2#include "wavFile.h"
3#include "qtrec.h" 3#include "qtrec.h"
4 4
5/* OPIE */ 5/* OPIE */
6#include <opie2/odebug.h> 6#include <opie2/odebug.h>
7#include <qpe/config.h> 7#include <qpe/config.h>
8using namespace Opie::Core; 8using namespace Opie::Core;
9 9
10/* QT */ 10/* QT */
11#include <qmessagebox.h> 11#include <qmessagebox.h>
12#include <qdir.h> 12#include <qdir.h>
13 13
14/* STD */ 14/* STD */
15#include <errno.h> 15#include <errno.h>
16#include <sys/time.h> 16#include <sys/time.h>
17#include <sys/types.h> 17#include <sys/types.h>
18#include <sys/vfs.h> 18#include <sys/vfs.h>
19#include <fcntl.h> 19#include <fcntl.h>
20#include <math.h> 20#include <math.h>
21#include <mntent.h> 21#include <mntent.h>
22#include <stdio.h> 22#include <stdio.h>
23#include <stdlib.h> 23#include <stdlib.h>
24#include <unistd.h> 24#include <unistd.h>
25 25
26WavFile::WavFile( QObject * parent,const QString &fileName, bool makeNwFile, int sampleRate, 26WavFile::WavFile( QObject * parent,const QString &fileName, bool makeNwFile, int sampleRate,
27 int channels, int resolution, int format ) 27 int channels, int resolution, int format )
28 : QObject( parent) 28 : QObject( parent)
29{ 29{
30//odebug << "new wave file" << oendl; 30 owarn << "new wave file: " << fileName << oendl;
31 bool b = makeNwFile; 31 bool b = makeNwFile;
32 wavSampleRate=sampleRate; 32 wavSampleRate=sampleRate;
33 wavFormat=format; 33 wavFormat=format;
34 wavChannels=channels; 34 wavChannels=channels;
35 wavResolution=resolution; 35 wavResolution=resolution;
36 useTmpFile=false; 36 useTmpFile=false;
37 if( b) { 37 if( b) {
38 newFile(); 38 newFile();
39 } else { 39 } else {
40 openFile(fileName); 40 openFile(fileName);
41 } 41 }
42} 42}
43 43
44bool WavFile::newFile() { 44bool WavFile::newFile() {
45 45
46// odebug << "Set up new file" << oendl; 46// odebug << "Set up new file" << oendl;
47 Config cfg("OpieRec"); 47 Config cfg("OpieRec");
48 cfg.setGroup("Settings"); 48 cfg.setGroup("Settings");
49 49
50 currentFileName=cfg.readEntry("directory",QDir::homeDirPath()); 50 currentFileName=cfg.readEntry("directory",QDir::homeDirPath());
51 QString date; 51 QString date;
52 QDateTime dt = QDateTime::currentDateTime(); 52 QDateTime dt = QDateTime::currentDateTime();
53 date = dt.toString();//TimeString::dateString( QDateTime::currentDateTime(),false,true); 53 date = dt.toString();//TimeString::dateString( QDateTime::currentDateTime(),false,true);
54 date.replace(QRegExp("'"),""); 54 date.replace(QRegExp("'"),"");
55 date.replace(QRegExp(" "),"_"); 55 date.replace(QRegExp(" "),"_");
56 date.replace(QRegExp(":"),"-"); 56 date.replace(QRegExp(":"),"-");
57 date.replace(QRegExp(","),""); 57 date.replace(QRegExp(","),"");
58 58
59 QString currentFile=date; 59 QString currentFile=date;
60 if(currentFileName.right(1).find("/",0,true) == -1) 60 if(currentFileName.right(1).find("/",0,true) == -1)
61 currentFileName += "/" + date; 61 currentFileName += "/" + date;
62 else 62 else
63 currentFileName += date; 63 currentFileName += date;
64 currentFileName+=".wav"; 64 currentFileName+=".wav";
65 65
66// odebug << "set up file for recording: "+currentFileName << oendl; 66// odebug << "set up file for recording: "+currentFileName << oendl;
67 char pointer[] = "/tmp/opierec-XXXXXX"; 67 char pointer[] = "/tmp/opierec-XXXXXX";
68 int fd = 0; 68 int fd = 0;
69 69
70 if( currentFileName.find("/mnt",0,true) == -1 70 if( currentFileName.find("/mnt",0,true) == -1
71 && currentFileName.find("/tmp",0,true) == -1 ) { 71 && currentFileName.find("/tmp",0,true) == -1 ) {
72 // if destination file is most likely in flash (assuming jffs2) 72 // if destination file is most likely in flash (assuming jffs2)
73 // we have to write to a different filesystem first 73 // we have to write to a different filesystem first
74 74
75 useTmpFile = true; 75 useTmpFile = true;
76 if(( fd = mkstemp( pointer)) < 0 ) { 76 if(( fd = mkstemp( pointer)) < 0 ) {
77 perror("mkstemp failed"); 77 perror("mkstemp failed");
78 return false; 78 return false;
79 } 79 }
80 80
81// odebug << "Opening tmp file " << pointer << "" << oendl; 81// odebug << "Opening tmp file " << pointer << "" << oendl;
82 track.setName( pointer); 82 track.setName( pointer);
83 83
84 } else { //just use regular file.. no moving 84 } else { //just use regular file.. no moving
85 85
86 useTmpFile = false; 86 useTmpFile = false;
87 track.setName( currentFileName); 87 track.setName( currentFileName);
88 } 88 }
89 if(!track.open( IO_ReadWrite | IO_Truncate)) { 89 if(!track.open( IO_ReadWrite | IO_Truncate)) {
90 QString errorMsg=(QString)strerror(errno); 90 QString errorMsg=(QString)strerror(errno);
91 odebug << errorMsg << oendl; 91 odebug << errorMsg << oendl;
92 QMessageBox::message("Note", "Error opening file.\n" +errorMsg); 92 QMessageBox::message("Note", "Error opening file.\n" +errorMsg);
93 93
94 return false; 94 return false;
95 } else { 95 } else {
96 setWavHeader( track.handle() , &hdr); 96 setWavHeader( track.handle() , &hdr);
97 } 97 }
98return true; 98return true;
99} 99}
100 100
101WavFile::~WavFile() { 101WavFile::~WavFile() {
102 102
103 closeFile(); 103 closeFile();
104} 104}
105 105
106void WavFile::closeFile() { 106void WavFile::closeFile() {
107 if(track.isOpen()) 107 if(track.isOpen())
108 track.close(); 108 track.close();
109} 109}
110 110
111int WavFile::openFile(const QString &currentFileName) { 111int WavFile::openFile(const QString &currentFileName) {
112// odebug << "open play file "+currentFileName << oendl; 112 qWarning("open play file "+currentFileName);;
113 closeFile(); 113 closeFile();
114 114
115 track.setName(currentFileName); 115 track.setName(currentFileName);
116 116
117 if(!track.open(IO_ReadOnly)) { 117 if(!track.open(IO_ReadOnly)) {
118 QString errorMsg=(QString)strerror(errno); 118 QString errorMsg=(QString)strerror(errno);
119 odebug << "<<<<<<<<<<< "+errorMsg+currentFileName << oendl; 119 odebug << "<<<<<<<<<<< "+errorMsg+currentFileName << oendl;
120 QMessageBox::message("Note", "Error opening file.\n" +errorMsg); 120 QMessageBox::message("Note", "Error opening file.\n" +errorMsg);
121 return -1; 121 return -1;
122 } else { 122 } else {
123 parseWavHeader( track.handle()); 123 parseWavHeader( track.handle());
124 } 124 }
125 return track.handle(); 125 return track.handle();
126} 126}
127 127
128bool WavFile::setWavHeader(int fd, wavhdr *hdr) { 128bool WavFile::setWavHeader(int fd, wavhdr *hdr) {
129 129
130 strncpy((*hdr).riffID, "RIFF", 4); // RIFF 130 strncpy((*hdr).riffID, "RIFF", 4); // RIFF
131 strncpy((*hdr).wavID, "WAVE", 4); //WAVE 131 strncpy((*hdr).wavID, "WAVE", 4); //WAVE
132 strncpy((*hdr).fmtID, "fmt ", 4); // fmt 132 strncpy((*hdr).fmtID, "fmt ", 4); // fmt
133 (*hdr).fmtLen = 16; // format length = 16 133 (*hdr).fmtLen = 16; // format length = 16
134 134
135 if( wavFormat == WAVE_FORMAT_PCM) { 135 if( wavFormat == WAVE_FORMAT_PCM) {
136 (*hdr).fmtTag = 1; // PCM 136 (*hdr).fmtTag = 1; // PCM
137// odebug << "set header WAVE_FORMAT_PCM" << oendl; 137// odebug << "set header WAVE_FORMAT_PCM" << oendl;
138 } 138 }
139 else { 139 else {
140 (*hdr).fmtTag = WAVE_FORMAT_DVI_ADPCM; //intel ADPCM 140 (*hdr).fmtTag = WAVE_FORMAT_DVI_ADPCM; //intel ADPCM
141 // odebug << "set header WAVE_FORMAT_DVI_ADPCM" << oendl; 141 // odebug << "set header WAVE_FORMAT_DVI_ADPCM" << oendl;
142 } 142 }
143 143
144 // (*hdr).nChannels = 1;//filePara.channels;// ? 2 : 1*/; // channels 144 // (*hdr).nChannels = 1;//filePara.channels;// ? 2 : 1*/; // channels
145 (*hdr).nChannels = wavChannels;// ? 2 : 1*/; // channels 145 (*hdr).nChannels = wavChannels;// ? 2 : 1*/; // channels
146 146
147 (*hdr).sampleRate = wavSampleRate; //samples per second 147 (*hdr).sampleRate = wavSampleRate; //samples per second
148 (*hdr).avgBytesPerSec = (wavSampleRate)*( wavChannels*(wavResolution/8)); // bytes per second 148 (*hdr).avgBytesPerSec = (wavSampleRate)*( wavChannels*(wavResolution/8)); // bytes per second
149 (*hdr).nBlockAlign = wavChannels*( wavResolution/8); //block align 149 (*hdr).nBlockAlign = wavChannels*( wavResolution/8); //block align
150 (*hdr).bitsPerSample = wavResolution; //bits per sample 8, or 16 150 (*hdr).bitsPerSample = wavResolution; //bits per sample 8, or 16
151 151
152 strncpy((*hdr).dataID, "data", 4); 152 strncpy((*hdr).dataID, "data", 4);
153 153
154 write( fd,hdr, sizeof(*hdr)); 154 write( fd,hdr, sizeof(*hdr));
155 odebug << "writing header: bitrate " << wavResolution << ", samplerate " << wavSampleRate << ", channels " << wavChannels << oendl; 155 owarn << "writing header: bitrate " << wavResolution << ", samplerate " << wavSampleRate << ", channels " << wavChannels << oendl;
156 return true; 156 return true;
157} 157}
158 158
159bool WavFile::adjustHeaders(int fd, int total) { 159bool WavFile::adjustHeaders(int fd, int total) {
160 lseek(fd, 4, SEEK_SET); 160 lseek(fd, 4, SEEK_SET);
161 int i = total + 36; 161 int i = total + 36;
162 write( fd, &i, sizeof(i)); 162 write( fd, &i, sizeof(i));
163 lseek( fd, 40, SEEK_SET); 163 lseek( fd, 40, SEEK_SET);
164 write( fd, &total, sizeof(total)); 164 write( fd, &total, sizeof(total));
165 odebug << "adjusting header " << total << "" << oendl; 165 owarn << "adjusting header " << total << "" << oendl;
166 return true; 166 return true;
167} 167}
168 168
169int WavFile::parseWavHeader(int fd) { 169int WavFile::parseWavHeader(int fd) {
170 odebug << "Parsing wav header" << oendl; 170 owarn << "Parsing wav header" << oendl;
171 char string[4]; 171 char string[4];
172 int found; 172 int found;
173 short fmt; 173 short fmt;
174 unsigned short ch, bitrate; 174 unsigned short ch, bitrate;
175 unsigned long samplerrate, longdata; 175 unsigned long samplerrate, longdata;
176 176
177 if (read(fd, string, 4) < 4) { 177 if (read(fd, string, 4) < 4) {
178 odebug << " Could not read from sound file." << oendl; 178 owarn << " Could not read from sound file." << oendl;
179 return -1; 179 return -1;
180 } 180 }
181 if (strncmp(string, "RIFF", 4)) { 181 if (strncmp(string, "RIFF", 4)) {
182 odebug << " not a valid WAV file." << oendl; 182 owarn << " not a valid WAV file." << oendl;
183 return -1; 183 return -1;
184 } 184 }
185 lseek(fd, 4, SEEK_CUR); 185 lseek(fd, 4, SEEK_CUR);
186 if (read(fd, string, 4) < 4) { 186 if (read(fd, string, 4) < 4) {
187 odebug << "Could not read from sound file." << oendl; 187 owarn << "Could not read from sound file." << oendl;
188 return -1; 188 return -1;
189 } 189 }
190 if (strncmp(string, "WAVE", 4)) { 190 if (strncmp(string, "WAVE", 4)) {
191 odebug << "not a valid WAV file." << oendl; 191 owarn << "not a valid WAV file." << oendl;
192 return -1; 192 return -1;
193 } 193 }
194 found = 0; 194 found = 0;
195 195
196 while (!found) { 196 while (!found) {
197 if (read(fd, string, 4) < 4) { 197 if (read(fd, string, 4) < 4) {
198 odebug << "Could not read from sound file." << oendl; 198 owarn << "Could not read from sound file." << oendl;
199 return -1; 199 return -1;
200 } 200 }
201 if (strncmp(string, "fmt ", 4)) { 201 if (strncmp(string, "fmt ", 4)) {
202 if (read(fd, &longdata, 4) < 4) { 202 if (read(fd, &longdata, 4) < 4) {
203 odebug << "Could not read from sound file." << oendl; 203 owarn << "Could not read from sound file." << oendl;
204 return -1; 204 return -1;
205 } 205 }
206 lseek(fd, longdata, SEEK_CUR); 206 lseek(fd, longdata, SEEK_CUR);
207 } else { 207 } else {
208 lseek(fd, 4, SEEK_CUR); 208 lseek(fd, 4, SEEK_CUR);
209 if (read(fd, &fmt, 2) < 2) { 209 if (read(fd, &fmt, 2) < 2) {
210 odebug << "Could not read format chunk." << oendl; 210 owarn << "Could not read format chunk." << oendl;
211 return -1; 211 return -1;
212 } 212 }
213 if (fmt != WAVE_FORMAT_PCM && fmt != WAVE_FORMAT_DVI_ADPCM) { 213 if (fmt != WAVE_FORMAT_PCM && fmt != WAVE_FORMAT_DVI_ADPCM) {
214 odebug << "Wave file contains unknown format. Unable to continue." << oendl; 214 owarn << "Wave file contains unknown format. Unable to continue." << oendl;
215 return -1; 215 return -1;
216 } 216 }
217 wavFormat = fmt; 217 wavFormat = fmt;
218 // compressionFormat=fmt; 218 // compressionFormat=fmt;
219 odebug << "compressionFormat is " << fmt << "" << oendl; 219 owarn << "compressionFormat is " << fmt << "" << oendl;
220 if (read(fd, &ch, 2) < 2) { 220 if (read(fd, &ch, 2) < 2) {
221 odebug << "Could not read format chunk." << oendl; 221 owarn << "Could not read format chunk." << oendl;
222 return -1; 222 return -1;
223 } else { 223 } else {
224 wavChannels = ch; 224 wavChannels = ch;
225 odebug << "File has " << ch << " channels" << oendl; 225 owarn << "File has " << ch << " channels" << oendl;
226 } 226 }
227 if (read(fd, &samplerrate, 4) < 4) { 227 if (read(fd, &samplerrate, 4) < 4) {
228 odebug << "Could not read from format chunk." << oendl; 228 owarn << "Could not read from format chunk." << oendl;
229 return -1; 229 return -1;
230 } else { 230 } else {
231 wavSampleRate = samplerrate; 231 wavSampleRate = samplerrate;
232 // sampleRate = samplerrate; 232 // sampleRate = samplerrate;
233 odebug << "File has samplerate of " << (int) samplerrate << "" << oendl; 233 owarn << "File has samplerate of " << (int) samplerrate << "" << oendl;
234 } 234 }
235 lseek(fd, 6, SEEK_CUR); 235 lseek(fd, 6, SEEK_CUR);
236 if (read(fd, &bitrate, 2) < 2) { 236 if (read(fd, &bitrate, 2) < 2) {
237 odebug << "Could not read format chunk." << oendl; 237 owarn << "Could not read format chunk." << oendl;
238 return -1; 238 return -1;
239 } else { 239 } else {
240 wavResolution=bitrate; 240 wavResolution=bitrate;
241 // resolution = bitrate; 241 // resolution = bitrate;
242 odebug << "File has bitrate of " << bitrate << "" << oendl; 242 owarn << "File has bitrate of " << bitrate << "" << oendl;
243 } 243 }
244 found++; 244 found++;
245 } 245 }
246 } 246 }
247 found = 0; 247 found = 0;
248 while (!found) { 248 while (!found) {
249 if (read(fd, string, 4) < 4) { 249 if (read(fd, string, 4) < 4) {
250 odebug << "Could not read from sound file." << oendl; 250 odebug << "Could not read from sound file." << oendl;
251 return -1; 251 return -1;
252 } 252 }
253 253
254 if (strncmp(string, "data", 4)) { 254 if (strncmp(string, "data", 4)) {
255 if (read(fd, &longdata, 4)<4) { 255 if (read(fd, &longdata, 4)<4) {
256 odebug << "Could not read from sound file." << oendl; 256 odebug << "Could not read from sound file." << oendl;
257 return -1; 257 return -1;
258 } 258 }
259 259
260 lseek(fd, longdata, SEEK_CUR); 260 lseek(fd, longdata, SEEK_CUR);
261 } else { 261 } else {
262 if (read(fd, &longdata, 4) < 4) { 262 if (read(fd, &longdata, 4) < 4) {
263 odebug << "Could not read from sound file." << oendl; 263 odebug << "Could not read from sound file." << oendl;
264 return -1; 264 return -1;
265 } else { 265 } else {
266 wavNumberSamples = longdata; 266 wavNumberSamples = longdata;
267 odebug << "file hase length of " << (int)longdata << "" 267 odebug << "file hase length of " << (int)longdata << ""
268 << "lasting " 268 << "lasting "
269 << (int)(( longdata / wavSampleRate) / wavChannels) / ( wavChannels*( wavResolution/8)) 269 << (int)(( longdata / wavSampleRate) / wavChannels) / ( wavChannels*( wavResolution/8))
270 << " seconds" << oendl; 270 << " seconds" << oendl;
271// wavSeconds = (( longdata / wavSampleRate) / wavChannels) / ( wavChannels*( wavResolution/8)); 271// wavSeconds = (( longdata / wavSampleRate) / wavChannels) / ( wavChannels*( wavResolution/8));
272 272
273 return longdata; 273 return longdata;
274 } 274 }
275 } 275 }
276 } 276 }
277 277
278 lseek(fd, 0, SEEK_SET); 278 lseek(fd, 0, SEEK_SET);
279 279
280 return 0; 280 return 0;
281} 281}
282 282
283QString WavFile::trackName() { 283QString WavFile::trackName() {
284 return track.name(); 284 return track.name();
285} 285}
286 286
287int WavFile::wavHandle(){ 287int WavFile::wavHandle(){
288 return track.handle(); 288 return track.handle();
289} 289}
290 290
291int WavFile::getFormat() { 291int WavFile::getFormat() {
292return wavFormat; 292return wavFormat;
293} 293}
294 294
295int WavFile::getResolution() { 295int WavFile::getResolution() {
296return wavResolution; 296return wavResolution;
297} 297}
298 298
299int WavFile::getSampleRate() { 299int WavFile::getSampleRate() {
300 return wavSampleRate; 300 return wavSampleRate;
301} 301}
302 302
303int WavFile::getNumberSamples() { 303int WavFile::getNumberSamples() {
304 return wavNumberSamples; 304 return wavNumberSamples;
305} 305}
306 306