summaryrefslogtreecommitdiff
path: root/core/applets/vmemo/vmemo.cpp
Unidiff
Diffstat (limited to 'core/applets/vmemo/vmemo.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/vmemo/vmemo.cpp178
1 files changed, 91 insertions, 87 deletions
diff --git a/core/applets/vmemo/vmemo.cpp b/core/applets/vmemo/vmemo.cpp
index 622b1df..1ead4dd 100644
--- a/core/applets/vmemo/vmemo.cpp
+++ b/core/applets/vmemo/vmemo.cpp
@@ -212,17 +212,18 @@ VMemo::VMemo( QWidget *parent, const char *_name )
212 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 212 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
213 213
214 odebug << "toggleKey " << toggleKey << "" << oendl; 214 odebug << "toggleKey " << toggleKey << "" << oendl;
215 if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) 215
216 systemZaurus=TRUE; 216// if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" ))
217 else 217// systemZaurus=TRUE;
218 systemZaurus=FALSE; 218// else
219 systemZaurus = FALSE;
219 220
220 myChannel = new QCopChannel( "QPE/VMemo", this ); 221 myChannel = new QCopChannel( "QPE/VMemo", this );
221 connect( myChannel, SIGNAL(received(const QCString&,const QByteArray&)), 222 connect( myChannel, SIGNAL(received(const QCString&,const QByteArray&)),
222 this, SLOT(receive(const QCString&,const QByteArray&)) ); 223 this, SLOT(receive(const QCString&,const QByteArray&)) );
223 224
224 if( toggleKey != -1 ) { 225 if( toggleKey != -1 ) {
225 // keyRegister(key, channel, message) 226 qDebug("Register key %d", toggleKey);
226 QCopEnvelope e("QPE/Launcher", "keyRegister(int,QCString,QCString)"); 227 QCopEnvelope e("QPE/Launcher", "keyRegister(int,QCString,QCString)");
227 // e << 4096; // Key_Escape 228 // e << 4096; // Key_Escape
228 // e << Key_F5; //4148 229 // e << Key_F5; //4148
@@ -231,11 +232,11 @@ VMemo::VMemo( QWidget *parent, const char *_name )
231 e << QString("toggleRecord()"); 232 e << QString("toggleRecord()");
232 } 233 }
233 if(toggleKey == 1) 234 if(toggleKey == 1)
234 usingIcon=TRUE; 235 usingIcon = TRUE;
235 else 236 else
236 usingIcon=FALSE; 237 usingIcon = FALSE;
237 if( vmCfg.readNumEntry("hideIcon",0) == 1) 238// if( vmCfg.readNumEntry("hideIcon",0) == 1)
238 hide(); 239// hide();
239 recording = FALSE; 240 recording = FALSE;
240 // } 241 // }
241} 242}
@@ -249,7 +250,7 @@ int VMemo::position()
249} 250}
250 251
251void VMemo::receive( const QCString &msg, const QByteArray &data ) { 252void VMemo::receive( const QCString &msg, const QByteArray &data ) {
252 odebug << "receive" << oendl; 253 odebug << "Vmemo receive" << oendl;
253 QDataStream stream( data, IO_ReadOnly ); 254 QDataStream stream( data, IO_ReadOnly );
254 255
255 if (msg == "toggleRecord()") { 256 if (msg == "toggleRecord()") {
@@ -328,10 +329,10 @@ bool VMemo::startRecording() {
328 fileName="/"+fileName; 329 fileName="/"+fileName;
329 if( fileName.right(1).find('/') == -1) 330 if( fileName.right(1).find('/') == -1)
330 fileName+="/"; 331 fileName+="/";
331 fName = "vm_"+ date+ ".wav"; 332 fName = "vm_"+ date + ".wav";
332 333
333 fileName+=fName; 334 fileName+=fName;
334 odebug << "filename is "+fileName << oendl; 335 odebug << "filename is " + fileName << oendl;
335// open tmp file here 336// open tmp file here
336 char *pointer; 337 char *pointer;
337 pointer=tmpnam(NULL); 338 pointer=tmpnam(NULL);
@@ -385,8 +386,8 @@ void VMemo::stopRecording() {
385 t_timer->stop(); 386 t_timer->stop();
386 Config cfg("Vmemo"); 387 Config cfg("Vmemo");
387 cfg.setGroup("Defaults"); 388 cfg.setGroup("Defaults");
388 if( cfg.readNumEntry("hideIcon",0) == 1 ) 389// if( cfg.readNumEntry("hideIcon",0) == 1 )
389 hide(); 390// hide();
390} 391}
391 392
392int VMemo::openDSP() { 393int VMemo::openDSP() {
@@ -483,16 +484,16 @@ int VMemo::openWAV(const char *filename) {
483} 484}
484 485
485bool VMemo::record() { 486bool VMemo::record() {
486 length=0; 487 length = 0;
487 int result, value; 488 int result, value;
488 QString msg; 489 QString msg;
489 msg.sprintf("Recording format %d", format); 490 msg.sprintf("Recording format %d", format);
490 odebug << msg << oendl; 491 odebug << msg << oendl;
491 Config config("Vmemo"); 492 Config config("Vmemo");
492 config.setGroup("Record"); 493 config.setGroup("Record");
493 int sRate=config.readNumEntry("SizeLimit", 30); 494 int sRate=config.readNumEntry("SizeLimit", 30);
494 if(sRate > 0) 495 if(sRate > 0)
495 t_timer->start( sRate * 1000+1000, TRUE); 496 t_timer->start( sRate * 1000+1000, TRUE);
496 497
497// if(systemZaurus) { 498// if(systemZaurus) {
498// } else { // 16 bit only capabilities 499// } else { // 16 bit only capabilities
@@ -500,105 +501,108 @@ bool VMemo::record() {
500 msg.sprintf("Recording format other"); 501 msg.sprintf("Recording format other");
501 odebug << msg << oendl; 502 odebug << msg << oendl;
502 503
503 int bufsize=1024; 504
504 int bytesWritten=0; 505 int bytesWritten = 0;
505 signed short sound[1024], monoBuffer[1024]; 506
506 char abuf[bufsize/2];
507 short sbuf[bufsize];
508 Config vmCfg("Vmemo"); 507 Config vmCfg("Vmemo");
509 vmCfg.setGroup("Defaults"); 508 vmCfg.setGroup("Defaults");
510 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 509 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
511 510
511 int bufsize = vmCfg.readNumEntry("BufferSize",1024);
512 signed short sound[bufsize], monoBuffer[bufsize];
513 char abuf[bufsize / 2];
514 short sbuf[bufsize];
515
512 while(recording) { 516 while(recording) {
513 517
514 if(useADPCM) 518 if(useADPCM)
515 result = read( dsp, sbuf, bufsize); // 8192 519 result = ::read(dsp, sbuf, bufsize); // 8192
516 else 520 else
517 result = read(dsp, sound, 1024); // 8192 521 result = ::read(dsp, sound, bufsize); // 8192
518 if( result <= 0) { 522 if( result <= 0) {
519 perror("recording error "); 523 perror("recording error ");
520// odebug << currentFileName << oendl; 524// odebug << currentFileName << oendl;
521 QMessageBox::message(tr("Note"),tr("error recording")); 525 QMessageBox::message(tr("Note"),tr("error recording"));
522 recording=FALSE; 526 recording = FALSE;
523 break; 527 break;
524 return FALSE; 528 return FALSE;
525 } 529 }
526 530
527 if(useADPCM) { 531 if(useADPCM) {
528 adpcm_coder( sbuf, abuf, result/2, &encoder_state); 532 adpcm_coder( sbuf, abuf, result/2, &encoder_state);
529 bytesWritten = ::write(wav, abuf, result/4); 533 bytesWritten = ::write(wav, abuf, result/4);
530 534
531 } else { 535 } else {
532 for (int i = 0; i < result; i++) { //since Z is mono do normally 536// for (int i = 0; i < result; i++) { //since Z is mono do normally
533 monoBuffer[i] = sound[i]; 537// monoBuffer[i] = sound[i];
534 } 538// }
535 539
536 length+=write(wav, monoBuffer, result); 540 length += write(wav, sound, result);
537 } 541 }
538 length +=bytesWritten; 542 length += bytesWritten;
539 543
540 if(length<0) { 544 if(length<0) {
541 recording=false; 545 recording = false;
542 perror("dev/dsp's is a lookin' messy"); 546 perror("dev/dsp's is a lookin' messy");
543 QMessageBox::message("Vmemo","Error writing to file\n"+ fileName); 547 QMessageBox::message("Vmemo","Error writing to file\n"+ fileName);
544 break; 548 break;
545 return FALSE; 549 return FALSE;
546 } 550 }
547 // odebug << "" << length << "\r" << oendl; 551 // odebug << "" << length << "\r" << oendl;
548 // fflush(stdout); 552 // fflush(stdout);
549 qApp->processEvents(); 553 qApp->processEvents();
550 } 554 }
551 // qDebug("file has length of %d lasting %d seconds", 555 // qDebug("file has length of %d lasting %d seconds",
552 // length, (( length / speed) / channels) / 2 ); 556 // length, (( length / speed) / channels) / 2 );
553 // } 557 // }
554 558
555 //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>><<<<<<<<<<<<<<<<<<<<<<<<<<<<// 559 //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>><<<<<<<<<<<<<<<<<<<<<<<<<<<<//
556 560
557 value = length+36; 561 value = length + 36;
558 562
559 lseek(wav, 4, SEEK_SET); 563 lseek(wav, 4, SEEK_SET);
560 write(wav, &value, 4); 564 write(wav, &value, 4);
561 lseek(wav, 40, SEEK_SET); 565 lseek(wav, 40, SEEK_SET);
562 566
563 write(wav, &length, 4); 567 write(wav, &length, 4);
564 568
565 track.close(); 569 track.close();
566 odebug << "Track closed" << oendl; 570 odebug << "Track closed" << oendl;
567 571
568 if( ioctl( dsp, SNDCTL_DSP_RESET,0) == -1) 572 if( ioctl( dsp, SNDCTL_DSP_RESET,0) == -1)
569 perror("ioctl(\"SNDCTL_DSP_RESET\")"); 573 perror("ioctl(\"SNDCTL_DSP_RESET\")");
570 574
571 ::close(dsp); 575 ::close(dsp);
572 576
573 Config cfgO("OpieRec"); 577 Config cfgO("OpieRec");
574 cfgO.setGroup("Sounds"); 578 cfgO.setGroup("Sounds");
575 579
576 int nFiles = cfgO.readNumEntry( "NumberofFiles",0); 580 int nFiles = cfgO.readNumEntry( "NumberofFiles",0);
577 581
578 QString currentFileName = fileName; 582 QString currentFileName = fileName;
579 QString currentFile = "vm_"+ date; 583 QString currentFile = "vm_"+ date;
580 584
581 float numberOfRecordedSeconds=(float) length / (float)speed * (float)2; 585 float numberOfRecordedSeconds=(float) length / (float)speed * (float)2;
582 586
583 cfgO.writeEntry( "NumberofFiles", nFiles + 1); 587 cfgO.writeEntry( "NumberofFiles", nFiles + 1);
584 cfgO.writeEntry( QString::number( nFiles + 1), currentFile); 588 cfgO.writeEntry( QString::number( nFiles + 1), currentFile);
585 cfgO.writeEntry( currentFile, currentFileName); 589 cfgO.writeEntry( currentFile, currentFileName);
586 590
587 QString time; 591 QString time;
588 time.sprintf("%.2f", numberOfRecordedSeconds); 592 time.sprintf("%.2f", numberOfRecordedSeconds);
589 cfgO.writeEntry( currentFileName, time ); 593 cfgO.writeEntry( currentFileName, time );
590 // odebug << "writing config numberOfRecordedSeconds "+time << oendl; 594 // odebug << "writing config numberOfRecordedSeconds "+time << oendl;
591 595
592 cfgO.write(); 596 cfgO.write();
593 597
594 odebug << "done recording "+fileName << oendl; 598 odebug << "done recording "+fileName << oendl;
595 599
596 Config cfg("qpe"); 600 Config cfg("qpe");
597 cfg.setGroup("Volume"); 601 cfg.setGroup("Volume");
598 QString foo = cfg.readEntry("Mute","TRUE"); 602 QString foo = cfg.readEntry("Mute","TRUE");
599 if(foo.find("TRUE",0,TRUE) != -1) 603 if(foo.find("TRUE",0,TRUE) != -1)
600 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << TRUE; //mute 604 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << TRUE; //mute
601return TRUE; 605 return TRUE;
602} 606}
603 607
604int VMemo::setToggleButton(int tog) { 608int VMemo::setToggleButton(int tog) {