summaryrefslogtreecommitdiff
authoraquadran <aquadran>2007-03-17 22:08:43 (UTC)
committer aquadran <aquadran>2007-03-17 22:08:43 (UTC)
commitfb862bdc6c9a6f5b6e7529823eb4b56cc7085a59 (patch) (side-by-side diff)
tree11ab2be67d1ffc1fabdb0cb489bc14205117d8cd
parent794f3bb9cf973e59a8ca773f42d72a6476b7a4e1 (diff)
downloadopie-fb862bdc6c9a6f5b6e7529823eb4b56cc7085a59.zip
opie-fb862bdc6c9a6f5b6e7529823eb4b56cc7085a59.tar.gz
opie-fb862bdc6c9a6f5b6e7529823eb4b56cc7085a59.tar.bz2
match h1910 and asus 716 to other pda latest changes
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--libopie2/opiecore/device/odevice_ipaq.cpp3
-rw-r--r--libopie2/opiecore/device/odevice_mypal.cpp45
2 files changed, 22 insertions, 26 deletions
diff --git a/libopie2/opiecore/device/odevice_ipaq.cpp b/libopie2/opiecore/device/odevice_ipaq.cpp
index 6dc1295..b18fd32 100644
--- a/libopie2/opiecore/device/odevice_ipaq.cpp
+++ b/libopie2/opiecore/device/odevice_ipaq.cpp
@@ -448,11 +448,10 @@ int iPAQ::displayBrightnessResolution() const
return 64;
case Model_iPAQ_H5xxx:
case Model_iPAQ_HX4700:
case Model_iPAQ_H4xxx:
- return 255;
case Model_iPAQ_H191x:
- return 7;
+ return 255;
case Model_iPAQ_H1940:
return 44;
default:
return 2;
diff --git a/libopie2/opiecore/device/odevice_mypal.cpp b/libopie2/opiecore/device/odevice_mypal.cpp
index 73b31cb..28e92bf 100644
--- a/libopie2/opiecore/device/odevice_mypal.cpp
+++ b/libopie2/opiecore/device/odevice_mypal.cpp
@@ -139,18 +139,22 @@ bool MyPal::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress,
{
int newkeycode = keycode;
switch ( keycode ) {
+ // QT has strange screen coordinate system, so depending
+ // on native device screen orientation, we need to rotate cursor keys
case Key_Left :
case Key_Right:
case Key_Up :
case Key_Down : {
- // Rotate the cursor keys by 270
- // keycode - Key_Left = position of the button starting from left clockwise
- // add the rotation to it and modolo. No we've the original offset
- // add the offset to the Key_Left key
- if ( d->m_model == Model_MyPal_716 )
- newkeycode = Key_Left + ( keycode - Key_Left + 3 ) % 4;
+ int quarters;
+ switch (d->m_rotation) {
+ case Rot0: quarters = 3/*270deg*/; break;
+ case Rot90: quarters = 2/*270deg*/; break;
+ case Rot180: quarters = 1/*270deg*/; break;
+ case Rot270: quarters = 0/*270deg*/; break;
+ }
+ newkeycode = Key_Left + ( keycode - Key_Left + quarters ) % 4;
break;
}
// map Power Button short/long press
@@ -209,26 +213,17 @@ bool MyPal::setDisplayBrightness ( int bright )
bright = 255;
if ( bright < 0 )
bright = 0;
- QDir sysClass( "/sys/class/backlight/pxafb/" );
+ QDir sysClass( "/sys/class/backlight/" );
sysClass.setFilter(QDir::Dirs);
- int fd;
- if ( sysClass.exists() ) {
- QString sysClassPath = sysClass.absFilePath( "/sys/class/backlight/pxafb/power" );
- fd = ::open( sysClassPath, O_WRONLY | O_NONBLOCK );
- if ( fd ) {
- char buf[10];
- buf[0] = bright ? 0 : 4;
- buf[1] = '\0';
- res = ( ::write( fd, &buf[0], 2 ) == 0 );
- ::close( fd );
- }
- sysClassPath = sysClass.absFilePath( "/sys/class/backlight/pxafb/brightness" );
- fd = ::open( sysClassPath, O_WRONLY | O_NONBLOCK );
+ if ( sysClass.exists() && sysClass.count() > 2 ) {
+ QString sysClassPath = sysClass.absFilePath( sysClass[2] + "/brightness" );
+ int fd = ::open( sysClassPath, O_WRONLY|O_NONBLOCK );
if ( fd ) {
char buf[100];
- int len = ::snprintf( &buf[0], sizeof buf, "%d", bright );
+ int val = bright * displayBrightnessResolution() / 255;
+ int len = ::snprintf( &buf[0], sizeof buf, "%d", val );
res = ( ::write( fd, &buf[0], len ) == 0 );
::close( fd );
}
}
@@ -239,9 +234,9 @@ bool MyPal::setDisplayBrightness ( int bright )
int MyPal::displayBrightnessResolution() const
{
switch ( model()) {
case Model_MyPal_716:
- return 7;
+ return 255;
default:
return OAbstractMobileDevice::displayBrightnessResolution();
}
}
@@ -251,18 +246,20 @@ bool MyPal::setDisplayStatus ( bool on )
bool res = false;
QDir sysClass( "/sys/class/lcd/" );
sysClass.setFilter(QDir::Dirs);
- if ( sysClass.exists() ) {
- QString sysClassPath = sysClass.absFilePath( "/sys/class/lcd/pxafb/power" );
+ if ( sysClass.exists() && sysClass.count() > 2 ) {
+ QString sysClassPath = sysClass.absFilePath( sysClass[2] + "/power" );
int fd = ::open( sysClassPath, O_WRONLY | O_NONBLOCK );
if ( fd ) {
char buf[10];
buf[0] = on ? 0 : 4;
buf[1] = '\0';
res = ( ::write( fd, &buf[0], 2 ) == 0 );
::close( fd );
}
+ } else {
+ res = OAbstractMobileDevice::setDisplayStatus(on);
}
return res;
}