aboutsummaryrefslogtreecommitdiff
path: root/backends
diff options
context:
space:
mode:
authorNicolas Bacca2004-05-09 14:53:05 +0000
committerNicolas Bacca2004-05-09 14:53:05 +0000
commit659b84633a1f01f8804a12fe2e4b286dfde363c0 (patch)
tree66d49c9baa7e1128c51342e52dcc5a0dbe0e385e /backends
parentb3ed0f2029538ee66505f8490efd84deb202058e (diff)
downloadscummvm-rg350-659b84633a1f01f8804a12fe2e4b286dfde363c0.tar.gz
scummvm-rg350-659b84633a1f01f8804a12fe2e4b286dfde363c0.tar.bz2
scummvm-rg350-659b84633a1f01f8804a12fe2e4b286dfde363c0.zip
Remove GAPI hardware keys which is handled by SDL now
svn-id: r13825
Diffstat (limited to 'backends')
-rw-r--r--backends/wince/CEDevice.cpp92
-rw-r--r--backends/wince/CEDevice.h6
2 files changed, 38 insertions, 60 deletions
diff --git a/backends/wince/CEDevice.cpp b/backends/wince/CEDevice.cpp
index b9fd8e789d..762db9e8e8 100644
--- a/backends/wince/CEDevice.cpp
+++ b/backends/wince/CEDevice.cpp
@@ -22,14 +22,29 @@
#include "stdafx.h"
#include "CEDevice.h"
-bool CEDevice::_hasGAPIMapping = false;
-struct GXKeyList CEDevice::_portrait_keys = {0};
+#include <SDL.h>
#define KEY_CALENDAR 0xc1
#define KEY_CONTACTS 0xc2
#define KEY_INBOX 0xc3
#define KEY_TASK 0xc4
+#ifdef WIN32_PLATFORM_WFSP
+const char* SMARTPHONE_KEYS_NAME[] = {
+ "1", "2", "3","4", "5", "6", "7", "8", "9", "*", "0", "#",
+ "Home", "Back", "Up", "Down", "Left", "Right", "Action", "Hang up", "Call",
+ "Soft 1", "Soft 2", "Power", "Volume Up" ,"Volume Down", "Record", "None",
+ 0
+};
+
+const int SMARTPHONE_KEYS_MAPPING[] = {
+ '1', '2', '3', '4', '5', '6', '7', '8', '9', VK_F8, '0', VK_F9,
+ VK_LWIN, VK_ESCAPE, VK_UP, VK_DOWN, VK_LEFT, VK_RIGHT, VK_RETURN, VK_F4, VK_F3,
+ VK_F1, VK_F2, VK_F18, VK_F6, VK_F7, VK_F10, 0xff, 0
+};
+#endif
+
+
bool CEDevice::hasPocketPCResolution() {
return (GetSystemMetrics(SM_CXSCREEN) < 320 && GetSystemMetrics(SM_CXSCREEN) >= 240);
}
@@ -46,64 +61,12 @@ bool CEDevice::hasSmartphoneResolution() {
return (GetSystemMetrics(SM_CXSCREEN) < 240);
}
-bool CEDevice::enableHardwareKeyMapping() {
- HINSTANCE GAPI_handle;
- tGXVoidFunction GAPIOpenInput;
- tGXGetDefaultKeys GAPIGetDefaultKeys;
-
- _hasGAPIMapping = false;
- GAPI_handle = LoadLibrary(TEXT("gx.dll"));
- if (!GAPI_handle)
- return false;
- GAPIOpenInput = (tGXVoidFunction)GetProcAddress(GAPI_handle, TEXT("?GXOpenInput@@YAHXZ"));
- if (!GAPIOpenInput)
- return false;
- GAPIGetDefaultKeys = (tGXGetDefaultKeys)GetProcAddress(GAPI_handle, TEXT("?GXGetDefaultKeys@@YA?AUGXKeyList@@H@Z"));
- if (!GAPIGetDefaultKeys)
- return false;
- GAPIOpenInput();
- _portrait_keys = GAPIGetDefaultKeys(GX_NORMALKEYS);
- _hasGAPIMapping = true;
- FreeLibrary(GAPI_handle);
- return true;
-}
-
-bool CEDevice::disableHardwareKeyMapping() {
- HINSTANCE GAPI_handle;
- tGXVoidFunction GAPICloseInput;
-
- GAPI_handle = LoadLibrary(TEXT("gx.dll"));
- if (!GAPI_handle)
- return false;
- GAPICloseInput = (tGXVoidFunction)GetProcAddress(GAPI_handle, TEXT("?GXCloseInput@@YAHXZ"));
- if (!GAPICloseInput)
- return false;
- GAPICloseInput();
- FreeLibrary(GAPI_handle);
- return true;
-}
-
Common::String CEDevice::getKeyName(unsigned int keyCode) {
char key_name[10];
if (!keyCode)
return "No key";
- if (keyCode == (unsigned int)_portrait_keys.vkA)
- return "Button A";
- if (keyCode == (unsigned int)_portrait_keys.vkB)
- return "Button B";
- if (keyCode == (unsigned int)_portrait_keys.vkC)
- return "Button C";
- if (keyCode == (unsigned int)_portrait_keys.vkStart)
- return "Button Start";
- if (keyCode == (unsigned int)_portrait_keys.vkUp)
- return "Pad Up";
- if (keyCode == (unsigned int)_portrait_keys.vkDown)
- return "Pad Down";
- if (keyCode == (unsigned int)_portrait_keys.vkLeft)
- return "Pad Left";
- if (keyCode == (unsigned int)_portrait_keys.vkRight)
- return "Pad Right";
+
if (keyCode == KEY_CALENDAR)
return "Button Calendar";
if (keyCode == KEY_CONTACTS)
@@ -112,6 +75,25 @@ Common::String CEDevice::getKeyName(unsigned int keyCode) {
return "Button Inbox";
if (keyCode == KEY_TASK)
return "Button Tasks";
+ if (keyCode == SDLK_F1)
+ return "F1 (hard 1)";
+ if (keyCode == SDLK_F2)
+ return "F2 (hard 2)";
+ if (keyCode == SDLK_F3)
+ return "F3 (hard 3)";
+ if (keyCode == SDLK_F4)
+ return "F4 (hard 4)";
+
+#ifdef WIN32_PLATFORM_WFSP
+ if (hasSmartphoneResolution()) {
+ int i = 0;
+ while (SMARTPHONE_KEYS_MAPPING[i]) {
+ if (keyCode == SMARTPHONE_KEYS_MAPPING[i])
+ return SMARTPHONE_KEYS_NAME[i];
+ i++;
+ }
+ }
+#endif
sprintf(key_name, "Key %.4x", keyCode);
return key_name;
diff --git a/backends/wince/CEDevice.h b/backends/wince/CEDevice.h
index 05558f6663..b8b0dd3f8f 100644
--- a/backends/wince/CEDevice.h
+++ b/backends/wince/CEDevice.h
@@ -35,15 +35,11 @@ class CEDevice {
static bool hasDesktopResolution();
static bool hasWideResolution();
static bool hasSmartphoneResolution();
- static bool enableHardwareKeyMapping();
- static bool disableHardwareKeyMapping();
static Common::String getKeyName(unsigned int keyCode);
private:
- static bool _hasGAPIMapping;
- static struct GXKeyList _portrait_keys;
typedef int (*tGXVoidFunction)(void);
typedef struct GXKeyList (*tGXGetDefaultKeys)(int);
};
-#endif \ No newline at end of file
+#endif