summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/tools/clock/clock.cpp429
-rw-r--r--noncore/tools/clock/clock.h15
2 files changed, 250 insertions, 194 deletions
diff --git a/noncore/tools/clock/clock.cpp b/noncore/tools/clock/clock.cpp
index 0937362..9898332 100644
--- a/noncore/tools/clock/clock.cpp
+++ b/noncore/tools/clock/clock.cpp
@@ -15,9 +15,9 @@
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20// changes added and Copyright (C) by L. J. Potter <ljp@llornkcor.com> 2002 20// changes added and Copyright (C) by L. J. Potter <ljp@llornkcor.com> 2002
21 21
22#include "clock.h" 22#include "clock.h"
23#include "setAlarm.h" 23#include "setAlarm.h"
@@ -57,13 +57,13 @@ const double deg2rad = 0.017453292519943295769; // pi/180
57const int sw_prec = 2; 57const int sw_prec = 2;
58 58
59void startPlayer() 59void startPlayer()
60{ 60{
61 Config config( "qpe" ); 61 Config config( "qpe" );
62 config.setGroup( "Time" ); 62 config.setGroup( "Time" );
63 sleep(15); 63 sleep(15);
64 QCopEnvelope e( "QPE/Application/opieplayer", "setDocument(QString)" ); 64 QCopEnvelope e( "QPE/Application/opieplayer", "setDocument(QString)" );
65 e << config.readEntry( "mp3File", "" ); 65 e << config.readEntry( "mp3File", "" );
66} 66}
67 67
68 68
69static void toggleScreenSaver( bool on ) 69static void toggleScreenSaver( bool on )
@@ -77,12 +77,8 @@ Clock::Clock( QWidget * parent, const char * name, WFlags f )
77{ 77{
78 setSpacing( 4 ); 78 setSpacing( 4 );
79 setMargin( 1 ); 79 setMargin( 1 );
80 80
81 Config config( "qpe" );
82 config.setGroup( "Time" );
83 ampm = config.readBoolEntry( "AMPM", TRUE );
84
85 81
86 snoozeBtn = new QPushButton ( this ); 82 snoozeBtn = new QPushButton ( this );
87 snoozeBtn->setText( tr( "Snooze" ) ); 83 snoozeBtn->setText( tr( "Snooze" ) );
88 84
@@ -127,43 +123,35 @@ Clock::Clock( QWidget * parent, const char * name, WFlags f )
127 123
128 connect( grp, SIGNAL( clicked( int ) ), this, SLOT( modeSelect( int ) ) ); 124 connect( grp, SIGNAL( clicked( int ) ), this, SLOT( modeSelect( int ) ) );
129 grp->setButton( 0 ); 125 grp->setButton( 0 );
130 126
131 set 127 set = new QPushButton ( controls );
132 = new QPushButton ( controls ); 128 set->setMaximumSize( 50, 30 );
133 set 129 gl->addWidget( set , 0, 1 );
134 ->setMaximumSize( 50, 30 ); 130 set->setText( tr( "Start" ) );
135 gl->addWidget( set 131 set->setEnabled( FALSE );
136 , 0, 1 ); 132 grp->insert( set );
137 set
138 ->setText( tr( "Start" ) );
139 set
140 ->setEnabled( FALSE );
141 grp->insert( set
142 );
143 133
144 reset = new QPushButton ( controls ); 134 reset = new QPushButton ( controls );
145 gl->addWidget( reset, 1, 1 ); 135 gl->addWidget( reset, 1, 1 );
146 reset->setText( tr( "Reset" ) ); 136 reset->setText( tr( "Reset" ) );
147 reset->setEnabled( FALSE ); 137 reset->setEnabled( FALSE );
148 grp->insert( reset ); 138 grp->insert( reset );
149 139
150 alarmOffBtn = new QPushButton ( controls ); 140 alarmOffBtn = new QPushButton ( controls );
151 // alarmOffBtn->setMaximumSize(60,30);
152 gl->addWidget( alarmOffBtn, 0, 2 ); 141 gl->addWidget( alarmOffBtn, 0, 2 );
153 142
154 alarmBtn = new QPushButton ( controls ); 143 alarmBtn = new QPushButton ( controls );
155 // alarmBtn->setMaximumSize(60,30);
156 gl->addWidget( alarmBtn, 1, 2 ); 144 gl->addWidget( alarmBtn, 1, 2 );
145
157 alarmBtn->setText( tr( "Set Alarm" ) ); 146 alarmBtn->setText( tr( "Set Alarm" ) );
158 147
159 OClickableLabel *click = new OClickableLabel( controls, "label" ); 148 OClickableLabel *click = new OClickableLabel( controls, "label" );
160 click->setText( tr( "Set date and time." ) ); 149 click->setText( tr( "Set date and time." ) );
161 gl->addMultiCellWidget( click, 3, 3, 0, 2, AlignHCenter ); 150 gl->addMultiCellWidget( click, 3, 3, 0, 2, AlignHCenter );
162 connect( click, SIGNAL( clicked() ), this, SLOT( slotAdjustTime() ) ); 151 connect( click, SIGNAL( clicked() ), this, SLOT( slotAdjustTime() ) );
163 152
164 connect( set 153 connect( set , SIGNAL( pressed() ), SLOT( slotSet() ) );
165 , SIGNAL( pressed() ), SLOT( slotSet() ) );
166 connect( reset, SIGNAL( clicked() ), SLOT( slotReset() ) ); 154 connect( reset, SIGNAL( clicked() ), SLOT( slotReset() ) );
167 155
168 connect( alarmBtn, SIGNAL( clicked() ), SLOT( slotSetAlarm() ) ); 156 connect( alarmBtn, SIGNAL( clicked() ), SLOT( slotSetAlarm() ) );
169 connect( snoozeBtn, SIGNAL( clicked() ), SLOT( slotSnooze() ) ); 157 connect( snoozeBtn, SIGNAL( clicked() ), SLOT( slotSnooze() ) );
@@ -182,27 +170,38 @@ Clock::Clock( QWidget * parent, const char * name, WFlags f )
182 swatch_totalms = 0; 170 swatch_totalms = 0;
183 171
184 connect( qApp, SIGNAL( clockChanged( bool ) ), this, SLOT( changeClock( bool ) ) ); 172 connect( qApp, SIGNAL( clockChanged( bool ) ), this, SLOT( changeClock( bool ) ) );
185 173
174
175 Config config( "qpe" );
176 config.setGroup( "Time" );
177 ampm = config.readBoolEntry( "AMPM", TRUE );
178
186 QString tmp = config.readEntry( "clockAlarmHour", "" ); 179 QString tmp = config.readEntry( "clockAlarmHour", "" );
187 bool ok; 180 bool ok;
188 hour = tmp.toInt( &ok, 10 ); 181 hour = tmp.toInt( &ok, 10 );
189 tmp = config.readEntry( "clockAlarmMinute", "" ); 182 tmp = config.readEntry( "clockAlarmMinute", "" );
190 minute = tmp.toInt( &ok, 10 ); 183 minute = tmp.toInt( &ok, 10 );
191 184
192 if ( config.readEntry( "clockAlarmSet", "FALSE" ) == "TRUE" ) { 185 if ( config.readEntry( "clockAlarmSet", "FALSE" ) == "TRUE" )
193 alarmOffBtn->setText( tr( "Alarm Is On" ) ); 186 {
194 alarmBool = TRUE; 187 alarmOffBtn->setText( tr( "Alarm Is On" ) );
195 snoozeBtn->show(); 188 alarmBool = TRUE;
196 } 189 snoozeBtn->show();
197 else { 190 }
198 alarmOffBtn->setText( tr( "Alarm Is Off" ) ); 191 else
199 alarmBool = FALSE; 192 {
200 snoozeBtn->hide(); 193 alarmOffBtn->setText( tr( "Alarm Is Off" ) );
201 } 194 alarmBool = FALSE;
195 snoozeBtn->hide();
196 }
202 197
203 QTimer::singleShot( 0, this, SLOT( updateClock() ) ); 198 QTimer::singleShot( 0, this, SLOT( updateClock() ) );
204 modeSelect( 0 ); 199
200 Config cfg( "Clock" );
201 cfg.setGroup( "Mode" );
202 int mode = cfg.readBoolEntry( "clockMode");setSwatchMode( mode);
203 modeSelect( mode);
205} 204}
206 205
207Clock::~Clock() 206Clock::~Clock()
208{ 207{
@@ -210,45 +209,49 @@ Clock::~Clock()
210} 209}
211 210
212void Clock::updateClock() 211void Clock::updateClock()
213{ 212{
214 if ( clockRB->isChecked() ) { 213 if ( clockRB->isChecked() )
215 QTime tm = QDateTime::currentDateTime().time(); 214 {
216 QString s; 215 QTime tm = QDateTime::currentDateTime().time();
217 if ( ampm ) { 216 QString s;
218 int hour = tm.hour(); 217 if ( ampm )
219 if ( hour == 0 ) 218 {
220 hour = 12; 219 int hour = tm.hour();
221 if ( hour > 12 ) 220 if ( hour == 0 )
222 hour -= 12; 221 hour = 12;
223 s.sprintf( "%2d%c%02d", hour, ':', tm.minute() ); 222 if ( hour > 12 )
224 ampmLabel->setText( ( tm.hour() >= 12 ) ? "PM" : "AM" ); 223 hour -= 12;
225 ampmLabel->show(); 224 s.sprintf( "%2d%c%02d", hour, ':', tm.minute() );
226 } 225 ampmLabel->setText( ( tm.hour() >= 12 ) ? "PM" : "AM" );
227 else { 226 ampmLabel->show();
228 s.sprintf( "%2d%c%02d", tm.hour(), ':', tm.minute() ); 227 }
229 ampmLabel->hide(); 228 else
230 } 229 {
231 lcd->display( s ); 230 s.sprintf( "%2d%c%02d", tm.hour(), ':', tm.minute() );
232 lcd->repaint( FALSE ); 231 ampmLabel->hide();
233 aclock->display( QTime::currentTime() ); 232 }
234 date->setText( TimeString::longDateString( QDate::currentDate() ) ); 233 lcd->display( s );
235 } 234 lcd->repaint( FALSE );
236 else { 235 aclock->display( QTime::currentTime() );
237 QTime swatch_time; 236 date->setText( TimeString::longDateString( QDate::currentDate() ) );
238 QString lcdtext; 237 }
239 int totalms = swatch_totalms; 238 else
240 if ( swatch_running ) 239 {
241 totalms += swatch_start.elapsed(); 240 QTime swatch_time;
242 swatch_time = QTime( 0, 0, 0 ).addMSecs( totalms ); 241 QString lcdtext;
243 QString d = swatch_running ? QString( " " ) 242 int totalms = swatch_totalms;
244 : QString::number( totalms % 1000 + 1000 ); 243 if ( swatch_running )
245 lcdtext = swatch_time.toString() + "." + d.right( 3 ).left( sw_prec ); 244 totalms += swatch_start.elapsed();
246 lcd->display( lcdtext ); 245 swatch_time = QTime( 0, 0, 0 ).addMSecs( totalms );
247 lcd->repaint( FALSE ); 246 QString d = swatch_running ? QString( " " )
248 aclock->display( swatch_time ); 247 : QString::number( totalms % 1000 + 1000 );
249 date->setText( TimeString::longDateString( QDate::currentDate() ) ); 248 lcdtext = swatch_time.toString() + "." + d.right( 3 ).left( sw_prec );
250 } 249 lcd->display( lcdtext );
250 lcd->repaint( FALSE );
251 aclock->display( swatch_time );
252 date->setText( TimeString::longDateString( QDate::currentDate() ) );
253 }
251} 254}
252 255
253void Clock::changeClock( bool a ) 256void Clock::changeClock( bool a )
254{ 257{
@@ -263,26 +266,26 @@ void Clock::clearClock( void )
263} 266}
264 267
265void Clock::slotSet() 268void Clock::slotSet()
266{ 269{
267 if ( t->isActive() ) { 270 if ( t->isActive() )
268 swatch_totalms += swatch_start.elapsed(); 271 {
269 set 272 swatch_totalms += swatch_start.elapsed();
270 ->setText( tr( "Start" ) ); 273 set->setText( tr( "Start" ) );
271 t->stop(); 274 t->stop();
272 swatch_running = FALSE; 275 swatch_running = FALSE;
273 toggleScreenSaver( TRUE ); 276 toggleScreenSaver( TRUE );
274 updateClock(); 277 updateClock();
275 } 278 }
276 else { 279 else
277 swatch_start.start(); 280 {
278 set 281 swatch_start.start();
279 ->setText( tr( "Stop" ) ); 282 set->setText( tr( "Stop" ) );
280 t->start( 1000 ); 283 t->start( 1000 );
281 swatch_running = TRUE; 284 swatch_running = TRUE;
282 // disable screensaver while stop watch is running 285 // disable screensaver while stop watch is running
283 toggleScreenSaver( FALSE ); 286 toggleScreenSaver( FALSE );
284 } 287 }
285} 288}
286 289
287void Clock::slotReset() 290void Clock::slotReset()
288{ 291{
@@ -297,27 +300,32 @@ void Clock::slotReset()
297} 300}
298 301
299void Clock::modeSelect( int m ) 302void Clock::modeSelect( int m )
300{ 303{
301 if ( m ) { 304 qDebug("Clock::modeSelect( %d) ", m);
302 lcd->setNumDigits( 8 + 1 + sw_prec ); 305 if ( m )
303 lcd->setMinimumWidth( lcd->sizeHint().width() ); 306 {
304 set 307 lcd->setNumDigits( 8 + 1 + sw_prec );
305 ->setEnabled( TRUE ); 308 lcd->setMinimumWidth( lcd->sizeHint().width() );
306 reset->setEnabled( TRUE ); 309 set->setEnabled( TRUE );
307 ampmLabel->hide(); 310 reset->setEnabled( TRUE );
308 311 ampmLabel->hide();
309 if ( !swatch_running ) 312
310 t->stop(); 313 if ( !swatch_running )
311 } 314 t->stop();
312 else { 315 }
313 lcd->setNumDigits( 5 ); 316 else
314 lcd->setMinimumWidth( lcd->sizeHint().width() ); 317 {
315 set 318 lcd->setNumDigits( 5 );
316 ->setEnabled( FALSE ); 319 lcd->setMinimumWidth( lcd->sizeHint().width() );
317 reset->setEnabled( FALSE ); 320 set->setEnabled( FALSE );
318 t->start( 1000 ); 321 reset->setEnabled( FALSE );
319 } 322 t->start( 1000 );
323 }
324
325 Config config( "Clock" );
326 config.setGroup( "Mode" );
327 config.writeEntry( "clockMode", m );
320 updateClock(); 328 updateClock();
321} 329}
322 330
323//this sets the alarm time 331//this sets the alarm time
@@ -366,22 +374,24 @@ void Clock::slotSnooze()
366void Clock::slotToggleAlarm() 374void Clock::slotToggleAlarm()
367{ 375{
368 Config config( "qpe" ); 376 Config config( "qpe" );
369 config.setGroup( "Time" ); 377 config.setGroup( "Time" );
370 if ( alarmBool ) { 378 if ( alarmBool )
371 config.writeEntry( "clockAlarmSet", "FALSE" ); 379 {
372 alarmOffBtn->setText( tr( "Alarm Is Off" ) ); 380 config.writeEntry( "clockAlarmSet", "FALSE" );
373 snoozeBtn->hide(); 381 alarmOffBtn->setText( tr( "Alarm Is Off" ) );
374 alarmBool = FALSE; 382 snoozeBtn->hide();
375 alarmOff(); 383 alarmBool = FALSE;
376 } 384 alarmOff();
377 else { 385 }
378 config.writeEntry( "clockAlarmSet", "TRUE" ); 386 else
379 alarmOffBtn->setText( tr( "Alarm Is On" ) ); 387 {
380 snoozeBtn->show(); 388 config.writeEntry( "clockAlarmSet", "TRUE" );
381 alarmBool = TRUE; 389 alarmOffBtn->setText( tr( "Alarm Is On" ) );
382 alarmOn(); 390 snoozeBtn->show();
383 } 391 alarmBool = TRUE;
392 alarmOn();
393 }
384 config.write(); 394 config.write();
385} 395}
386 396
387void Clock::alarmOn() 397void Clock::alarmOn()
@@ -413,52 +423,52 @@ void Clock::alarmOff()
413} 423}
414 424
415void Clock::clearTimer() 425void Clock::clearTimer()
416{ 426{
417 alarmOffBtn->setText( tr( "Alarm Is Off" ) ); 427 alarmOffBtn->setText( tr( "Alarm Is Off" ) );
418 alarmBool = FALSE; 428 alarmBool = FALSE;
419 snoozeBtn->hide(); 429 snoozeBtn->hide();
420 setCaption( "Clock" ); 430 setCaption( "Clock" );
421} 431}
422 432
423void Clock::appMessage( const QCString& msg, const QByteArray& /*data*/ ) 433void Clock::appMessage( const QCString& msg, const QByteArray& /*data*/ )
424{ 434{
425 int stopTimer = 0; 435 int stopTimer = 0;
426 int timerStay = 5000; 436 int timerStay = 5000;
427 bSound = TRUE; 437 bSound = TRUE;
428 qDebug( "Message received in clock" ); 438 qDebug( "Message received in clock" );
429 if ( msg == "alarm(QDateTime,int)" ) { 439 if ( msg == "alarm(QDateTime,int)" )
430 Config config( "qpe" ); 440 {
431 config.setGroup( "Time" ); 441 Config config( "qpe" );
432 if ( config.readBoolEntry( "mp3Alarm", 0 ) ) 442 config.setGroup( "Time" );
433 { 443 if ( config.readBoolEntry( "mp3Alarm", 0 ) )
434 clearTimer(); 444 {
435// pid_t pid; 445 clearTimer();
436// switch(pid = fork()) 446 pthread_t thread;
437// { 447 pthread_create(&thread, NULL, (void * (*) (void *))startPlayer, NULL/* &*/);
438// case -1: 448
439// {//failed 449 }
440// } 450 else
441// break; 451 {
442// case 0: 452
443// {//child 453 Sound::soundAlarm();
444// QCopEnvelope e( "QPE/Application/opieplayer", "setDocument(QString)" ); 454 stopTimer = startTimer( timerStay );
445// e << config.readEntry( "mp3File", "" ); 455 }
446 pthread_t thread; 456 }
447 pthread_create(&thread, NULL, (void * (*) (void *))startPlayer, NULL/* &*/); 457
448// startPlayer(); 458 if ( msg == "timerStart()" )
449// } 459 {
450// break; 460 slotStartTimer();
451// }; 461 }
452 462 if ( msg == "timerStop()" )
453 } 463 {
454 else 464 slotStopTimer();
455 { 465 }
466 if ( msg == "timerReset()" )
467 {
468 slotResetTimer();
469 }
456 470
457 Sound::soundAlarm();
458 stopTimer = startTimer( timerStay );
459 }
460 }
461 show(); 471 show();
462 raise(); 472 raise();
463 QPEApplication::setKeepRunning(); 473 QPEApplication::setKeepRunning();
464 setActiveWindow(); 474 setActiveWindow();
@@ -466,18 +476,20 @@ void Clock::appMessage( const QCString& msg, const QByteArray& /*data*/ )
466 476
467void Clock::timerEvent( QTimerEvent *e ) 477void Clock::timerEvent( QTimerEvent *e )
468{ 478{
469 static int stop = 0; 479 static int stop = 0;
470 if ( stop < 120 && bSound ) { 480 if ( stop < 120 && bSound )
471 Sound::soundAlarm(); 481 {
472 stop++; 482 Sound::soundAlarm();
473 } 483 stop++;
474 else { 484 }
475 stop = 0; 485 else
476 killTimer( e->timerId() ); 486 {
477 clearTimer(); 487 stop = 0;
478 setCaption( tr( "Clock: Alarm was missed." ) ); 488 killTimer( e->timerId() );
479 } 489 clearTimer();
490 setCaption( tr( "Clock: Alarm was missed." ) );
491 }
480} 492}
481 493
482 494
483QSizePolicy AnalogClock::sizePolicy() const 495QSizePolicy AnalogClock::sizePolicy() const
@@ -493,33 +505,35 @@ void AnalogClock::drawContents( QPainter *p )
493 if ( r. width ( ) > r. height ( )) 505 if ( r. width ( ) > r. height ( ))
494 fr. setRect (( r. width ( ) - r. height ( )) / 2, r. y ( ), r. height ( ), r. height ( )); 506 fr. setRect (( r. width ( ) - r. height ( )) / 2, r. y ( ), r. height ( ), r. height ( ));
495 else 507 else
496 fr. setRect ( r. x ( ), ( r. height ( ) - r. width ( )) / 2, r. width ( ), r. width ( )); 508 fr. setRect ( r. x ( ), ( r. height ( ) - r. width ( )) / 2, r. width ( ), r. width ( ));
497 509
498 QPoint center = fr. center ( ); // ( fr.x() + fr.width() / 2, fr.y() + fr.height() / 2 ); 510 QPoint center = fr. center ( ); // ( fr.x() + fr.width() / 2, fr.y() + fr.height() / 2 );
499 QPoint l1 ( center. x ( ), fr. y ( ) + 2 ); 511 QPoint l1 ( center. x ( ), fr. y ( ) + 2 );
500 QPoint l2 ( center. x ( ), fr. y ( ) + 8 ); 512 QPoint l2 ( center. x ( ), fr. y ( ) + 8 );
501 513
502 514
503 515
504 if ( clear ) { 516 if ( clear )
505 erase ( r ); 517 {
506 p-> setPen ( NoPen ); 518 erase ( r );
507 p-> setBrush ( colorGroup ( ). color ( QColorGroup::Base )); 519 p-> setPen ( NoPen );
508 p-> drawEllipse ( fr ); 520 p-> setBrush ( colorGroup ( ). color ( QColorGroup::Base ));
509 p-> setBrush ( NoBrush ); 521 p-> drawEllipse ( fr );
522 p-> setBrush ( NoBrush );
523
524 // draw ticks
525 p->setPen( QPen( colorGroup ( ). color ( QColorGroup::Text ), 1 ) );
526 for ( int i = 0; i < 12; i++ )
527 p->drawLine( rotate( center, l1, i * 30 ), rotate( center, l2, i * 30 ) );
528 }
529 else
530 {
531 drawPointers ( p, fr, colorGroup ( ). color ( QColorGroup::Base ), prevTime, &currTime );
532 }
510 533
511 // draw ticks
512 p->setPen( QPen( colorGroup ( ). color ( QColorGroup::Text ), 1 ) );
513 for ( int i = 0; i < 12; i++ )
514 p->drawLine( rotate( center, l1, i * 30 ), rotate( center, l2, i * 30 ) );
515 }
516 else {
517 drawPointers ( p, fr, colorGroup ( ). color ( QColorGroup::Base ), prevTime, &currTime );
518 }
519
520 drawPointers ( p, fr, colorGroup ( ). color ( QColorGroup::Text ), currTime ); 534 drawPointers ( p, fr, colorGroup ( ). color ( QColorGroup::Text ), currTime );
521 535
522 prevTime = currTime; 536 prevTime = currTime;
523} 537}
524 538
525void AnalogClock::drawPointers ( QPainter *p, const QRect &r, const QColor &c, const QTime &t, const QTime *t2 ) 539void AnalogClock::drawPointers ( QPainter *p, const QRect &r, const QColor &c, const QTime &t, const QTime *t2 )
@@ -536,25 +550,25 @@ void AnalogClock::drawPointers ( QPainter *p, const QRect &r, const QColor &c, c
536 QPoint s2( center. x ( ), center. y ( ) ); 550 QPoint s2( center. x ( ), center. y ( ) );
537 551
538 552
539 if ( !t2 || ( t. minute ( ) != t2-> minute ( ) || t. hour ( ) != t2-> hour ( ))) { 553 if ( !t2 || ( t. minute ( ) != t2-> minute ( ) || t. hour ( ) != t2-> hour ( ))) {
540 // draw hour pointer 554 // draw hour pointer
541 h1 = rotate( center, h1, 30 * ( t.hour() % 12 ) + t.minute() / 2 ); 555 h1 = rotate( center, h1, 30 * ( t.hour() % 12 ) + t.minute() / 2 );
542 h2 = rotate( center, h2, 30 * ( t.hour() % 12 ) + t.minute() / 2 ); 556 h2 = rotate( center, h2, 30 * ( t.hour() % 12 ) + t.minute() / 2 );
543 p-> setPen ( QPen ( c, 3 )); 557 p-> setPen ( QPen ( c, 3 ));
544 p-> drawLine ( h1, h2 ); 558 p-> drawLine ( h1, h2 );
545 } 559 }
546 560
547 if ( !t2 || ( t. minute ( ) != t2-> minute ( ))) { 561 if ( !t2 || ( t. minute ( ) != t2-> minute ( ))) {
548 // draw minute pointer 562 // draw minute pointer
549 m1 = rotate( center, m1, t.minute() * 6 ); 563 m1 = rotate( center, m1, t.minute() * 6 );
550 m2 = rotate( center, m2, t.minute() * 6 ); 564 m2 = rotate( center, m2, t.minute() * 6 );
551 p-> setPen ( QPen ( c, 2 )); 565 p-> setPen ( QPen ( c, 2 ));
552 p-> drawLine ( m1, m2 ); 566 p-> drawLine ( m1, m2 );
553 } 567 }
554 568
555 if ( !t2 || ( t. second ( ) != t2-> second ( ))) { 569 if ( !t2 || ( t. second ( ) != t2-> second ( ))) {
556 // draw second pointer 570 // draw second pointer
557 s1 = rotate( center, s1, t.second() * 6 ); 571 s1 = rotate( center, s1, t.second() * 6 );
558 s2 = rotate( center, s2, t.second() * 6 ); 572 s2 = rotate( center, s2, t.second() * 6 );
559 p-> setPen ( QPen ( c, 1 )); 573 p-> setPen ( QPen ( c, 1 ));
560 p-> drawLine ( s1, s2 ); 574 p-> drawLine ( s1, s2 );
@@ -583,4 +597,39 @@ void Clock::slotAdjustTime()
583{ 597{
584 QCopEnvelope e( "QPE/System", "execute(QString)" ); 598 QCopEnvelope e( "QPE/System", "execute(QString)" );
585 e << QString( "systemtime" ); 599 e << QString( "systemtime" );
586} 600}
601
602void Clock::slotStartTimer()
603{
604 Config cfg( "Clock" );
605 cfg.setGroup( "Mode" );
606 int mode = cfg.readBoolEntry( "clockMode");
607 if ( clockRB->isChecked() )
608 setSwatchMode( 1);
609 slotSet();
610}
611
612void Clock::slotStopTimer()
613{
614 Config cfg( "Clock" );
615 cfg.setGroup( "Mode" );
616 int mode = cfg.readBoolEntry( "clockMode");
617 if ( clockRB->isChecked() )
618 setSwatchMode( 1);
619slotSet();
620}
621
622void Clock::slotResetTimer()
623{
624 if ( clockRB->isChecked() )
625 setSwatchMode( 1);
626slotReset();
627}
628
629void Clock::setSwatchMode(int mode)
630{
631 qDebug("Clock::setSwatchMode( %d)"), mode;
632 swatchRB->setChecked( mode);
633 clearClock( );
634 modeSelect( mode );
635}
diff --git a/noncore/tools/clock/clock.h b/noncore/tools/clock/clock.h
index 23cc143..9b00e28 100644
--- a/noncore/tools/clock/clock.h
+++ b/noncore/tools/clock/clock.h
@@ -45,14 +45,16 @@ public:
45protected: 45protected:
46 void drawContents( QPainter *p ); 46 void drawContents( QPainter *p );
47 47
48private: 48private:
49 QPoint rotate( QPoint center, QPoint p, int angle );
50 void drawPointers ( QPainter *, const QRect &r, const QColor &c, const QTime &t, const QTime *t2 = 0 );
51 49
52 QTime currTime; 50 QTime currTime;
53 QTime prevTime; 51 QTime prevTime;
54 bool clear; 52 bool clear;
53
54 QPoint rotate( QPoint center, QPoint p, int angle );
55 void drawPointers ( QPainter *, const QRect &r, const QColor &c, const QTime &t, const QTime *t2 = 0 );
56
55}; 57};
56 58
57class Clock : public QVBox 59class Clock : public QVBox
58{ 60{
@@ -77,11 +79,14 @@ private slots:
77 void alarmOff(); 79 void alarmOff();
78 void appMessage(const QCString& msg, const QByteArray& data); 80 void appMessage(const QCString& msg, const QByteArray& data);
79 void timerEvent( QTimerEvent *e ); 81 void timerEvent( QTimerEvent *e );
80 void slotAdjustTime(); 82 void slotAdjustTime();
83
84 void slotStartTimer();
85 void slotStopTimer();
86 void slotResetTimer();
87 void setSwatchMode( int );
81private: 88private:
82 void clearClock();
83 void clearTimer();
84 bool alarmBool; 89 bool alarmBool;
85 QTimer *t; 90 QTimer *t;
86 QLCDNumber *lcd; 91 QLCDNumber *lcd;
87 QLabel *date; 92 QLabel *date;
@@ -92,8 +97,10 @@ private:
92 QTime swatch_start; 97 QTime swatch_start;
93 int swatch_totalms; 98 int swatch_totalms;
94 bool swatch_running; 99 bool swatch_running;
95 bool ampm; 100 bool ampm;
101 void clearClock();
102 void clearTimer();
96}; 103};
97 104
98#endif 105#endif
99 106