diff options
author | Dianne Hackborn <hackbod@google.com> | 2009-07-14 12:06:54 -0700 |
---|---|---|
committer | Dianne Hackborn <hackbod@google.com> | 2009-07-14 18:51:53 -0700 |
commit | e3dd884815b2aaeec4241859722ab603e0b1466b (patch) | |
tree | ab595122c085720a236251afbfe78af248d87bc5 /include/ui/EventHub.h | |
parent | 334a67740c9f7f35fa9ee93cf0f8051d41ce2d7a (diff) | |
download | frameworks_base-e3dd884815b2aaeec4241859722ab603e0b1466b.zip frameworks_base-e3dd884815b2aaeec4241859722ab603e0b1466b.tar.gz frameworks_base-e3dd884815b2aaeec4241859722ab603e0b1466b.tar.bz2 |
Implement virtual button support.
The kernel can now publish a property describing the layout of virtual
hardware buttons on the touchscreen. These outside of the display
area (outside of the absolute x and y controller range the driver
reports), and when the user presses on them a key event will be
generated rather than a touch event.
This also includes a number of tweaks to the absolute controller
processing to make things work better on the new screens. For
example, we now reject down events outside of the display area.
Still left to be done is the ability to cancel a key down event,
so the user can slide up from the virtual keys to the touch screen
without causing a virtual key to execute.
Diffstat (limited to 'include/ui/EventHub.h')
-rw-r--r-- | include/ui/EventHub.h | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/include/ui/EventHub.h b/include/ui/EventHub.h index e12c4f1..d9c0af2 100644 --- a/include/ui/EventHub.h +++ b/include/ui/EventHub.h @@ -73,6 +73,9 @@ public: int getKeycodeState(int key) const; int getKeycodeState(int32_t deviceId, int key) const; + status_t scancodeToKeycode(int32_t deviceId, int scancode, + int32_t* outKeycode, uint32_t* outFlags) const; + // special type codes when devices are added/removed. enum { DEVICE_ADDED = 0x10000000, @@ -121,7 +124,7 @@ private: mutable Mutex mLock; bool mHaveFirstKeyboard; - int32_t mFirstKeyboardId; // the API is that the build in keyboard is id 0, so map it + int32_t mFirstKeyboardId; // the API is that the built-in keyboard is id 0, so map it struct device_ent { device_t* device; |