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 | |||
@@ -62,48 +62,51 @@ public: | |||
62 | 62 | ||
63 | QString m_systemstr; | 63 | QString m_systemstr; |
64 | OSystem m_system; | 64 | OSystem m_system; |
65 | 65 | ||
66 | QString m_sysverstr; | 66 | QString m_sysverstr; |
67 | }; | 67 | }; |
68 | 68 | ||
69 | 69 | ||
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 | ||
102 | public: | 105 | public: |
103 | virtual bool setSoftSuspend ( bool soft ); | 106 | virtual bool setSoftSuspend ( bool soft ); |
104 | 107 | ||
105 | virtual bool setDisplayBrightness ( int b ); | 108 | virtual bool setDisplayBrightness ( int b ); |
106 | virtual int displayBrightnessResolution ( ) const; | 109 | virtual int displayBrightnessResolution ( ) const; |
107 | 110 | ||
108 | virtual void alarmSound ( ); | 111 | virtual void alarmSound ( ); |
109 | virtual void keySound ( ); | 112 | virtual void keySound ( ); |
@@ -335,48 +338,57 @@ void ODevice::touchSound ( ) | |||
335 | #endif | 338 | #endif |
336 | } | 339 | } |
337 | 340 | ||
338 | 341 | ||
339 | QValueList <OLed> ODevice::ledList ( ) const | 342 | QValueList <OLed> ODevice::ledList ( ) const |
340 | { | 343 | { |
341 | return QValueList <OLed> ( ); | 344 | return QValueList <OLed> ( ); |
342 | } | 345 | } |
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 ( ) |
375 | { | 387 | { |
376 | d-> m_vendorstr = "HP"; | 388 | d-> m_vendorstr = "HP"; |
377 | d-> m_vendor = Vendor_HP; | 389 | d-> m_vendor = Vendor_HP; |
378 | 390 | ||
379 | QFile f ( "/proc/hal/model" ); | 391 | QFile f ( "/proc/hal/model" ); |
380 | 392 | ||
381 | if ( f. open ( IO_ReadOnly )) { | 393 | if ( f. open ( IO_ReadOnly )) { |
382 | QTextStream ts ( &f ); | 394 | QTextStream ts ( &f ); |
@@ -645,48 +657,78 @@ bool iPAQ::setDisplayBrightness ( int bright ) | |||
645 | 657 | ||
646 | // 128 is the maximum if you want a decent lifetime for the LCD | 658 | // 128 is the maximum if you want a decent lifetime for the LCD |
647 | 659 | ||
648 | if ( bright > 1 ) | 660 | if ( bright > 1 ) |
649 | bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic | 661 | bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic |
650 | //bright = ( bright + 1 ) / 2; | 662 | //bright = ( bright + 1 ) / 2; |
651 | 663 | ||
652 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { | 664 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { |
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" ); |
685 | 727 | ||
686 | if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { | 728 | if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { |
687 | d-> m_systemstr = "OpenZaurus"; | 729 | d-> m_systemstr = "OpenZaurus"; |
688 | d-> m_system = System_OpenZaurus; | 730 | d-> m_system = System_OpenZaurus; |
689 | 731 | ||
690 | f. close ( ); | 732 | f. close ( ); |
691 | 733 | ||
692 | f. setName ( "/etc/oz_version" ); | 734 | f. setName ( "/etc/oz_version" ); |
diff --git a/libopie/odevice.h b/libopie/odevice.h index 38f3787..be2a9c7 100644 --- a/libopie/odevice.h +++ b/libopie/odevice.h | |||
@@ -9,54 +9,58 @@ | |||
9 | This library is distributed in the hope that it will be useful, | 9 | This library is distributed in the hope that it will be useful, |
10 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
12 | Library General Public License for more details. | 12 | Library General Public License for more details. |
13 | 13 | ||
14 | You should have received a copy of the GNU Library General Public License | 14 | You should have received a copy of the GNU Library General Public License |
15 | along with this library; see the file COPYING.LIB. If not, write to | 15 | along with this library; see the file COPYING.LIB. If not, write to |
16 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 16 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
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 | }; |
55 | 59 | ||
56 | enum OLedState { | 60 | enum OLedState { |
57 | Led_Off, | 61 | Led_Off, |
58 | Led_On, | 62 | Led_On, |
59 | Led_BlinkSlow, | 63 | Led_BlinkSlow, |
60 | Led_BlinkFast | 64 | Led_BlinkFast |
61 | }; | 65 | }; |
62 | 66 | ||
@@ -108,31 +112,34 @@ public: | |||
108 | OSystem system ( ) const; | 112 | OSystem system ( ) const; |
109 | 113 | ||
110 | QString systemVersionString ( ) const; | 114 | QString systemVersionString ( ) const; |
111 | 115 | ||
112 | // system | 116 | // system |
113 | 117 | ||
114 | virtual bool setSoftSuspend ( bool on ); | 118 | virtual bool setSoftSuspend ( bool on ); |
115 | virtual bool suspend ( ); | 119 | virtual bool suspend ( ); |
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 | ||