summaryrefslogtreecommitdiff
path: root/noncore/tools/clock/clock.cpp
Unidiff
Diffstat (limited to 'noncore/tools/clock/clock.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/tools/clock/clock.cpp47
1 files changed, 26 insertions, 21 deletions
diff --git a/noncore/tools/clock/clock.cpp b/noncore/tools/clock/clock.cpp
index 9898332..0eb2b83 100644
--- a/noncore/tools/clock/clock.cpp
+++ b/noncore/tools/clock/clock.cpp
@@ -244,67 +244,78 @@ void Clock::updateClock()
244 totalms += swatch_start.elapsed(); 244 totalms += swatch_start.elapsed();
245 swatch_time = QTime( 0, 0, 0 ).addMSecs( totalms ); 245 swatch_time = QTime( 0, 0, 0 ).addMSecs( totalms );
246 QString d = swatch_running ? QString( " " ) 246 QString d = swatch_running ? QString( " " )
247 : QString::number( totalms % 1000 + 1000 ); 247 : QString::number( totalms % 1000 + 1000 );
248 lcdtext = swatch_time.toString() + "." + d.right( 3 ).left( sw_prec ); 248 lcdtext = swatch_time.toString() + "." + d.right( 3 ).left( sw_prec );
249 lcd->display( lcdtext ); 249 lcd->display( lcdtext );
250 lcd->repaint( FALSE ); 250 lcd->repaint( FALSE );
251 aclock->display( swatch_time ); 251 aclock->display( swatch_time );
252 date->setText( TimeString::longDateString( QDate::currentDate() ) ); 252 date->setText( TimeString::longDateString( QDate::currentDate() ) );
253 } 253 }
254} 254}
255 255
256void Clock::changeClock( bool a ) 256void Clock::changeClock( bool a )
257{ 257{
258 ampm = a; 258 ampm = a;
259 updateClock(); 259 updateClock();
260} 260}
261 261
262void Clock::clearClock( void ) 262void Clock::clearClock( void )
263{ 263{
264 lcd->display( QTime( 0, 0, 0 ).toString() ); 264 lcd->display( QTime( 0, 0, 0 ).toString() );
265 aclock->display( QTime( 0, 0, 0 ) ); 265 aclock->display( QTime( 0, 0, 0 ) );
266} 266}
267 267
268void Clock::startSWatch()
269{
270 swatch_start.start();
271 set->setText( tr( "Stop" ) );
272 t->start( 1000 );
273 swatch_running = TRUE;
274 // disable screensaver while stop watch is running
275 toggleScreenSaver( FALSE );
276}
277
278void Clock::stopSWatch()
279{
280 swatch_totalms += swatch_start.elapsed();
281 set->setText( tr( "Start" ) );
282 t->stop();
283 swatch_running = FALSE;
284 toggleScreenSaver( TRUE );
285 updateClock();
286}
287
288
268void Clock::slotSet() 289void Clock::slotSet()
269{ 290{
270 if ( t->isActive() ) 291 if ( t->isActive() )
271 { 292 {
272 swatch_totalms += swatch_start.elapsed(); 293 startSWatch();
273 set->setText( tr( "Start" ) );
274 t->stop();
275 swatch_running = FALSE;
276 toggleScreenSaver( TRUE );
277 updateClock();
278 } 294 }
279 else 295 else
280 { 296 {
281 swatch_start.start(); 297 stopSWatch();
282 set->setText( tr( "Stop" ) );
283 t->start( 1000 );
284 swatch_running = TRUE;
285 // disable screensaver while stop watch is running
286 toggleScreenSaver( FALSE );
287 } 298 }
288} 299}
289 300
290void Clock::slotReset() 301void Clock::slotReset()
291{ 302{
292 t->stop(); 303 t->stop();
293 swatch_start.start(); 304 swatch_start.start();
294 swatch_totalms = 0; 305 swatch_totalms = 0;
295 306
296 if ( swatch_running ) 307 if ( swatch_running )
297 t->start( 1000 ); 308 t->start( 1000 );
298 309
299 updateClock(); 310 updateClock();
300} 311}
301 312
302void Clock::modeSelect( int m ) 313void Clock::modeSelect( int m )
303{ 314{
304 qDebug("Clock::modeSelect( %d) ", m); 315 qDebug("Clock::modeSelect( %d) ", m);
305 if ( m ) 316 if ( m )
306 { 317 {
307 lcd->setNumDigits( 8 + 1 + sw_prec ); 318 lcd->setNumDigits( 8 + 1 + sw_prec );
308 lcd->setMinimumWidth( lcd->sizeHint().width() ); 319 lcd->setMinimumWidth( lcd->sizeHint().width() );
309 set->setEnabled( TRUE ); 320 set->setEnabled( TRUE );
310 reset->setEnabled( TRUE ); 321 reset->setEnabled( TRUE );
@@ -580,56 +591,50 @@ void AnalogClock::display( const QTime& t )
580 currTime = t; 591 currTime = t;
581 clear = false; 592 clear = false;
582 repaint( false ); 593 repaint( false );
583 clear = true; 594 clear = true;
584} 595}
585 596
586QPoint AnalogClock::rotate( QPoint c, QPoint p, int a ) 597QPoint AnalogClock::rotate( QPoint c, QPoint p, int a )
587{ 598{
588 double angle = deg2rad * ( - a + 180 ); 599 double angle = deg2rad * ( - a + 180 );
589 double nx = c.x() - ( p.x() - c.x() ) * cos( angle ) - 600 double nx = c.x() - ( p.x() - c.x() ) * cos( angle ) -
590 ( p.y() - c.y() ) * sin( angle ); 601 ( p.y() - c.y() ) * sin( angle );
591 double ny = c.y() - ( p.y() - c.y() ) * cos( angle ) + 602 double ny = c.y() - ( p.y() - c.y() ) * cos( angle ) +
592 ( p.x() - c.x() ) * sin( angle ); 603 ( p.x() - c.x() ) * sin( angle );
593 return QPoint( nx, ny ); 604 return QPoint( nx, ny );
594} 605}
595 606
596void Clock::slotAdjustTime() 607void Clock::slotAdjustTime()
597{ 608{
598 QCopEnvelope e( "QPE/System", "execute(QString)" ); 609 QCopEnvelope e( "QPE/System", "execute(QString)" );
599 e << QString( "systemtime" ); 610 e << QString( "systemtime" );
600} 611}
601 612
602void Clock::slotStartTimer() 613void Clock::slotStartTimer()
603{ 614{
604 Config cfg( "Clock" );
605 cfg.setGroup( "Mode" );
606 int mode = cfg.readBoolEntry( "clockMode");
607 if ( clockRB->isChecked() ) 615 if ( clockRB->isChecked() )
608 setSwatchMode( 1); 616 setSwatchMode( 1);
609 slotSet(); 617 startSWatch();
610} 618}
611 619
612void Clock::slotStopTimer() 620void Clock::slotStopTimer()
613{ 621{
614 Config cfg( "Clock" );
615 cfg.setGroup( "Mode" );
616 int mode = cfg.readBoolEntry( "clockMode");
617 if ( clockRB->isChecked() ) 622 if ( clockRB->isChecked() )
618 setSwatchMode( 1); 623 setSwatchMode( 1);
619slotSet(); 624 stopSWatch();
620} 625}
621 626
622void Clock::slotResetTimer() 627void Clock::slotResetTimer()
623{ 628{
624 if ( clockRB->isChecked() ) 629 if ( clockRB->isChecked() )
625 setSwatchMode( 1); 630 setSwatchMode( 1);
626slotReset(); 631slotReset();
627} 632}
628 633
629void Clock::setSwatchMode(int mode) 634void Clock::setSwatchMode(int mode)
630{ 635{
631 qDebug("Clock::setSwatchMode( %d)"), mode; 636 qDebug("Clock::setSwatchMode( %d)", mode);
632 swatchRB->setChecked( mode); 637 swatchRB->setChecked( mode);
633 clearClock( ); 638 clearClock( );
634 modeSelect( mode ); 639 modeSelect( mode );
635} 640}