author | sandman <sandman> | 2002-10-29 18:43:23 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-10-29 18:43:23 (UTC) |
commit | 5ac67b8aece5aca20419f8953f88a36fd729adfc (patch) (unidiff) | |
tree | 3ce57c7a938d36ce40ff0dfe4b114233febf7b08 /libopie/odevice.cpp | |
parent | 45d9a30ec17b5146ffdac8e776003752fe2deeea (diff) | |
download | opie-5ac67b8aece5aca20419f8953f88a36fd729adfc.zip opie-5ac67b8aece5aca20419f8953f88a36fd729adfc.tar.gz opie-5ac67b8aece5aca20419f8953f88a36fd729adfc.tar.bz2 |
- redone the Model enum to make it easy to check for series (like: is this an
iPAQ - and not is this a 31xx or 36xx or ...)
- fixed the disply brightness resolution bug on H38xx
-rw-r--r-- | libopie/odevice.cpp | 34 |
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 | |||
@@ -405,12 +405,14 @@ void iPAQ::init ( ) | |||
405 | else if ( d-> m_modelstr == "H3600" ) | 405 | else if ( d-> m_modelstr == "H3600" ) |
406 | d-> m_model = Model_iPAQ_H36xx; | 406 | d-> m_model = Model_iPAQ_H36xx; |
407 | else if ( d-> m_modelstr == "H3700" ) | 407 | else if ( d-> m_modelstr == "H3700" ) |
408 | d-> m_model = Model_iPAQ_H37xx; | 408 | d-> m_model = Model_iPAQ_H37xx; |
409 | else if ( d-> m_modelstr == "H3800" ) | 409 | else if ( d-> m_modelstr == "H3800" ) |
410 | d-> m_model = Model_iPAQ_H38xx; | 410 | d-> m_model = Model_iPAQ_H38xx; |
411 | else if ( d-> m_modelstr == "H3900" ) | ||
412 | d-> m_model = Model_iPAQ_H39xx; | ||
411 | else | 413 | else |
412 | d-> m_model = Model_Unknown; | 414 | d-> m_model = Model_Unknown; |
413 | 415 | ||
414 | f. close ( ); | 416 | f. close ( ); |
415 | } | 417 | } |
416 | 418 | ||
@@ -652,23 +654,19 @@ bool iPAQ::setSoftSuspend ( bool soft ) | |||
652 | 654 | ||
653 | bool iPAQ::setDisplayBrightness ( int bright ) | 655 | bool iPAQ::setDisplayBrightness ( int bright ) |
654 | { | 656 | { |
655 | bool res = false; | 657 | bool res = false; |
656 | int fd; | 658 | int fd; |
657 | 659 | ||
658 | if ( bright > 255 ) | 660 | int maxbright = displayBrightnessResolution ( ); |
659 | bright = 255; | 661 | |
662 | if ( bright > maxbright ) | ||
663 | bright = maxbright; | ||
660 | if ( bright < 0 ) | 664 | if ( bright < 0 ) |
661 | bright = 0; | 665 | bright = 0; |
662 | 666 | ||
663 | // 128 is the maximum if you want a decent lifetime for the LCD | ||
664 | |||
665 | if ( bright > 1 ) | ||
666 | bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic | ||
667 | //bright = ( bright + 1 ) / 2; | ||
668 | |||
669 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { | 667 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { |
670 | FLITE_IN bl; | 668 | FLITE_IN bl; |
671 | bl. mode = 1; | 669 | bl. mode = 1; |
672 | bl. pwr = bright ? 1 : 0; | 670 | bl. pwr = bright ? 1 : 0; |
673 | bl. brightness = bright; | 671 | bl. brightness = bright; |
674 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); | 672 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); |
@@ -676,13 +674,25 @@ bool iPAQ::setDisplayBrightness ( int bright ) | |||
676 | } | 674 | } |
677 | return res; | 675 | return res; |
678 | } | 676 | } |
679 | 677 | ||
680 | int iPAQ::displayBrightnessResolution ( ) const | 678 | int iPAQ::displayBrightnessResolution ( ) const |
681 | { | 679 | { |
682 | return 256; // really 128, but logarithmic control is smoother this way | 680 | switch ( model ( )) { |
681 | case Model_iPAQ_H31xx: | ||
682 | case Model_iPAQ_H36xx: | ||
683 | case Model_iPAQ_H37xx: | ||
684 | return 128; // really 256, but >128 could damage the LCD | ||
685 | |||
686 | case Model_iPAQ_H38xx: | ||
687 | case Model_iPAQ_H39xx: | ||
688 | return 64; | ||
689 | |||
690 | default: | ||
691 | return 2; | ||
692 | } | ||
683 | } | 693 | } |
684 | 694 | ||
685 | 695 | ||
686 | bool iPAQ::hasLightSensor ( ) const | 696 | bool iPAQ::hasLightSensor ( ) const |
687 | { | 697 | { |
688 | return true; | 698 | return true; |
@@ -954,13 +964,7 @@ bool Zaurus::setDisplayBrightness ( int bright ) | |||
954 | 964 | ||
955 | int Zaurus::displayBrightnessResolution ( ) const | 965 | int Zaurus::displayBrightnessResolution ( ) const |
956 | { | 966 | { |
957 | return 5; | 967 | return 5; |
958 | } | 968 | } |
959 | 969 | ||
960 | //QValueList <int> Zaurus::keyList ( ) const | ||
961 | //{ | ||
962 | //QValueList <int> vl; | ||
963 | //vl << HardKey_Datebook << HardKey_Contacts << HardKey_Mail << HardKey_Menu << HardKey_Home << HardKey_Suspend << HardKey_Backlight; | ||
964 | //return vl; | ||
965 | //} | ||
966 | 970 | ||