author | llornkcor <llornkcor> | 2002-03-15 04:29:42 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-03-15 04:29:42 (UTC) |
commit | a0d6c8fdac4e8644c31d1b2e2a321131be4b57c2 (patch) (side-by-side diff) | |
tree | 319d9a01475596ccefa9765cc324485a4ce7e5aa | |
parent | 320291b5006c75e3e42ba1cbbac9639a54309553 (diff) | |
download | opie-a0d6c8fdac4e8644c31d1b2e2a321131be4b57c2.zip opie-a0d6c8fdac4e8644c31d1b2e2a321131be4b57c2.tar.gz opie-a0d6c8fdac4e8644c31d1b2e2a321131be4b57c2.tar.bz2 |
added simple 24 hr alarm features
-rw-r--r-- | noncore/tools/clock/clock.cpp | 157 | ||||
-rw-r--r-- | noncore/tools/clock/clock.h | 15 | ||||
-rw-r--r-- | noncore/tools/clock/clock.pro | 4 | ||||
-rw-r--r-- | noncore/tools/clock/setAlarm.cpp | 183 | ||||
-rw-r--r-- | noncore/tools/clock/setAlarm.h | 57 |
5 files changed, 412 insertions, 4 deletions
diff --git a/noncore/tools/clock/clock.cpp b/noncore/tools/clock/clock.cpp index ef93e11..d5d77bc 100644 --- a/noncore/tools/clock/clock.cpp +++ b/noncore/tools/clock/clock.cpp @@ -10,60 +10,72 @@ ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #include "clock.h" +#include "setAlarm.h" #include <qpe/qpeapplication.h> #include <qpe/qcopenvelope_qws.h> #include <qpe/config.h> #include <qpe/timestring.h> +#include <qpe/alarmserver.h> +#include <qpe/sound.h> +#include <qpe/resource.h> +#include <qsound.h> +#include <qtimer.h> #include <qlcdnumber.h> +#include <qslider.h> #include <qlabel.h> #include <qlayout.h> #include <qtimer.h> #include <qpushbutton.h> #include <qradiobutton.h> #include <qbuttongroup.h> #include <qpainter.h> +#include <qmessagebox.h> +#include <qdatetime.h> #include <math.h> const double deg2rad = 0.017453292519943295769; // pi/180 const int sw_prec = 2; static void toggleScreenSaver( bool on ) { QCopEnvelope e("QPE/System", "setScreenSaverMode(int)" ); e << (on ? QPEApplication::Enable: QPEApplication::DisableSuspend ); } Clock::Clock( QWidget * parent, const char * name, WFlags f ) : QVBox( parent, name , f ) { setSpacing( 4 ); setMargin( 1 ); Config config( "qpe" ); config.setGroup("Time"); ampm = config.readBoolEntry( "AMPM", TRUE ); + snoozeBtn = new QPushButton ( this); + snoozeBtn->setText( tr( "Snooze" ) ); + aclock = new AnalogClock( this ); aclock->display( QTime::currentTime() ); aclock->setLineWidth( 2 ); QHBox *hb = new QHBox( this ); hb->setMargin( 0 ); QWidget *space = new QWidget( hb ); lcd = new QLCDNumber( hb ); lcd->setSegmentStyle( QLCDNumber::Flat ); lcd->setFrameStyle( QFrame::NoFrame ); lcd->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum ) ); lcd->setFixedHeight( 23 ); @@ -89,49 +101,82 @@ Clock::Clock( QWidget * parent, const char * name, WFlags f ) clockRB = new QRadioButton ( tr( "Clock" ), controls ); gl->addWidget( clockRB, 0, 0 ); grp->insert( clockRB ); swatchRB = new QRadioButton ( tr( "Stopwatch" ), controls ); gl->addWidget( swatchRB, 1, 0 ); grp->insert( swatchRB ); connect( grp, SIGNAL(clicked(int)), this, SLOT(modeSelect(int)) ); grp->setButton( 0 ); set = new QPushButton ( controls ); + set->setMaximumSize(50,30); gl->addWidget( set, 0, 1 ); set->setText( tr( "Start" ) ); set->setEnabled( FALSE ); grp->insert( set ); reset = new QPushButton ( controls ); gl->addWidget( reset, 1, 1 ); reset->setText( tr( "Reset" ) ); reset->setEnabled( FALSE ); grp->insert( reset ); + alarmOffBtn = new QPushButton ( controls ); + alarmOffBtn->setMaximumSize(60,30); + gl->addWidget( alarmOffBtn, 0, 2 ); + + alarmBtn = new QPushButton ( controls ); + alarmBtn->setMaximumSize(60,30); + gl->addWidget( alarmBtn, 1, 2 ); + alarmBtn->setText( tr( "Set Alarm" ) ); + connect( set, SIGNAL( pressed() ), SLOT( slotSet() ) ); connect( reset, SIGNAL( clicked() ), SLOT( slotReset() ) ); + connect( alarmBtn, SIGNAL( clicked() ), SLOT( slotSetAlarm() ) ); + connect( snoozeBtn, SIGNAL( clicked() ), SLOT( slotSnooze() ) ); + connect( alarmOffBtn, SIGNAL( clicked() ), SLOT( slotToggleAlarm() ) ); + + connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), + this, SLOT(appMessage(const QCString&, const QByteArray&)) ); + t = new QTimer( this ); connect( t, SIGNAL( timeout() ), SLOT( updateClock() ) ); t->start( 1000 ); connect( qApp, SIGNAL( timeChanged() ), SLOT( updateClock() ) ); swatch_running = FALSE; swatch_totalms = 0; connect( qApp, SIGNAL(clockChanged(bool)), this, SLOT(changeClock(bool)) ); + QString tmp = config.readEntry("clockAlarmHour", ""); + bool ok; + hour = tmp.toInt(&ok,10); + tmp = config.readEntry("clockAlarmMinute",""); + minute = tmp.toInt(&ok,10); + + if( config.readEntry("clockAlarmSet","FALSE") == "TRUE") { + alarmOffBtn->setText( tr( "Alarm On" ) ); + alarmBool=TRUE; + snoozeBtn->show(); + } else { + alarmOffBtn->setText( tr( "Alarm Off" ) ); + alarmBool=FALSE; + snoozeBtn->hide(); + } + QTimer::singleShot( 0, this, SLOT(updateClock()) ); modeSelect(0); } Clock::~Clock() { toggleScreenSaver( true ); } void Clock::updateClock() { if ( clockRB->isChecked() ) { @@ -226,24 +271,136 @@ void Clock::modeSelect( int m ) if ( !swatch_running ) t->stop(); } else { lcd->setNumDigits( 5 ); lcd->setMinimumWidth( lcd->sizeHint().width() ); set->setEnabled( FALSE ); reset->setEnabled( FALSE ); t->start(1000); } updateClock(); } +//this sets the alarm time +void Clock::slotSetAlarm() +{ + if( !snoozeBtn->isHidden()) + slotToggleAlarm(); + Set_Alarm *setAlarmDlg; + setAlarmDlg = new Set_Alarm(this,"SetAlarm", TRUE); + int result = setAlarmDlg->exec(); + if(result == 1) { + Config config( "qpe" ); + config.setGroup("Time"); + QString tmp; + hour = setAlarmDlg->Hour_Slider->value(); + minute = setAlarmDlg->Minute_Slider->value(); + snoozeTime=setAlarmDlg->SnoozeSlider->value(); + if(ampm) { + if(setAlarmDlg->Pm_RadioButton->isChecked() && hour < 12 ) + hour+=12; + } + config.writeEntry("clockAlarmHour", tmp.setNum( hour ),10); + config.writeEntry("clockAlarmMinute",tmp.setNum( minute ),10); + config.writeEntry("clockAlarmSnooze",tmp.setNum( snoozeTime ),10); + config.write(); + } +} + +void Clock::slotSnooze() +{ + bSound=FALSE; + int warn; + QTime t = QTime::currentTime(); + QDateTime whenl( when.date(), t.addSecs( snoozeTime*60)); + when=whenl; + AlarmServer::addAlarm( when, + "QPE/Application/clock", + "alarm(QDateTime,int)", warn ); + +} + +//toggles alarm on/off +void Clock::slotToggleAlarm() +{ + Config config( "qpe" ); + config.setGroup("Time"); + if(alarmBool) { + config.writeEntry("clockAlarmSet","FALSE"); + alarmOffBtn->setText( tr( "Alarm Off" ) ); + snoozeBtn->hide(); + alarmBool=FALSE; + alarmOff(); + } else { + config.writeEntry("clockAlarmSet","TRUE"); + alarmOffBtn->setText( tr( "Alarm On" ) ); + snoozeBtn->show(); + alarmBool=TRUE; + alarmOn(); + } + config.write(); +} + +void Clock::alarmOn() +{ + QDate d = QDate::currentDate(); + QTime tm((int)hour,(int)minute,0); + qDebug("Time set "+tm.toString()); + QTime t = QTime::currentTime(); + if( t > tm) + d = d.addDays(1); + int warn; + QDateTime whenl(d,tm); + when=whenl; + AlarmServer::addAlarm( when, + "QPE/Application/clock", + "alarm(QDateTime,int)", warn ); + QMessageBox::message("Note","Alarm is set for:\n"+ whenl.toString()); +} + +void Clock::alarmOff() +{ + int warn; + bSound=FALSE; + AlarmServer::deleteAlarm( when, + "QPE/Application/clock", + "alarm(QDateTime,int)", warn ); + qDebug("Alarm Off "+ when.toString()); + +} + +void Clock::appMessage(const QCString& msg, const QByteArray& data) +{ + int stopTimer = 0; + int timerStay = 5000; + bSound=TRUE; + if ( msg == "alarm(QDateTime,int)" ) { + Sound::soundAlarm(); + stopTimer = startTimer( timerStay); + } +} + +void Clock::timerEvent( QTimerEvent *e ) +{ + static int stop = 0; + if ( stop < 10 && bSound) { + Sound::soundAlarm(); + stop++; + } else { + stop = 0; + killTimer( e->timerId() ); + } +} + + QSizePolicy AnalogClock::sizePolicy() const { return QSizePolicy( QSizePolicy::Expanding, QSizePolicy::Expanding ); } void AnalogClock::drawContents( QPainter *p ) { QRect r = contentsRect(); QPoint center( r.x() + r.width() / 2, r.y() + r.height() / 2 ); QPoint l1( r.x() + r.width() / 2, r.y() + 2 ); QPoint l2( r.x() + r.width() / 2, r.y() + 8 ); diff --git a/noncore/tools/clock/clock.h b/noncore/tools/clock/clock.h index 6dbebf7..9b756b5 100644 --- a/noncore/tools/clock/clock.h +++ b/noncore/tools/clock/clock.h @@ -19,24 +19,25 @@ **********************************************************************/ #ifndef CLOCK_H #define CLOCK_H #include <qdatetime.h> #include <qvbox.h> class QLCDNumber; class QLabel; class QTimer; class QRadioButton; class QPushButton; +class QDateTime; class AnalogClock : public QFrame { Q_OBJECT public: AnalogClock( QWidget * parent = 0, const char * name = 0 ) : QFrame( parent, name ), clear(false) {} QSizePolicy sizePolicy() const; void display( const QTime& time ); @@ -50,38 +51,48 @@ private: QTime currTime; QTime prevTime; bool clear; }; class Clock : public QVBox { Q_OBJECT public: Clock( QWidget * parent = 0, const char * name = 0, WFlags f=0 ); ~Clock(); - + QDateTime when; + bool bSound; + int hour, minute, snoozeTime; private slots: void slotSet(); void slotReset(); void modeSelect(int); void updateClock(); void changeClock( bool ); + void slotSetAlarm(); + void slotSnooze(); + void slotToggleAlarm(); + void alarmOn(); + void alarmOff(); + void appMessage(const QCString& msg, const QByteArray& data); + void timerEvent( QTimerEvent *e ); private: void clearClock(); + bool alarmBool; QTimer *t; QLCDNumber *lcd; QLabel *date; QLabel *ampmLabel; - QPushButton *set, *reset; + QPushButton *set, *reset, *alarmBtn, *snoozeBtn, *alarmOffBtn; QRadioButton *clockRB, *swatchRB; AnalogClock *aclock; QTime swatch_start; int swatch_totalms; bool swatch_running; bool ampm; }; #endif diff --git a/noncore/tools/clock/clock.pro b/noncore/tools/clock/clock.pro index ec27adc..10d375f 100644 --- a/noncore/tools/clock/clock.pro +++ b/noncore/tools/clock/clock.pro @@ -1,13 +1,13 @@ TEMPLATE = app CONFIG = qt warn_on release DESTDIR = $(OPIEDIR)/bin -HEADERS = clock.h -SOURCES = clock.cpp \ +HEADERS = clock.h setAlarm.h +SOURCES = clock.cpp setAlarm.cpp \ main.cpp INCLUDEPATH += $(OPIEDIR)/include DEPENDPATH += $(OPIEDIR)/include LIBS += -lqpe INTERFACES = TARGET = clock TRANSLATIONS = ../i18n/de/clock.ts diff --git a/noncore/tools/clock/setAlarm.cpp b/noncore/tools/clock/setAlarm.cpp new file mode 100644 index 0000000..01e52f6 --- a/dev/null +++ b/noncore/tools/clock/setAlarm.cpp @@ -0,0 +1,183 @@ + /*************************************************************************** +// setAlarm.cpp - description +// ------------------- +// Created: Wed Mar 13 19:47:24 2002 +// copyright : (C) 2002 by ljp +// email : ljp@llornkcor.com +// +*************************************************************************** + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + ***************************************************************************/ + +#include "setAlarm.h" + +#include <qpe/config.h> + +#include <qpe/qpeapplication.h> +#include <qstring.h> +#include <qlabel.h> +#include <qlcdnumber.h> +#include <qpushbutton.h> +#include <qradiobutton.h> +#include <qslider.h> +#include <qlayout.h> +#include <qvariant.h> +#include <qtooltip.h> +#include <qwhatsthis.h> +#include <qbuttongroup.h> + +Set_Alarm::Set_Alarm( QWidget* parent, const char* name, bool modal, WFlags fl ) + : QDialog( parent, name, modal, fl ) +{ + if ( !name ) + setName( "Set_Alarm" ); + resize( 240, 101 ); + setMaximumSize( QSize( 240, 320 ) ); + setCaption( tr( "Set Alarm" ) ); + connect( qApp,SIGNAL( aboutToQuit()),SLOT( cleanUp()) ); + + Set_AlarmLayout = new QGridLayout( this ); + Set_AlarmLayout->setSpacing( 6 ); + Set_AlarmLayout->setMargin( 11 ); + + TextLabel1 = new QLabel( this, "TextLabel1" ); + TextLabel1->setText( tr( "Hour" ) ); + + Set_AlarmLayout->addWidget( TextLabel1, 0, 0 ); + + TextLabel2 = new QLabel( this, "TextLabel2" ); + TextLabel2->setText( tr( "Minute" ) ); + + Set_AlarmLayout->addMultiCellWidget( TextLabel2, 0, 0, 1, 2 ); + + Hour_Slider = new QSlider( this, "Hour_Slider" ); + Hour_Slider->setPageStep( 1); + Hour_Slider->setOrientation( QSlider::Horizontal ); + connect(Hour_Slider, SIGNAL( valueChanged(int)),this,SLOT(slotChangeHour(int))); + + Set_AlarmLayout->addWidget( Hour_Slider, 2, 0 ); + + Hour_LCDNumber = new QLCDNumber( this, "Hour_LCDNumber" ); + Hour_LCDNumber->setFrameShape( QLCDNumber::Box ); + Hour_LCDNumber->setFrameShadow( QLCDNumber::Plain ); + Hour_LCDNumber->setSegmentStyle( QLCDNumber::Flat ); + + Set_AlarmLayout->addWidget( Hour_LCDNumber, 1, 0 ); + + Minute_Slider = new QSlider( this, "Minute_Slider" ); + Minute_Slider->setMaxValue( 59); + Minute_Slider->setOrientation( QSlider::Horizontal ); + connect(Minute_Slider, SIGNAL( valueChanged(int)),this,SLOT(slotChangeMinute(int))); + + Set_AlarmLayout->addMultiCellWidget( Minute_Slider, 2, 2, 1, 2 ); + + Minute_LCDNumber = new QLCDNumber( this, "Minute_LCDNumber" ); + Minute_LCDNumber->setFrameShape( QLCDNumber::Box ); + Minute_LCDNumber->setFrameShadow( QLCDNumber::Plain ); + Minute_LCDNumber->setSegmentStyle( QLCDNumber::Flat ); + + Set_AlarmLayout->addMultiCellWidget( Minute_LCDNumber, 1, 1, 1, 2 ); + + Am_RadioButton = new QRadioButton( this, "Am_RadioButton" ); + Am_RadioButton->setText( tr( "AM" ) ); + Am_RadioButton->setChecked(TRUE); + connect( Am_RadioButton, SIGNAL(toggled(bool)),this,SLOT( amButtonToggled(bool))); + + Set_AlarmLayout->addMultiCellWidget( Am_RadioButton, 0, 1, 3, 4 ); + + + Pm_RadioButton = new QRadioButton( this, "Pm_RadioButton" ); + Pm_RadioButton->setText( tr( "PM" ) ); + connect( Pm_RadioButton, SIGNAL(toggled(bool)),this,SLOT( pmButtonToggled(bool))); + + Set_AlarmLayout->addMultiCellWidget(Pm_RadioButton, 1, 2, 3, 4 ); + + TextLabel3 = new QLabel( this, "TextLabel3" ); + TextLabel3->setText( tr( "Snooze Delay\n(minutes)" ) ); + + Set_AlarmLayout->addMultiCellWidget( TextLabel3, 3, 3, 0, 1 ); + + Snooze_LCDNumber = new QLCDNumber( this, "Snooze_LCDNumber" ); + Snooze_LCDNumber->setFrameShape( QLCDNumber::Box ); + Snooze_LCDNumber->setFrameShadow( QLCDNumber::Plain ); + Snooze_LCDNumber->setSegmentStyle( QLCDNumber::Flat ); + + Set_AlarmLayout->addMultiCellWidget( Snooze_LCDNumber, 3, 3, 1, 2 ); + + SnoozeSlider = new QSlider( this, "SnoozeSlider" ); + SnoozeSlider->setMaxValue( 60 ); + SnoozeSlider->setOrientation( QSlider::Horizontal ); + connect(SnoozeSlider, SIGNAL( valueChanged(int)),this,SLOT(slotChangeSnooze(int))); + + Set_AlarmLayout->addMultiCellWidget( SnoozeSlider, 3, 3, 3, 4 ); + + Config config( "qpe" ); + config.setGroup("Time"); + + bool ok; + bool ampm = config.readBoolEntry( "AMPM", TRUE ); + QString alarmHour=config.readEntry("clockAlarmHour","8"); + int i_alarmHour = alarmHour.toInt(&ok,10); + QString alarmMinute=config.readEntry("clockAlarmMinute","0"); + QString snoozeTime=config.readEntry("clockAlarmSnooze","0"); + if(ampm) { + Hour_Slider->setMaxValue( 12); + Hour_Slider->setMinValue( 1); + + if( i_alarmHour > 12) { + i_alarmHour = i_alarmHour - 12; + Pm_RadioButton->setChecked(TRUE); + } + Hour_Slider->setValue( i_alarmHour); + Minute_Slider->setValue( alarmMinute.toInt(&ok,10) ); + SnoozeSlider->setValue( snoozeTime.toInt(&ok,10) ); + } else { + Hour_Slider->setMaxValue( 23); + Hour_Slider->setMinValue( 1); + Hour_Slider->setValue( i_alarmHour); + Minute_Slider->setValue( alarmMinute.toInt(&ok,10) ); + SnoozeSlider->setValue( snoozeTime.toInt(&ok,10) ); + Am_RadioButton->hide(); + Pm_RadioButton->hide(); + } + // signals and slots connections +} + +Set_Alarm::~Set_Alarm() +{ + +} + +void Set_Alarm::slotChangeHour(int hour) +{ + Hour_LCDNumber->display(hour); +} + +void Set_Alarm::slotChangeMinute(int minute) +{ + Minute_LCDNumber->display(minute); +} + +void Set_Alarm::slotChangeSnooze(int minute) +{ + Snooze_LCDNumber->display(minute); +} + +void Set_Alarm::amButtonToggled(bool b) +{ + if ( b) + Pm_RadioButton->setChecked(FALSE); +} + +void Set_Alarm::pmButtonToggled(bool b) +{ + if (b) + Am_RadioButton->setChecked(FALSE); +} + +void Set_Alarm::cleanUp() +{ +} diff --git a/noncore/tools/clock/setAlarm.h b/noncore/tools/clock/setAlarm.h new file mode 100644 index 0000000..7d63237 --- a/dev/null +++ b/noncore/tools/clock/setAlarm.h @@ -0,0 +1,57 @@ + /*************************************************************************** +// setAlarm.h - description +// ------------------- +// Created: Wed Mar 13 19:47:24 2002 +// copyright : (C) 2002 by ljp +// email : ljp@llornkcor.com +// +*************************************************************************** + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + ***************************************************************************/ + +#ifndef SET_ALARM_H +#define SET_ALARM_H + +#include <qvariant.h> +#include <qdialog.h> + +class QVBoxLayout; +class QHBoxLayout; +class QGridLayout; +class QLCDNumber; +class QLabel; +class QRadioButton; +class QSlider; +class QButtonGroup; + +class Set_Alarm : public QDialog +{ + Q_OBJECT + +public: + Set_Alarm( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); + ~Set_Alarm(); + + QLabel *TextLabel1, *TextLabel2, *TextLabel3; + QSlider *Hour_Slider, *Minute_Slider, *SnoozeSlider; + QLCDNumber *Hour_LCDNumber, *Minute_LCDNumber, *Snooze_LCDNumber; + + QRadioButton* Am_RadioButton; + + QRadioButton* Pm_RadioButton; + QButtonGroup *ButtonGroup1; +protected slots: + void slotChangeHour(int); + void slotChangeMinute(int); + void slotChangeSnooze(int); + void amButtonToggled(bool); + void pmButtonToggled(bool); + void cleanUp(); +protected: + QGridLayout* Set_AlarmLayout; +}; + +#endif // SET_ALARM_H |