author | sandman <sandman> | 2003-03-26 23:53:14 (UTC) |
---|---|---|
committer | sandman <sandman> | 2003-03-26 23:53:14 (UTC) |
commit | 9d291e88efa5b33bbf34112cdee8b0e516150dd6 (patch) (unidiff) | |
tree | 6059b942d98691d7882d5290d5aa854b187f13ce | |
parent | eda6fffbe8ad7e3635985d9b2a8f7b46964aa271 (diff) | |
download | opie-9d291e88efa5b33bbf34112cdee8b0e516150dd6.zip opie-9d291e88efa5b33bbf34112cdee8b0e516150dd6.tar.gz opie-9d291e88efa5b33bbf34112cdee8b0e516150dd6.tar.bz2 |
delay the initialization of the button information:
- faster startup for apps that are not accessing the HW buttons
- the basic ODevice stuff is useable without a QApplication object
-rw-r--r-- | libopie/odevice.cpp | 91 | ||||
-rw-r--r-- | libopie/odevice.h | 3 |
2 files changed, 70 insertions, 24 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 80975c9..377945d 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -59,32 +59,33 @@ public: | |||
59 | OVendor m_vendor; | 59 | OVendor m_vendor; |
60 | 60 | ||
61 | QString m_modelstr; | 61 | QString m_modelstr; |
62 | OModel m_model; | 62 | OModel m_model; |
63 | 63 | ||
64 | QString m_systemstr; | 64 | QString m_systemstr; |
65 | OSystem m_system; | 65 | OSystem m_system; |
66 | 66 | ||
67 | QString m_sysverstr; | 67 | QString m_sysverstr; |
68 | 68 | ||
69 | Transformation m_rotation; | 69 | Transformation m_rotation; |
70 | 70 | ||
71 | QValueList <ODeviceButton> m_buttons; | 71 | QValueList <ODeviceButton> *m_buttons; |
72 | uint m_holdtime; | 72 | uint m_holdtime; |
73 | }; | 73 | }; |
74 | 74 | ||
75 | 75 | ||
76 | class iPAQ : public ODevice, public QWSServer::KeyboardFilter { | 76 | class iPAQ : public ODevice, public QWSServer::KeyboardFilter { |
77 | protected: | 77 | protected: |
78 | virtual void init ( ); | 78 | virtual void init ( ); |
79 | virtual void initButtons ( ); | ||
79 | 80 | ||
80 | public: | 81 | public: |
81 | virtual bool setSoftSuspend ( bool soft ); | 82 | virtual bool setSoftSuspend ( bool soft ); |
82 | 83 | ||
83 | virtual bool setDisplayBrightness ( int b ); | 84 | virtual bool setDisplayBrightness ( int b ); |
84 | virtual int displayBrightnessResolution ( ) const; | 85 | virtual int displayBrightnessResolution ( ) const; |
85 | 86 | ||
86 | virtual void alarmSound ( ); | 87 | virtual void alarmSound ( ); |
87 | 88 | ||
88 | virtual QValueList <OLed> ledList ( ) const; | 89 | virtual QValueList <OLed> ledList ( ) const; |
89 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; | 90 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; |
90 | virtual OLedState ledState ( OLed led ) const; | 91 | virtual OLedState ledState ( OLed led ) const; |
@@ -97,24 +98,25 @@ public: | |||
97 | protected: | 98 | protected: |
98 | virtual bool filter ( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat ); | 99 | virtual bool filter ( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat ); |
99 | virtual void timerEvent ( QTimerEvent *te ); | 100 | virtual void timerEvent ( QTimerEvent *te ); |
100 | 101 | ||
101 | int m_power_timer; | 102 | int m_power_timer; |
102 | 103 | ||
103 | OLedState m_leds [2]; | 104 | OLedState m_leds [2]; |
104 | }; | 105 | }; |
105 | 106 | ||
106 | class Zaurus : public ODevice { | 107 | class Zaurus : public ODevice { |
107 | protected: | 108 | protected: |
108 | virtual void init ( ); | 109 | virtual void init ( ); |
110 | virtual void initButtons ( ); | ||
109 | 111 | ||
110 | public: | 112 | public: |
111 | virtual bool setSoftSuspend ( bool soft ); | 113 | virtual bool setSoftSuspend ( bool soft ); |
112 | 114 | ||
113 | virtual bool setDisplayBrightness ( int b ); | 115 | virtual bool setDisplayBrightness ( int b ); |
114 | virtual int displayBrightnessResolution ( ) const; | 116 | virtual int displayBrightnessResolution ( ) const; |
115 | 117 | ||
116 | virtual void alarmSound ( ); | 118 | virtual void alarmSound ( ); |
117 | virtual void keySound ( ); | 119 | virtual void keySound ( ); |
118 | virtual void touchSound ( ); | 120 | virtual void touchSound ( ); |
119 | 121 | ||
120 | virtual QValueList <OLed> ledList ( ) const; | 122 | virtual QValueList <OLed> ledList ( ) const; |
@@ -245,54 +247,65 @@ ODevice::ODevice ( ) | |||
245 | d-> m_qwsserver = qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; | 247 | d-> m_qwsserver = qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; |
246 | 248 | ||
247 | d-> m_modelstr = "Unknown"; | 249 | d-> m_modelstr = "Unknown"; |
248 | d-> m_model = Model_Unknown; | 250 | d-> m_model = Model_Unknown; |
249 | d-> m_vendorstr = "Unknown"; | 251 | d-> m_vendorstr = "Unknown"; |
250 | d-> m_vendor = Vendor_Unknown; | 252 | d-> m_vendor = Vendor_Unknown; |
251 | d-> m_systemstr = "Unknown"; | 253 | d-> m_systemstr = "Unknown"; |
252 | d-> m_system = System_Unknown; | 254 | d-> m_system = System_Unknown; |
253 | d-> m_sysverstr = "0.0"; | 255 | d-> m_sysverstr = "0.0"; |
254 | d-> m_rotation = Rot0; | 256 | d-> m_rotation = Rot0; |
255 | 257 | ||
256 | d-> m_holdtime = 1000; // 1000ms | 258 | d-> m_holdtime = 1000; // 1000ms |
257 | 259 | d-> m_buttons = 0; | |
258 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | ||
259 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | ||
260 | } | 260 | } |
261 | 261 | ||
262 | void ODevice::systemMessage ( const QCString &msg, const QByteArray & ) | 262 | void ODevice::systemMessage ( const QCString &msg, const QByteArray & ) |
263 | { | 263 | { |
264 | if ( msg == "deviceButtonMappingChanged()" ) { | 264 | if ( msg == "deviceButtonMappingChanged()" ) { |
265 | reloadButtonMapping ( ); | 265 | reloadButtonMapping ( ); |
266 | } | 266 | } |
267 | } | 267 | } |
268 | 268 | ||
269 | void ODevice::init ( ) | 269 | void ODevice::init ( ) |
270 | { | 270 | { |
271 | } | ||
272 | |||
273 | void ODevice::initButtons ( ) | ||
274 | { | ||
275 | if ( d-> m_buttons ) | ||
276 | return; | ||
277 | |||
271 | // Simulation uses iPAQ 3660 device buttons | 278 | // Simulation uses iPAQ 3660 device buttons |
272 | 279 | ||
280 | qDebug ( "init Buttons" ); | ||
281 | d-> m_buttons = new QValueList <ODeviceButton>; | ||
282 | |||
273 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { | 283 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { |
274 | i_button *ib = ipaq_buttons + i; | 284 | i_button *ib = ipaq_buttons + i; |
275 | ODeviceButton b; | 285 | ODeviceButton b; |
276 | 286 | ||
277 | if (( ib-> model & Model_iPAQ_H36xx ) == Model_iPAQ_H36xx ) { | 287 | if (( ib-> model & Model_iPAQ_H36xx ) == Model_iPAQ_H36xx ) { |
278 | b. setKeycode ( ib-> code ); | 288 | b. setKeycode ( ib-> code ); |
279 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); | 289 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); |
280 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); | 290 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); |
281 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); | 291 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); |
282 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); | 292 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); |
283 | d-> m_buttons. append ( b ); | 293 | d-> m_buttons-> append ( b ); |
284 | } | 294 | } |
285 | } | 295 | } |
286 | reloadButtonMapping ( ); | 296 | reloadButtonMapping ( ); |
297 | |||
298 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | ||
299 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | ||
287 | } | 300 | } |
288 | 301 | ||
289 | ODevice::~ODevice ( ) | 302 | ODevice::~ODevice ( ) |
290 | { | 303 | { |
291 | delete d; | 304 | delete d; |
292 | } | 305 | } |
293 | 306 | ||
294 | bool ODevice::setSoftSuspend ( bool /*soft*/ ) | 307 | bool ODevice::setSoftSuspend ( bool /*soft*/ ) |
295 | { | 308 | { |
296 | return false; | 309 | return false; |
297 | } | 310 | } |
298 | 311 | ||
@@ -465,49 +478,55 @@ bool ODevice::hasLightSensor ( ) const | |||
465 | } | 478 | } |
466 | 479 | ||
467 | int ODevice::readLightSensor ( ) | 480 | int ODevice::readLightSensor ( ) |
468 | { | 481 | { |
469 | return -1; | 482 | return -1; |
470 | } | 483 | } |
471 | 484 | ||
472 | int ODevice::lightSensorResolution ( ) const | 485 | int ODevice::lightSensorResolution ( ) const |
473 | { | 486 | { |
474 | return 0; | 487 | return 0; |
475 | } | 488 | } |
476 | 489 | ||
477 | const QValueList <ODeviceButton> &ODevice::buttons ( ) const | 490 | const QValueList <ODeviceButton> &ODevice::buttons ( ) |
478 | { | 491 | { |
479 | return d-> m_buttons; | 492 | initButtons ( ); |
493 | |||
494 | return *d-> m_buttons; | ||
480 | } | 495 | } |
481 | 496 | ||
482 | uint ODevice::buttonHoldTime ( ) const | 497 | uint ODevice::buttonHoldTime ( ) const |
483 | { | 498 | { |
484 | return d-> m_holdtime; | 499 | return d-> m_holdtime; |
485 | } | 500 | } |
486 | 501 | ||
487 | const ODeviceButton *ODevice::buttonForKeycode ( ushort code ) | 502 | const ODeviceButton *ODevice::buttonForKeycode ( ushort code ) |
488 | { | 503 | { |
489 | for ( QValueListConstIterator<ODeviceButton> it = d-> m_buttons. begin ( ); it != d-> m_buttons. end ( ); ++it ) { | 504 | initButtons ( ); |
505 | |||
506 | for ( QValueListConstIterator<ODeviceButton> it = d-> m_buttons-> begin ( ); it != d-> m_buttons-> end ( ); ++it ) { | ||
490 | if ( (*it). keycode ( ) == code ) | 507 | if ( (*it). keycode ( ) == code ) |
491 | return &(*it); | 508 | return &(*it); |
492 | } | 509 | } |
493 | return 0; | 510 | return 0; |
494 | } | 511 | } |
495 | 512 | ||
496 | void ODevice::reloadButtonMapping ( ) | 513 | void ODevice::reloadButtonMapping ( ) |
497 | { | 514 | { |
515 | initButtons ( ); | ||
516 | |||
498 | Config cfg ( "ButtonSettings" ); | 517 | Config cfg ( "ButtonSettings" ); |
499 | 518 | ||
500 | for ( uint i = 0; i < d-> m_buttons. count ( ); i++ ) { | 519 | for ( uint i = 0; i < d-> m_buttons-> count ( ); i++ ) { |
501 | ODeviceButton &b = d-> m_buttons [i]; | 520 | ODeviceButton &b = ( *d-> m_buttons ) [i]; |
502 | QString group = "Button" + QString::number ( i ); | 521 | QString group = "Button" + QString::number ( i ); |
503 | 522 | ||
504 | QCString pch, hch; | 523 | QCString pch, hch; |
505 | QCString pm, hm; | 524 | QCString pm, hm; |
506 | QByteArray pdata, hdata; | 525 | QByteArray pdata, hdata; |
507 | 526 | ||
508 | if ( cfg. hasGroup ( group )) { | 527 | if ( cfg. hasGroup ( group )) { |
509 | cfg. setGroup ( group ); | 528 | cfg. setGroup ( group ); |
510 | pch = cfg. readEntry ( "PressedActionChannel" ). latin1 ( ); | 529 | pch = cfg. readEntry ( "PressedActionChannel" ). latin1 ( ); |
511 | pm = cfg. readEntry ( "PressedActionMessage" ). latin1 ( ); | 530 | pm = cfg. readEntry ( "PressedActionMessage" ). latin1 ( ); |
512 | // pdata = decodeBase64 ( buttonFile. readEntry ( "PressedActionArgs" )); | 531 | // pdata = decodeBase64 ( buttonFile. readEntry ( "PressedActionArgs" )); |
513 | 532 | ||
@@ -515,51 +534,54 @@ void ODevice::reloadButtonMapping ( ) | |||
515 | hm = cfg. readEntry ( "HeldActionMessage" ). latin1 ( ); | 534 | hm = cfg. readEntry ( "HeldActionMessage" ). latin1 ( ); |
516 | // hdata = decodeBase64 ( buttonFile. readEntry ( "HeldActionArgs" )); | 535 | // hdata = decodeBase64 ( buttonFile. readEntry ( "HeldActionArgs" )); |
517 | } | 536 | } |
518 | 537 | ||
519 | b. setPressedAction ( OQCopMessage ( pch, pm, pdata )); | 538 | b. setPressedAction ( OQCopMessage ( pch, pm, pdata )); |
520 | 539 | ||
521 | b. setHeldAction ( OQCopMessage ( hch, hm, hdata )); | 540 | b. setHeldAction ( OQCopMessage ( hch, hm, hdata )); |
522 | } | 541 | } |
523 | } | 542 | } |
524 | 543 | ||
525 | void ODevice::remapPressedAction ( int button, const OQCopMessage &action ) | 544 | void ODevice::remapPressedAction ( int button, const OQCopMessage &action ) |
526 | { | 545 | { |
546 | initButtons ( ); | ||
547 | |||
527 | QString mb_chan; | 548 | QString mb_chan; |
528 | 549 | ||
529 | if ( button >= (int) d-> m_buttons. count ( )) | 550 | if ( button >= (int) d-> m_buttons-> count ( )) |
530 | return; | 551 | return; |
531 | |||
532 | 552 | ||
533 | ODeviceButton &b = d-> m_buttons [button]; | 553 | ODeviceButton &b = ( *d-> m_buttons ) [button]; |
534 | b. setPressedAction ( action ); | 554 | b. setPressedAction ( action ); |
535 | 555 | ||
536 | mb_chan=b. pressedAction ( ). channel ( ); | 556 | mb_chan=b. pressedAction ( ). channel ( ); |
537 | 557 | ||
538 | Config buttonFile ( "ButtonSettings" ); | 558 | Config buttonFile ( "ButtonSettings" ); |
539 | buttonFile. setGroup ( "Button" + QString::number ( button )); | 559 | buttonFile. setGroup ( "Button" + QString::number ( button )); |
540 | buttonFile. writeEntry ( "PressedActionChannel", (const char*) mb_chan); | 560 | buttonFile. writeEntry ( "PressedActionChannel", (const char*) mb_chan); |
541 | buttonFile. writeEntry ( "PressedActionMessage", (const char*) b. pressedAction ( ). message ( )); | 561 | buttonFile. writeEntry ( "PressedActionMessage", (const char*) b. pressedAction ( ). message ( )); |
542 | 562 | ||
543 | //buttonFile. writeEntry ( "PressedActionArgs", encodeBase64 ( b. pressedAction ( ). data ( ))); | 563 | //buttonFile. writeEntry ( "PressedActionArgs", encodeBase64 ( b. pressedAction ( ). data ( ))); |
544 | 564 | ||
545 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); | 565 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); |
546 | } | 566 | } |
547 | 567 | ||
548 | void ODevice::remapHeldAction ( int button, const OQCopMessage &action ) | 568 | void ODevice::remapHeldAction ( int button, const OQCopMessage &action ) |
549 | { | 569 | { |
550 | if ( button >= (int) d-> m_buttons. count ( )) | 570 | initButtons ( ); |
571 | |||
572 | if ( button >= (int) d-> m_buttons-> count ( )) | ||
551 | return; | 573 | return; |
552 | 574 | ||
553 | ODeviceButton &b = d-> m_buttons [button]; | 575 | ODeviceButton &b = ( *d-> m_buttons ) [button]; |
554 | b. setHeldAction ( action ); | 576 | b. setHeldAction ( action ); |
555 | 577 | ||
556 | Config buttonFile ( "ButtonSettings" ); | 578 | Config buttonFile ( "ButtonSettings" ); |
557 | buttonFile. setGroup ( "Button" + QString::number ( button )); | 579 | buttonFile. setGroup ( "Button" + QString::number ( button )); |
558 | buttonFile. writeEntry ( "HeldActionChannel", (const char *) b. heldAction ( ). channel ( )); | 580 | buttonFile. writeEntry ( "HeldActionChannel", (const char *) b. heldAction ( ). channel ( )); |
559 | buttonFile. writeEntry ( "HeldActionMessage", (const char *) b. heldAction ( ). message ( )); | 581 | buttonFile. writeEntry ( "HeldActionMessage", (const char *) b. heldAction ( ). message ( )); |
560 | 582 | ||
561 | //buttonFile. writeEntry ( "HeldActionArgs", decodeBase64 ( b. heldAction ( ). data ( ))); | 583 | //buttonFile. writeEntry ( "HeldActionArgs", decodeBase64 ( b. heldAction ( ). data ( ))); |
562 | 584 | ||
563 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); | 585 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); |
564 | } | 586 | } |
565 | 587 | ||
@@ -619,44 +641,56 @@ void iPAQ::init ( ) | |||
619 | d-> m_system = System_Familiar; | 641 | d-> m_system = System_Familiar; |
620 | 642 | ||
621 | QTextStream ts ( &f ); | 643 | QTextStream ts ( &f ); |
622 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); | 644 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); |
623 | 645 | ||
624 | f. close ( ); | 646 | f. close ( ); |
625 | } | 647 | } |
626 | 648 | ||
627 | m_leds [0] = m_leds [1] = Led_Off; | 649 | m_leds [0] = m_leds [1] = Led_Off; |
628 | 650 | ||
629 | m_power_timer = 0; | 651 | m_power_timer = 0; |
630 | 652 | ||
653 | if ( d-> m_qwsserver ) | ||
654 | QWSServer::setKeyboardFilter ( this ); | ||
655 | } | ||
656 | |||
657 | void iPAQ::initButtons ( ) | ||
658 | { | ||
659 | if ( d-> m_buttons ) | ||
660 | return; | ||
661 | |||
662 | d-> m_buttons = new QValueList <ODeviceButton>; | ||
663 | |||
631 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { | 664 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { |
632 | i_button *ib = ipaq_buttons + i; | 665 | i_button *ib = ipaq_buttons + i; |
633 | ODeviceButton b; | 666 | ODeviceButton b; |
634 | 667 | ||
635 | if (( ib-> model & d-> m_model ) == d-> m_model ) { | 668 | if (( ib-> model & d-> m_model ) == d-> m_model ) { |
636 | b. setKeycode ( ib-> code ); | 669 | b. setKeycode ( ib-> code ); |
637 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); | 670 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); |
638 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); | 671 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); |
639 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); | 672 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); |
640 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); | 673 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); |
641 | 674 | ||
642 | d-> m_buttons. append ( b ); | 675 | d-> m_buttons-> append ( b ); |
643 | } | 676 | } |
644 | } | 677 | } |
645 | reloadButtonMapping ( ); | 678 | reloadButtonMapping ( ); |
646 | 679 | ||
647 | if ( d-> m_qwsserver ) | 680 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
648 | QWSServer::setKeyboardFilter ( this ); | 681 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); |
649 | } | 682 | } |
650 | 683 | ||
684 | |||
651 | //#include <linux/h3600_ts.h> // including kernel headers is evil ... | 685 | //#include <linux/h3600_ts.h> // including kernel headers is evil ... |
652 | 686 | ||
653 | typedef struct { | 687 | typedef struct { |
654 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ | 688 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ |
655 | unsigned char TotalTime; /* Units of 5 seconds */ | 689 | unsigned char TotalTime; /* Units of 5 seconds */ |
656 | unsigned char OnTime; /* units of 100m/s */ | 690 | unsigned char OnTime; /* units of 100m/s */ |
657 | unsigned char OffTime; /* units of 100m/s */ | 691 | unsigned char OffTime; /* units of 100m/s */ |
658 | } LED_IN; | 692 | } LED_IN; |
659 | 693 | ||
660 | typedef struct { | 694 | typedef struct { |
661 | unsigned char mode; | 695 | unsigned char mode; |
662 | unsigned char pwr; | 696 | unsigned char pwr; |
@@ -984,40 +1018,51 @@ void Zaurus::init ( ) | |||
984 | case Model_Zaurus_SLC700: | 1018 | case Model_Zaurus_SLC700: |
985 | /* note for C700, we must check the display rotation | 1019 | /* note for C700, we must check the display rotation |
986 | * sensor to set an appropriate value | 1020 | * sensor to set an appropriate value |
987 | */ | 1021 | */ |
988 | case Model_Zaurus_SLA300: | 1022 | case Model_Zaurus_SLA300: |
989 | case Model_Zaurus_SLB600: | 1023 | case Model_Zaurus_SLB600: |
990 | case Model_Zaurus_SL5500: | 1024 | case Model_Zaurus_SL5500: |
991 | case Model_Zaurus_SL5000: | 1025 | case Model_Zaurus_SL5000: |
992 | default: | 1026 | default: |
993 | d-> m_rotation = Rot270; | 1027 | d-> m_rotation = Rot270; |
994 | break; | 1028 | break; |
995 | } | 1029 | } |
1030 | m_leds [0] = Led_Off; | ||
1031 | } | ||
1032 | |||
1033 | void Zaurus::initButtons ( ) | ||
1034 | { | ||
1035 | if ( d-> m_buttons ) | ||
1036 | return; | ||
1037 | |||
1038 | d-> m_buttons = new QValueList <ODeviceButton>; | ||
996 | 1039 | ||
997 | for ( uint i = 0; i < ( sizeof( z_buttons ) / sizeof( z_button )); i++ ) { | 1040 | for ( uint i = 0; i < ( sizeof( z_buttons ) / sizeof( z_button )); i++ ) { |
998 | z_button *zb = z_buttons + i; | 1041 | z_button *zb = z_buttons + i; |
999 | ODeviceButton b; | 1042 | ODeviceButton b; |
1000 | 1043 | ||
1001 | b. setKeycode ( zb-> code ); | 1044 | b. setKeycode ( zb-> code ); |
1002 | b. setUserText ( QObject::tr ( "Button", zb-> utext )); | 1045 | b. setUserText ( QObject::tr ( "Button", zb-> utext )); |
1003 | b. setPixmap ( Resource::loadPixmap ( zb-> pix )); | 1046 | b. setPixmap ( Resource::loadPixmap ( zb-> pix )); |
1004 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( zb-> fpressedservice ), zb-> fpressedaction )); | 1047 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( zb-> fpressedservice ), zb-> fpressedaction )); |
1005 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( zb-> fheldservice ), zb-> fheldaction )); | 1048 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( zb-> fheldservice ), zb-> fheldaction )); |
1006 | 1049 | ||
1007 | d-> m_buttons. append ( b ); | 1050 | d-> m_buttons-> append ( b ); |
1008 | } | 1051 | } |
1052 | |||
1009 | reloadButtonMapping ( ); | 1053 | reloadButtonMapping ( ); |
1010 | 1054 | ||
1011 | m_leds [0] = Led_Off; | 1055 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
1056 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | ||
1012 | } | 1057 | } |
1013 | 1058 | ||
1014 | #include <unistd.h> | 1059 | #include <unistd.h> |
1015 | #include <fcntl.h> | 1060 | #include <fcntl.h> |
1016 | #include <sys/ioctl.h> | 1061 | #include <sys/ioctl.h> |
1017 | 1062 | ||
1018 | //#include <asm/sharp_char.h> // including kernel headers is evil ... | 1063 | //#include <asm/sharp_char.h> // including kernel headers is evil ... |
1019 | 1064 | ||
1020 | #define SHARP_DEV_IOCTL_COMMAND_START 0x5680 | 1065 | #define SHARP_DEV_IOCTL_COMMAND_START 0x5680 |
1021 | 1066 | ||
1022 | #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | 1067 | #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) |
1023 | #define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) | 1068 | #define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) |
diff --git a/libopie/odevice.h b/libopie/odevice.h index 575e1fe..ff578d8 100644 --- a/libopie/odevice.h +++ b/libopie/odevice.h | |||
@@ -94,24 +94,25 @@ enum OHardKey { | |||
94 | HardKey_Backlight = Qt::Key_F35, | 94 | HardKey_Backlight = Qt::Key_F35, |
95 | }; | 95 | }; |
96 | 96 | ||
97 | class ODevice : public QObject { | 97 | class ODevice : public QObject { |
98 | Q_OBJECT | 98 | Q_OBJECT |
99 | 99 | ||
100 | private: | 100 | private: |
101 | ODevice ( const ODevice & ); | 101 | ODevice ( const ODevice & ); |
102 | 102 | ||
103 | protected: | 103 | protected: |
104 | ODevice ( ); | 104 | ODevice ( ); |
105 | virtual void init ( ); | 105 | virtual void init ( ); |
106 | virtual void initButtons ( ); | ||
106 | 107 | ||
107 | ODeviceData *d; | 108 | ODeviceData *d; |
108 | 109 | ||
109 | public: | 110 | public: |
110 | virtual ~ODevice ( ); | 111 | virtual ~ODevice ( ); |
111 | 112 | ||
112 | static ODevice *inst ( ); | 113 | static ODevice *inst ( ); |
113 | 114 | ||
114 | // information | 115 | // information |
115 | 116 | ||
116 | QString modelString ( ) const; | 117 | QString modelString ( ) const; |
117 | OModel model ( ) const; | 118 | OModel model ( ) const; |
@@ -148,25 +149,25 @@ public: | |||
148 | virtual bool setLedState ( OLed led, OLedState st ); | 149 | virtual bool setLedState ( OLed led, OLedState st ); |
149 | 150 | ||
150 | virtual bool hasLightSensor ( ) const; | 151 | virtual bool hasLightSensor ( ) const; |
151 | virtual int readLightSensor ( ); | 152 | virtual int readLightSensor ( ); |
152 | virtual int lightSensorResolution ( ) const; | 153 | virtual int lightSensorResolution ( ) const; |
153 | 154 | ||
154 | /** | 155 | /** |
155 | * Returns the available buttons on this device. The number and location | 156 | * Returns the available buttons on this device. The number and location |
156 | * of buttons will vary depending on the device. Button numbers will be assigned | 157 | * of buttons will vary depending on the device. Button numbers will be assigned |
157 | * by the device manufacturer and will be from most preferred button to least preffered | 158 | * by the device manufacturer and will be from most preferred button to least preffered |
158 | * button. Note that this list only contains "user mappable" buttons. | 159 | * button. Note that this list only contains "user mappable" buttons. |
159 | */ | 160 | */ |
160 | const QValueList<ODeviceButton> &buttons ( ) const; | 161 | const QValueList<ODeviceButton> &buttons ( ); |
161 | 162 | ||
162 | /** | 163 | /** |
163 | * Returns the DeviceButton for the \a keyCode. If \a keyCode is not found, it | 164 | * Returns the DeviceButton for the \a keyCode. If \a keyCode is not found, it |
164 | * returns 0L | 165 | * returns 0L |
165 | */ | 166 | */ |
166 | const ODeviceButton *buttonForKeycode ( ushort keyCode ); | 167 | const ODeviceButton *buttonForKeycode ( ushort keyCode ); |
167 | 168 | ||
168 | /** | 169 | /** |
169 | * Reassigns the pressed action for \a button. To return to the factory | 170 | * Reassigns the pressed action for \a button. To return to the factory |
170 | * default pass an empty string as \a qcopMessage. | 171 | * default pass an empty string as \a qcopMessage. |
171 | */ | 172 | */ |
172 | void remapPressedAction ( int button, const OQCopMessage &qcopMessage ); | 173 | void remapPressedAction ( int button, const OQCopMessage &qcopMessage ); |