-rw-r--r-- | core/applets/vmemo/vmemo.cpp | 116 | ||||
-rw-r--r-- | core/applets/vmemo/vmemo.h | 5 |
2 files changed, 63 insertions, 58 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 @@ -196,71 +196,81 @@ static char * vmemo_xpm[] = { VMemo::VMemo( QWidget *parent, const char *_name ) : QWidget( parent, _name ) { - setFixedHeight( 18 ); - setFixedWidth( 14 ); + setFixedHeight( 18 ); + setFixedWidth( 14 ); - recording = FALSE; + recording = FALSE; - 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) - systemZaurus=TRUE; - else { - 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 - QCopEnvelope e("QPE/Desktop", "keyRegister(int key, QString channel, QString message)"); - e << 4096; - e << QString("QPE/VMemo"); - e << QString("toggleRecord()"); - } - } + struct utsname name; /* check for embedix kernel running on the zaurus*/ + if (uname(&name) != -1) { + QString release=name.release; + Config vmCfg("VMemo"); + vmCfg.setGroup("Defaults"); + + if(release.find("embedix",0,TRUE) !=-1) { + int toggleKey = vmCfg.readNumEntry("toggleKey", -1); + systemZaurus=TRUE; + } 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&)) ); + + if( toggleKey != -1 ) { + QCopEnvelope e("QPE/Desktop", "keyRegister(int key, QString channel, QString message)"); +// e << 4096; // Key_Escape +// e << Key_F5; //4148 + e << toggleKey; + e << QString("QPE/VMemo"); + e << QString("toggleRecord()"); + } + } } VMemo::~VMemo() { } void VMemo::receive( const QCString &msg, const QByteArray &data ) { - QDataStream stream( data, IO_ReadOnly ); - if (msg == "toggleRecord()") { - if (recording) - mouseReleaseEvent(NULL); - else - mousePressEvent(NULL); - } + QDataStream stream( data, IO_ReadOnly ); + if (msg == "toggleRecord()") { + if (recording) { + fromToggle = TRUE; + stopRecording(); + } else { + fromToggle = TRUE; + startRecording(); + } + } } void VMemo::paintEvent( QPaintEvent* ) { QPainter p(this); 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(); +} + +void VMemo::mouseReleaseEvent( QMouseEvent * ) +{ + stopRecording(); +} + +bool VMemo::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 - + if ( recording) + return FALSE;; Config config( "Sound" ); config.setGroup( "System" ); useAlerts = config.readBoolEntry("Alert"); @@ -275,19 +285,19 @@ void VMemo::mousePressEvent( QMouseEvent *me ) recording = TRUE; if (openDSP() == -1) { QMessageBox::critical(0, "VMemo", "Could not open dsp device.\n"+errorMsg, "Abort"); recording = FALSE; - return; + return FALSE; } Config vmCfg("VMemo"); vmCfg.setGroup("Defaults"); QDateTime dt = QDateTime::currentDateTime(); QString fName; - Config cfg( "Sound" ); - cfg.setGroup( "System" ); + Config cfg( "Sound" ); + cfg.setGroup( "System" ); fName = QPEApplication::documentDir() ; fileName = cfg.readEntry("RecLocation", fName); int s; @@ -296,14 +306,8 @@ void VMemo::mousePressEvent( QMouseEvent *me ) fileName=fileName.right(fileName.length()-s-2); 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; qDebug("filename is "+fileName); @@ -317,9 +321,9 @@ void VMemo::mousePressEvent( QMouseEvent *me ) QString err("Could not open the output file\n"); err += fileName; QMessageBox::critical(0, "VMemo", err, "Abort"); close(dsp); - return; + return FALSE; } QArray<int> cats(1); cats[0] = vmCfg.readNumEntry("Category", 0); @@ -333,12 +337,12 @@ void VMemo::mousePressEvent( QMouseEvent *me ) l.setCategories(cats); l.writeLink(); record(); + return TRUE; } -void VMemo::mouseReleaseEvent( QMouseEvent * ) -{ +void VMemo::stopRecording() { recording = FALSE; } int VMemo::openDSP() @@ -478,9 +482,9 @@ 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]; while(recording) { 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 @@ -36,16 +36,17 @@ public slots: void record(); 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; int dsp, wav, rate, speed, channels, format, resolution; |