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 | |||
@@ -70,32 +70,35 @@ public: | |||
70 | class iPAQ : public QObject, public ODevice, public QWSServer::KeyboardFilter { | 70 | class iPAQ : public QObject, public ODevice, public QWSServer::KeyboardFilter { |
71 | protected: | 71 | protected: |
72 | virtual void init ( ); | 72 | virtual void init ( ); |
73 | 73 | ||
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 | ||
98 | class Zaurus : public ODevice { | 101 | class Zaurus : public ODevice { |
99 | protected: | 102 | protected: |
100 | virtual void init ( ); | 103 | virtual void init ( ); |
101 | 104 | ||
@@ -343,32 +346,41 @@ QValueList <OLed> ODevice::ledList ( ) const | |||
343 | 346 | ||
344 | QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const | 347 | QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const |
345 | { | 348 | { |
346 | return QValueList <OLedState> ( ); | 349 | return QValueList <OLedState> ( ); |
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 |
371 | * | 383 | * |
372 | **************************************************/ | 384 | **************************************************/ |
373 | 385 | ||
374 | void iPAQ::init ( ) | 386 | void iPAQ::init ( ) |
@@ -653,32 +665,62 @@ bool iPAQ::setDisplayBrightness ( int bright ) | |||
653 | FLITE_IN bl; | 665 | FLITE_IN bl; |
654 | bl. mode = 1; | 666 | bl. mode = 1; |
655 | bl. pwr = bright ? 1 : 0; | 667 | bl. pwr = bright ? 1 : 0; |
656 | bl. brightness = bright; | 668 | bl. brightness = 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; |
681 | d-> m_vendorstr = "Sharp"; | 723 | d-> m_vendorstr = "Sharp"; |
682 | d-> m_vendor = Vendor_Sharp; | 724 | d-> m_vendor = Vendor_Sharp; |
683 | 725 | ||
684 | QFile f ( "/proc/filesystems" ); | 726 | QFile f ( "/proc/filesystems" ); |
diff --git a/libopie/odevice.h b/libopie/odevice.h index 38f3787..be2a9c7 100644 --- a/libopie/odevice.h +++ b/libopie/odevice.h | |||
@@ -17,38 +17,42 @@ | |||
17 | Boston, MA 02111-1307, USA. | 17 | Boston, MA 02111-1307, USA. |
18 | */ | 18 | */ |
19 | 19 | ||
20 | #ifndef _LIBOPIE_ODEVICE_H_ | 20 | #ifndef _LIBOPIE_ODEVICE_H_ |
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 | ||
51 | System_Familiar, | 55 | System_Familiar, |
52 | System_Zaurus, | 56 | System_Zaurus, |
53 | System_OpenZaurus | 57 | System_OpenZaurus |
54 | }; | 58 | }; |
@@ -116,23 +120,26 @@ public: | |||
116 | 120 | ||
117 | virtual bool setDisplayStatus ( bool on ); | 121 | virtual bool setDisplayStatus ( bool on ); |
118 | virtual bool setDisplayBrightness ( int brightness ); | 122 | virtual bool setDisplayBrightness ( int brightness ); |
119 | virtual int displayBrightnessResolution ( ) const; | 123 | virtual int displayBrightnessResolution ( ) const; |
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 | ||