author | sandman <sandman> | 2002-10-27 15:52:44 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-10-27 15:52:44 (UTC) |
commit | bf21c882b82bfcdbcdce6b2dc5d863a2a2fb37c7 (patch) (unidiff) | |
tree | 6f104afe571f394bea83b94cb0de9242ee742b88 | |
parent | 4ad1fa6d01c9de96d309cd662e658bcb1bb899a5 (diff) | |
download | opie-bf21c882b82bfcdbcdce6b2dc5d863a2a2fb37c7.zip opie-bf21c882b82bfcdbcdce6b2dc5d863a2a2fb37c7.tar.gz opie-bf21c882b82bfcdbcdce6b2dc5d863a2a2fb37c7.tar.bz2 |
- new function to check for and read the light sensor
- redone the Model enum, to make it easier to check for "any iPAQ"
!! This means every application using this enum has to be recompiled !!
-rw-r--r-- | libopie/odevice.cpp | 42 | ||||
-rw-r--r-- | libopie/odevice.h | 17 |
2 files changed, 54 insertions, 5 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 58bd663..44fe35f 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -74,24 +74,27 @@ protected: | |||
74 | public: | 74 | public: |
75 | virtual bool setSoftSuspend ( bool soft ); | 75 | virtual bool setSoftSuspend ( bool soft ); |
76 | 76 | ||
77 | virtual bool setDisplayBrightness ( int b ); | 77 | virtual bool setDisplayBrightness ( int b ); |
78 | virtual int displayBrightnessResolution ( ) const; | 78 | virtual int displayBrightnessResolution ( ) const; |
79 | 79 | ||
80 | virtual void alarmSound ( ); | 80 | virtual void alarmSound ( ); |
81 | 81 | ||
82 | virtual QValueList <OLed> ledList ( ) const; | 82 | virtual QValueList <OLed> ledList ( ) const; |
83 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; | 83 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; |
84 | virtual OLedState ledState ( OLed led ) const; | 84 | virtual OLedState ledState ( OLed led ) const; |
85 | virtual bool setLedState ( OLed led, OLedState st ); | 85 | virtual bool setLedState ( OLed led, OLedState st ); |
86 | |||
87 | virtual bool hasLightSensor ( ) const; | ||
88 | virtual int readLightSensor ( ); | ||
86 | 89 | ||
87 | //virtual QValueList <int> keyList ( ) const; | 90 | //virtual QValueList <int> keyList ( ) const; |
88 | 91 | ||
89 | protected: | 92 | protected: |
90 | virtual bool filter ( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat ); | 93 | virtual bool filter ( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat ); |
91 | virtual void timerEvent ( QTimerEvent *te ); | 94 | virtual void timerEvent ( QTimerEvent *te ); |
92 | 95 | ||
93 | int m_power_timer; | 96 | int m_power_timer; |
94 | 97 | ||
95 | OLedState m_leds [2]; | 98 | OLedState m_leds [2]; |
96 | }; | 99 | }; |
97 | 100 | ||
@@ -347,24 +350,33 @@ QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const | |||
347 | } | 350 | } |
348 | 351 | ||
349 | OLedState ODevice::ledState ( OLed /*which*/ ) const | 352 | OLedState ODevice::ledState ( OLed /*which*/ ) const |
350 | { | 353 | { |
351 | return Led_Off; | 354 | return Led_Off; |
352 | } | 355 | } |
353 | 356 | ||
354 | bool ODevice::setLedState ( OLed /*which*/, OLedState /*st*/ ) | 357 | bool ODevice::setLedState ( OLed /*which*/, OLedState /*st*/ ) |
355 | { | 358 | { |
356 | return false; | 359 | return false; |
357 | } | 360 | } |
358 | 361 | ||
362 | bool ODevice::hasLightSensor ( ) const | ||
363 | { | ||
364 | return false; | ||
365 | } | ||
366 | |||
367 | int ODevice::readLightSensor ( ) | ||
368 | { | ||
369 | return -1; | ||
370 | } | ||
359 | 371 | ||
360 | 372 | ||
361 | //QValueList <int> ODevice::keyList ( ) const | 373 | //QValueList <int> ODevice::keyList ( ) const |
362 | //{ | 374 | //{ |
363 | //return QValueList <int> ( ); | 375 | //return QValueList <int> ( ); |
364 | //} | 376 | //} |
365 | 377 | ||
366 | 378 | ||
367 | 379 | ||
368 | /************************************************** | 380 | /************************************************** |
369 | * | 381 | * |
370 | * iPAQ | 382 | * iPAQ |
@@ -657,24 +669,54 @@ bool iPAQ::setDisplayBrightness ( int bright ) | |||
657 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); | 669 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); |
658 | ::close ( fd ); | 670 | ::close ( fd ); |
659 | } | 671 | } |
660 | return res; | 672 | return res; |
661 | } | 673 | } |
662 | 674 | ||
663 | int iPAQ::displayBrightnessResolution ( ) const | 675 | int iPAQ::displayBrightnessResolution ( ) const |
664 | { | 676 | { |
665 | return 255; // really 128, but logarithmic control is smoother this way | 677 | return 255; // really 128, but logarithmic control is smoother this way |
666 | } | 678 | } |
667 | 679 | ||
668 | 680 | ||
681 | bool iPAQ::hasLightSensor ( ) const | ||
682 | { | ||
683 | return true; | ||
684 | } | ||
685 | |||
686 | int iPAQ::readLightSensor ( ) | ||
687 | { | ||
688 | int fd; | ||
689 | int val = -1; | ||
690 | |||
691 | if (( fd = ::open ( "/proc/hal/lightsensor", O_RDONLY )) >= 0 ) { | ||
692 | char buffer [5]; | ||
693 | |||
694 | if ( ::read ( fd, buffer, 4 ) == 4 ) { | ||
695 | char *endptr; | ||
696 | |||
697 | buffer [4] = 0; | ||
698 | val = ::strtol ( buffer + 2, &endptr, 16 ); | ||
699 | |||
700 | if ( *endptr != 0 ) | ||
701 | val = -1; | ||
702 | } | ||
703 | |||
704 | ::close ( fd ); | ||
705 | } | ||
706 | |||
707 | return val; | ||
708 | } | ||
709 | |||
710 | |||
669 | /************************************************** | 711 | /************************************************** |
670 | * | 712 | * |
671 | * Zaurus | 713 | * Zaurus |
672 | * | 714 | * |
673 | **************************************************/ | 715 | **************************************************/ |
674 | 716 | ||
675 | 717 | ||
676 | 718 | ||
677 | void Zaurus::init ( ) | 719 | void Zaurus::init ( ) |
678 | { | 720 | { |
679 | d-> m_modelstr = "Zaurus SL5000"; | 721 | d-> m_modelstr = "Zaurus SL5000"; |
680 | d-> m_model = Model_Zaurus_SL5000; | 722 | d-> m_model = Model_Zaurus_SL5000; |
diff --git a/libopie/odevice.h b/libopie/odevice.h index 38f3787..be2a9c7 100644 --- a/libopie/odevice.h +++ b/libopie/odevice.h | |||
@@ -21,30 +21,34 @@ | |||
21 | #define _LIBOPIE_ODEVICE_H_ | 21 | #define _LIBOPIE_ODEVICE_H_ |
22 | 22 | ||
23 | #include <qstring.h> | 23 | #include <qstring.h> |
24 | #include <qnamespace.h> | 24 | #include <qnamespace.h> |
25 | 25 | ||
26 | class ODeviceData; | 26 | class ODeviceData; |
27 | 27 | ||
28 | namespace Opie { | 28 | namespace Opie { |
29 | 29 | ||
30 | enum OModel { | 30 | enum OModel { |
31 | Model_Unknown, | 31 | Model_Unknown, |
32 | 32 | ||
33 | Model_iPAQ_H31xx, | 33 | Model_iPAQ = ( 1 << 16 ), |
34 | Model_iPAQ_H36xx, | ||
35 | Model_iPAQ_H37xx, | ||
36 | Model_iPAQ_H38xx, | ||
37 | 34 | ||
38 | Model_Zaurus_SL5000 | 35 | Model_iPAQ_H31xx = ( Model_iPAQ | 1 ), |
36 | Model_iPAQ_H36xx = ( Model_iPAQ | 2 ), | ||
37 | Model_iPAQ_H37xx = ( Model_iPAQ | 3 ), | ||
38 | Model_iPAQ_H38xx = ( Model_iPAQ | 4 ), | ||
39 | |||
40 | Model_Zaurus = ( 2 << 16 ), | ||
41 | |||
42 | Model_Zaurus_SL5000 = ( Model_Zaurus | 1 ), | ||
39 | }; | 43 | }; |
40 | 44 | ||
41 | enum OVendor { | 45 | enum OVendor { |
42 | Vendor_Unknown, | 46 | Vendor_Unknown, |
43 | 47 | ||
44 | Vendor_HP, | 48 | Vendor_HP, |
45 | Vendor_Sharp | 49 | Vendor_Sharp |
46 | }; | 50 | }; |
47 | 51 | ||
48 | enum OSystem { | 52 | enum OSystem { |
49 | System_Unknown, | 53 | System_Unknown, |
50 | 54 | ||
@@ -120,19 +124,22 @@ public: | |||
120 | 124 | ||
121 | // input / output | 125 | // input / output |
122 | 126 | ||
123 | virtual void alarmSound ( ); | 127 | virtual void alarmSound ( ); |
124 | virtual void keySound ( ); | 128 | virtual void keySound ( ); |
125 | virtual void touchSound ( ); | 129 | virtual void touchSound ( ); |
126 | 130 | ||
127 | virtual QValueList <OLed> ledList ( ) const; | 131 | virtual QValueList <OLed> ledList ( ) const; |
128 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; | 132 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; |
129 | virtual OLedState ledState ( OLed led ) const; | 133 | virtual OLedState ledState ( OLed led ) const; |
130 | virtual bool setLedState ( OLed led, OLedState st ); | 134 | virtual bool setLedState ( OLed led, OLedState st ); |
131 | 135 | ||
136 | virtual bool hasLightSensor ( ) const; | ||
137 | virtual int readLightSensor ( ); | ||
138 | |||
132 | //virtual QValueList <int> keyList ( ) const; | 139 | //virtual QValueList <int> keyList ( ) const; |
133 | }; | 140 | }; |
134 | 141 | ||
135 | } | 142 | } |
136 | 143 | ||
137 | #endif | 144 | #endif |
138 | 145 | ||