summaryrefslogtreecommitdiff
path: root/libopie/odevice.cpp
Side-by-side diff
Diffstat (limited to 'libopie/odevice.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/odevice.cpp34
1 files changed, 19 insertions, 15 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp
index 4c49c4f..8f4e296 100644
--- a/libopie/odevice.cpp
+++ b/libopie/odevice.cpp
@@ -410,2 +410,4 @@ void iPAQ::init ( )
d-> m_model = Model_iPAQ_H38xx;
+ else if ( d-> m_modelstr == "H3900" )
+ d-> m_model = Model_iPAQ_H39xx;
else
@@ -657,4 +659,6 @@ bool iPAQ::setDisplayBrightness ( int bright )
- if ( bright > 255 )
- bright = 255;
+ int maxbright = displayBrightnessResolution ( );
+
+ if ( bright > maxbright )
+ bright = maxbright;
if ( bright < 0 )
@@ -662,8 +666,2 @@ bool iPAQ::setDisplayBrightness ( int bright )
- // 128 is the maximum if you want a decent lifetime for the LCD
-
- if ( bright > 1 )
- bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic
-// bright = ( bright + 1 ) / 2;
-
if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) {
@@ -681,3 +679,15 @@ int iPAQ::displayBrightnessResolution ( ) const
{
- return 256; // really 128, but logarithmic control is smoother this way
+ switch ( model ( )) {
+ case Model_iPAQ_H31xx:
+ case Model_iPAQ_H36xx:
+ case Model_iPAQ_H37xx:
+ return 128; // really 256, but >128 could damage the LCD
+
+ case Model_iPAQ_H38xx:
+ case Model_iPAQ_H39xx:
+ return 64;
+
+ default:
+ return 2;
+ }
}
@@ -959,8 +969,2 @@ int Zaurus::displayBrightnessResolution ( ) const
-//QValueList <int> Zaurus::keyList ( ) const
-//{
-// QValueList <int> vl;
-// vl << HardKey_Datebook << HardKey_Contacts << HardKey_Mail << HardKey_Menu << HardKey_Home << HardKey_Suspend << HardKey_Backlight;
-// return vl;
-//}