-rw-r--r-- | core/applets/vmemo/vmemo.cpp | 68 | ||||
-rw-r--r-- | core/applets/vmemo/vmemo.h | 5 |
2 files changed, 39 insertions, 34 deletions
diff --git a/core/applets/vmemo/vmemo.cpp b/core/applets/vmemo/vmemo.cpp index e14d532..7e91ef0 100644 --- a/core/applets/vmemo/vmemo.cpp +++ b/core/applets/vmemo/vmemo.cpp @@ -205,17 +205,27 @@ VMemo::VMemo( QWidget *parent, const char *_name ) struct utsname name; /* check for embedix kernel running on the zaurus*/ if (uname(&name) != -1) { QString release=name.release; - if(release.find("embedix",0,TRUE) !=-1) + Config vmCfg("VMemo"); + vmCfg.setGroup("Defaults"); + + if(release.find("embedix",0,TRUE) !=-1) { + int toggleKey = vmCfg.readNumEntry("toggleKey", -1); systemZaurus=TRUE; - else { + } else { + int toggleKey = vmCfg.readNumEntry("toggleKey", 4096); +//default key for ipaq record button is Key_Escape = 4096 systemZaurus=FALSE; + } + myChannel = new QCopChannel( "QPE/VMemo", this ); connect( myChannel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); -// // Register the REC key press, for ipaq only + if( toggleKey != -1 ) { QCopEnvelope e("QPE/Desktop", "keyRegister(int key, QString channel, QString message)"); - e << 4096; +// e << 4096; // Key_Escape +// e << Key_F5; //4148 + e << toggleKey; e << QString("QPE/VMemo"); e << QString("toggleRecord()"); } @@ -230,10 +240,13 @@ void VMemo::receive( const QCString &msg, const QByteArray &data ) { QDataStream stream( data, IO_ReadOnly ); if (msg == "toggleRecord()") { - if (recording) - mouseReleaseEvent(NULL); - else - mousePressEvent(NULL); + if (recording) { + fromToggle = TRUE; + stopRecording(); + } else { + fromToggle = TRUE; + startRecording(); + } } } @@ -243,23 +256,20 @@ void VMemo::paintEvent( QPaintEvent* ) p.drawPixmap( 0, 1,( const char** ) vmemo_xpm ); } -void VMemo::mousePressEvent( QMouseEvent *me ) +void VMemo::mousePressEvent( QMouseEvent * ) { - // just to be safe - if (recording) { - recording = FALSE; - return; + startRecording(); } - /* - No mousePress/mouseRelease recording on the iPAQ. The REC button on the iPAQ calls these functions - mousePressEvent and mouseReleaseEvent with a NULL parameter. - */ -// #if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) -// if (!systemZaurus ) -// return; -// #endif +void VMemo::mouseReleaseEvent( QMouseEvent * ) +{ + stopRecording(); +} + +bool VMemo::startRecording() { + if ( recording) + return FALSE;; Config config( "Sound" ); config.setGroup( "System" ); useAlerts = config.readBoolEntry("Alert"); @@ -276,7 +286,7 @@ void VMemo::mousePressEvent( QMouseEvent *me ) if (openDSP() == -1) { QMessageBox::critical(0, "VMemo", "Could not open dsp device.\n"+errorMsg, "Abort"); recording = FALSE; - return; + return FALSE; } Config vmCfg("VMemo"); @@ -297,12 +307,6 @@ void VMemo::mousePressEvent( QMouseEvent *me ) qDebug("filename will be "+fileName); if( fileName.right(1).find('/') == -1) fileName+="/"; - -// if(systemZaurus) -// fileName=vmCfg.readEntry("Dir", "/mnt/cf/"); // zaurus does not have /mnt/ramfs -// else -// fileName=vmCfg.readEntry("Dir", "/mnt/ramfs/"); - fName = "vm_"+ dt.toString()+ ".wav"; fileName+=fName; @@ -318,7 +322,7 @@ void VMemo::mousePressEvent( QMouseEvent *me ) err += fileName; QMessageBox::critical(0, "VMemo", err, "Abort"); close(dsp); - return; + return FALSE; } QArray<int> cats(1); @@ -334,10 +338,10 @@ void VMemo::mousePressEvent( QMouseEvent *me ) l.writeLink(); record(); + return TRUE; } -void VMemo::mouseReleaseEvent( QMouseEvent * ) -{ +void VMemo::stopRecording() { recording = FALSE; } @@ -479,7 +483,7 @@ void VMemo::record(void) qApp->processEvents(); } - } else { + } else { // this is specific for ipaqs that do not have 8 bit capabilities signed short sound[512], monoBuffer[512]; diff --git a/core/applets/vmemo/vmemo.h b/core/applets/vmemo/vmemo.h index 3972877..701663f 100644 --- a/core/applets/vmemo/vmemo.h +++ b/core/applets/vmemo/vmemo.h @@ -37,14 +37,15 @@ public slots: void mousePressEvent( QMouseEvent * ); void mouseReleaseEvent( QMouseEvent * ); void receive( const QCString &msg, const QByteArray &data ); - + bool startRecording(); + void stopRecording(); private: bool useAlerts; void paintEvent( QPaintEvent* ); int openDSP(); int openWAV(const char *filename); - + bool fromToggle; QPixmap vmemoPixmap; QCopChannel *myChannel; bool systemZaurus; |