author | zecke <zecke> | 2004-02-19 01:01:30 (UTC) |
---|---|---|
committer | zecke <zecke> | 2004-02-19 01:01:30 (UTC) |
commit | 3b4b9e070f84ce884a98b4112eaee2cef7530308 (patch) (unidiff) | |
tree | a63b57ec3368e41ea1482a37a41b4b9df2f30fd4 /libopie | |
parent | ab41e301eb7f06af0869844d197e38a7838f3f2d (diff) | |
download | opie-3b4b9e070f84ce884a98b4112eaee2cef7530308.zip opie-3b4b9e070f84ce884a98b4112eaee2cef7530308.tar.gz opie-3b4b9e070f84ce884a98b4112eaee2cef7530308.tar.bz2 |
The hardware keys on the H5xxx are rotated by 270°
so rotate the key events
-rw-r--r-- | libopie/odevice.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 35d6cb4..c5a916b 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -1237,201 +1237,208 @@ void iPAQ::initButtons ( ) | |||
1237 | typedef struct { | 1237 | typedef struct { |
1238 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ | 1238 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ |
1239 | unsigned char TotalTime; /* Units of 5 seconds */ | 1239 | unsigned char TotalTime; /* Units of 5 seconds */ |
1240 | unsigned char OnTime; /* units of 100m/s */ | 1240 | unsigned char OnTime; /* units of 100m/s */ |
1241 | unsigned char OffTime; /* units of 100m/s */ | 1241 | unsigned char OffTime; /* units of 100m/s */ |
1242 | } LED_IN; | 1242 | } LED_IN; |
1243 | 1243 | ||
1244 | typedef struct { | 1244 | typedef struct { |
1245 | unsigned char mode; | 1245 | unsigned char mode; |
1246 | unsigned char pwr; | 1246 | unsigned char pwr; |
1247 | unsigned char brightness; | 1247 | unsigned char brightness; |
1248 | } FLITE_IN; | 1248 | } FLITE_IN; |
1249 | 1249 | ||
1250 | #define LED_ON OD_IOW( 'f', 5, LED_IN ) | 1250 | #define LED_ON OD_IOW( 'f', 5, LED_IN ) |
1251 | #define FLITE_ON OD_IOW( 'f', 7, FLITE_IN ) | 1251 | #define FLITE_ON OD_IOW( 'f', 7, FLITE_IN ) |
1252 | 1252 | ||
1253 | 1253 | ||
1254 | QValueList <OLed> iPAQ::ledList ( ) const | 1254 | QValueList <OLed> iPAQ::ledList ( ) const |
1255 | { | 1255 | { |
1256 | QValueList <OLed> vl; | 1256 | QValueList <OLed> vl; |
1257 | vl << Led_Power; | 1257 | vl << Led_Power; |
1258 | 1258 | ||
1259 | if ( d-> m_model == Model_iPAQ_H38xx ) | 1259 | if ( d-> m_model == Model_iPAQ_H38xx ) |
1260 | vl << Led_BlueTooth; | 1260 | vl << Led_BlueTooth; |
1261 | return vl; | 1261 | return vl; |
1262 | } | 1262 | } |
1263 | 1263 | ||
1264 | QValueList <OLedState> iPAQ::ledStateList ( OLed l ) const | 1264 | QValueList <OLedState> iPAQ::ledStateList ( OLed l ) const |
1265 | { | 1265 | { |
1266 | QValueList <OLedState> vl; | 1266 | QValueList <OLedState> vl; |
1267 | 1267 | ||
1268 | if ( l == Led_Power ) | 1268 | if ( l == Led_Power ) |
1269 | vl << Led_Off << Led_On << Led_BlinkSlow << Led_BlinkFast; | 1269 | vl << Led_Off << Led_On << Led_BlinkSlow << Led_BlinkFast; |
1270 | else if ( l == Led_BlueTooth && d-> m_model == Model_iPAQ_H38xx ) | 1270 | else if ( l == Led_BlueTooth && d-> m_model == Model_iPAQ_H38xx ) |
1271 | vl << Led_Off; // << Led_On << ??? | 1271 | vl << Led_Off; // << Led_On << ??? |
1272 | 1272 | ||
1273 | return vl; | 1273 | return vl; |
1274 | } | 1274 | } |
1275 | 1275 | ||
1276 | OLedState iPAQ::ledState ( OLed l ) const | 1276 | OLedState iPAQ::ledState ( OLed l ) const |
1277 | { | 1277 | { |
1278 | switch ( l ) { | 1278 | switch ( l ) { |
1279 | case Led_Power: | 1279 | case Led_Power: |
1280 | return m_leds [0]; | 1280 | return m_leds [0]; |
1281 | case Led_BlueTooth: | 1281 | case Led_BlueTooth: |
1282 | return m_leds [1]; | 1282 | return m_leds [1]; |
1283 | default: | 1283 | default: |
1284 | return Led_Off; | 1284 | return Led_Off; |
1285 | } | 1285 | } |
1286 | } | 1286 | } |
1287 | 1287 | ||
1288 | bool iPAQ::setLedState ( OLed l, OLedState st ) | 1288 | bool iPAQ::setLedState ( OLed l, OLedState st ) |
1289 | { | 1289 | { |
1290 | static int fd = ::open ( "/dev/touchscreen/0", O_RDWR | O_NONBLOCK ); | 1290 | static int fd = ::open ( "/dev/touchscreen/0", O_RDWR | O_NONBLOCK ); |
1291 | 1291 | ||
1292 | if ( l == Led_Power ) { | 1292 | if ( l == Led_Power ) { |
1293 | if ( fd >= 0 ) { | 1293 | if ( fd >= 0 ) { |
1294 | LED_IN leds; | 1294 | LED_IN leds; |
1295 | ::memset ( &leds, 0, sizeof( leds )); | 1295 | ::memset ( &leds, 0, sizeof( leds )); |
1296 | leds. TotalTime = 0; | 1296 | leds. TotalTime = 0; |
1297 | leds. OnTime = 0; | 1297 | leds. OnTime = 0; |
1298 | leds. OffTime = 1; | 1298 | leds. OffTime = 1; |
1299 | leds. OffOnBlink = 2; | 1299 | leds. OffOnBlink = 2; |
1300 | 1300 | ||
1301 | switch ( st ) { | 1301 | switch ( st ) { |
1302 | case Led_Off : leds. OffOnBlink = 0; break; | 1302 | case Led_Off : leds. OffOnBlink = 0; break; |
1303 | case Led_On : leds. OffOnBlink = 1; break; | 1303 | case Led_On : leds. OffOnBlink = 1; break; |
1304 | case Led_BlinkSlow: leds. OnTime = 10; leds. OffTime = 10; break; | 1304 | case Led_BlinkSlow: leds. OnTime = 10; leds. OffTime = 10; break; |
1305 | case Led_BlinkFast: leds. OnTime = 5; leds. OffTime = 5; break; | 1305 | case Led_BlinkFast: leds. OnTime = 5; leds. OffTime = 5; break; |
1306 | } | 1306 | } |
1307 | 1307 | ||
1308 | if ( ::ioctl ( fd, LED_ON, &leds ) >= 0 ) { | 1308 | if ( ::ioctl ( fd, LED_ON, &leds ) >= 0 ) { |
1309 | m_leds [0] = st; | 1309 | m_leds [0] = st; |
1310 | return true; | 1310 | return true; |
1311 | } | 1311 | } |
1312 | } | 1312 | } |
1313 | } | 1313 | } |
1314 | return false; | 1314 | return false; |
1315 | } | 1315 | } |
1316 | 1316 | ||
1317 | 1317 | ||
1318 | bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, bool autoRepeat ) | 1318 | bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, bool autoRepeat ) |
1319 | { | 1319 | { |
1320 | int newkeycode = keycode; | 1320 | int newkeycode = keycode; |
1321 | 1321 | ||
1322 | switch ( keycode ) { | 1322 | switch ( keycode ) { |
1323 | // H38xx/H39xx have no "Q" key anymore - this is now the Mail key | 1323 | // H38xx/H39xx have no "Q" key anymore - this is now the Mail key |
1324 | case HardKey_Menu: { | 1324 | case HardKey_Menu: { |
1325 | if (( d-> m_model == Model_iPAQ_H38xx ) || | 1325 | if (( d-> m_model == Model_iPAQ_H38xx ) || |
1326 | ( d-> m_model == Model_iPAQ_H39xx ) || | 1326 | ( d-> m_model == Model_iPAQ_H39xx ) || |
1327 | ( d-> m_model == Model_iPAQ_H5xxx)) { | 1327 | ( d-> m_model == Model_iPAQ_H5xxx)) { |
1328 | newkeycode = HardKey_Mail; | 1328 | newkeycode = HardKey_Mail; |
1329 | } | 1329 | } |
1330 | break; | 1330 | break; |
1331 | } | 1331 | } |
1332 | 1332 | ||
1333 | // Rotate cursor keys 180° | 1333 | // Rotate cursor keys 180° or 270° |
1334 | case Key_Left : | 1334 | case Key_Left : |
1335 | case Key_Right: | 1335 | case Key_Right: |
1336 | case Key_Up : | 1336 | case Key_Up : |
1337 | case Key_Down : { | 1337 | case Key_Down : { |
1338 | |||
1338 | if (( d-> m_model == Model_iPAQ_H31xx ) || | 1339 | if (( d-> m_model == Model_iPAQ_H31xx ) || |
1339 | ( d-> m_model == Model_iPAQ_H38xx )) { | 1340 | ( d-> m_model == Model_iPAQ_H38xx )) { |
1340 | newkeycode = Key_Left + ( keycode - Key_Left + 2 ) % 4; | 1341 | newkeycode = Key_Left + ( keycode - Key_Left + 2 ) % 4; |
1341 | } | 1342 | } |
1343 | // Rotate the cursor keys by 270° | ||
1344 | // keycode - Key_Left = position of the button starting from left clockwise | ||
1345 | // add the rotation to it and modolo. No we've the original offset | ||
1346 | // add the offset to the Key_Left key | ||
1347 | if ( d-> m_model == Model_iPAQ_H5xxx ) | ||
1348 | newkeycode = Key_Left + ( keycode - Key_Left + 3 ) % 4; | ||
1342 | break; | 1349 | break; |
1343 | } | 1350 | } |
1344 | 1351 | ||
1345 | // map Power Button short/long press to F34/F35 | 1352 | // map Power Button short/long press to F34/F35 |
1346 | case Key_SysReq: { | 1353 | case Key_SysReq: { |
1347 | if ( isPress ) { | 1354 | if ( isPress ) { |
1348 | if ( m_power_timer ) | 1355 | if ( m_power_timer ) |
1349 | killTimer ( m_power_timer ); | 1356 | killTimer ( m_power_timer ); |
1350 | m_power_timer = startTimer ( 500 ); | 1357 | m_power_timer = startTimer ( 500 ); |
1351 | } | 1358 | } |
1352 | else if ( m_power_timer ) { | 1359 | else if ( m_power_timer ) { |
1353 | killTimer ( m_power_timer ); | 1360 | killTimer ( m_power_timer ); |
1354 | m_power_timer = 0; | 1361 | m_power_timer = 0; |
1355 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false ); | 1362 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false ); |
1356 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false ); | 1363 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false ); |
1357 | } | 1364 | } |
1358 | newkeycode = Key_unknown; | 1365 | newkeycode = Key_unknown; |
1359 | break; | 1366 | break; |
1360 | } | 1367 | } |
1361 | } | 1368 | } |
1362 | 1369 | ||
1363 | if ( newkeycode != keycode ) { | 1370 | if ( newkeycode != keycode ) { |
1364 | if ( newkeycode != Key_unknown ) | 1371 | if ( newkeycode != Key_unknown ) |
1365 | QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat ); | 1372 | QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat ); |
1366 | return true; | 1373 | return true; |
1367 | } | 1374 | } |
1368 | else | 1375 | else |
1369 | return false; | 1376 | return false; |
1370 | } | 1377 | } |
1371 | 1378 | ||
1372 | void iPAQ::timerEvent ( QTimerEvent * ) | 1379 | void iPAQ::timerEvent ( QTimerEvent * ) |
1373 | { | 1380 | { |
1374 | killTimer ( m_power_timer ); | 1381 | killTimer ( m_power_timer ); |
1375 | m_power_timer = 0; | 1382 | m_power_timer = 0; |
1376 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false ); | 1383 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false ); |
1377 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false ); | 1384 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false ); |
1378 | } | 1385 | } |
1379 | 1386 | ||
1380 | 1387 | ||
1381 | void iPAQ::alarmSound ( ) | 1388 | void iPAQ::alarmSound ( ) |
1382 | { | 1389 | { |
1383 | #ifndef QT_NO_SOUND | 1390 | #ifndef QT_NO_SOUND |
1384 | static Sound snd ( "alarm" ); | 1391 | static Sound snd ( "alarm" ); |
1385 | int fd; | 1392 | int fd; |
1386 | int vol; | 1393 | int vol; |
1387 | bool vol_reset = false; | 1394 | bool vol_reset = false; |
1388 | 1395 | ||
1389 | if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { | 1396 | if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { |
1390 | if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { | 1397 | if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { |
1391 | Config cfg ( "qpe" ); | 1398 | Config cfg ( "qpe" ); |
1392 | cfg. setGroup ( "Volume" ); | 1399 | cfg. setGroup ( "Volume" ); |
1393 | 1400 | ||
1394 | int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); | 1401 | int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); |
1395 | if ( volalarm < 0 ) | 1402 | if ( volalarm < 0 ) |
1396 | volalarm = 0; | 1403 | volalarm = 0; |
1397 | else if ( volalarm > 100 ) | 1404 | else if ( volalarm > 100 ) |
1398 | volalarm = 100; | 1405 | volalarm = 100; |
1399 | volalarm |= ( volalarm << 8 ); | 1406 | volalarm |= ( volalarm << 8 ); |
1400 | 1407 | ||
1401 | if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 ) | 1408 | if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 ) |
1402 | vol_reset = true; | 1409 | vol_reset = true; |
1403 | } | 1410 | } |
1404 | } | 1411 | } |
1405 | 1412 | ||
1406 | snd. play ( ); | 1413 | snd. play ( ); |
1407 | while ( !snd. isFinished ( )) | 1414 | while ( !snd. isFinished ( )) |
1408 | qApp-> processEvents ( ); | 1415 | qApp-> processEvents ( ); |
1409 | 1416 | ||
1410 | if ( fd >= 0 ) { | 1417 | if ( fd >= 0 ) { |
1411 | if ( vol_reset ) | 1418 | if ( vol_reset ) |
1412 | ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); | 1419 | ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); |
1413 | ::close ( fd ); | 1420 | ::close ( fd ); |
1414 | } | 1421 | } |
1415 | #endif | 1422 | #endif |
1416 | } | 1423 | } |
1417 | 1424 | ||
1418 | 1425 | ||
1419 | bool iPAQ::setSoftSuspend ( bool soft ) | 1426 | bool iPAQ::setSoftSuspend ( bool soft ) |
1420 | { | 1427 | { |
1421 | bool res = false; | 1428 | bool res = false; |
1422 | int fd; | 1429 | int fd; |
1423 | 1430 | ||
1424 | if (( fd = ::open ( "/proc/sys/ts/suspend_button_mode", O_WRONLY )) >= 0 ) { | 1431 | if (( fd = ::open ( "/proc/sys/ts/suspend_button_mode", O_WRONLY )) >= 0 ) { |
1425 | if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 ) | 1432 | if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 ) |
1426 | res = true; | 1433 | res = true; |
1427 | else | 1434 | else |
1428 | ::perror ( "write to /proc/sys/ts/suspend_button_mode" ); | 1435 | ::perror ( "write to /proc/sys/ts/suspend_button_mode" ); |
1429 | 1436 | ||
1430 | ::close ( fd ); | 1437 | ::close ( fd ); |
1431 | } | 1438 | } |
1432 | else | 1439 | else |
1433 | ::perror ( "/proc/sys/ts/suspend_button_mode" ); | 1440 | ::perror ( "/proc/sys/ts/suspend_button_mode" ); |
1434 | 1441 | ||
1435 | return res; | 1442 | return res; |
1436 | } | 1443 | } |
1437 | 1444 | ||