diff options
author | 2014-06-27 10:17:49 +0000 | |
---|---|---|
committer | 2014-06-26 23:19:11 +0000 | |
commit | d966c0727fc7706b2ed28e09cd323f79236292c8 (patch) | |
tree | 27c05fd6e39fa0351c617aea7d9a16fae5ebcab5 /java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java | |
parent | 1a2f3c4433d154c07c5017066c5dfe0f0070d520 (diff) | |
parent | 1e3167229519843b83ba8bea7d78a82ffba236bc (diff) | |
download | latinime-d966c0727fc7706b2ed28e09cd323f79236292c8.tar.gz latinime-d966c0727fc7706b2ed28e09cd323f79236292c8.tar.xz latinime-d966c0727fc7706b2ed28e09cd323f79236292c8.zip |
Merge "Support performAccessibilityAction for CLICK and LONG_CLICK"
Diffstat (limited to 'java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java')
-rw-r--r-- | java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java b/java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java index 328d9ec0d..66b0acb2f 100644 --- a/java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java +++ b/java/src/com/android/inputmethod/accessibility/KeyboardAccessibilityNodeProvider.java @@ -47,7 +47,8 @@ import java.util.List; * virtual views, thus conveying their logical structure. * </p> */ -final class KeyboardAccessibilityNodeProvider extends AccessibilityNodeProviderCompat { +final class KeyboardAccessibilityNodeProvider<KV extends KeyboardView> + extends AccessibilityNodeProviderCompat { private static final String TAG = KeyboardAccessibilityNodeProvider.class.getSimpleName(); // From {@link android.view.accessibility.AccessibilityNodeInfo#UNDEFINED_ITEM_ID}. @@ -69,16 +70,20 @@ final class KeyboardAccessibilityNodeProvider extends AccessibilityNodeProviderC private int mHoveringNodeId = UNDEFINED; /** The keyboard view to provide an accessibility node info. */ - private final KeyboardView mKeyboardView; + private final KV mKeyboardView; + /** The accessibility delegate. */ + private final KeyboardAccessibilityDelegate<KV> mDelegate; /** The current keyboard. */ private Keyboard mKeyboard; - public KeyboardAccessibilityNodeProvider(final KeyboardView keyboardView) { + public KeyboardAccessibilityNodeProvider(final KV keyboardView, + final KeyboardAccessibilityDelegate<KV> delegate) { super(); mKeyCodeDescriptionMapper = KeyCodeDescriptionMapper.getInstance(); mAccessibilityUtils = AccessibilityUtils.getInstance(); mKeyboardView = keyboardView; + mDelegate = delegate; // Since this class is constructed lazily, we might not get a subsequent // call to setKeyboard() and therefore need to call it now. @@ -287,9 +292,11 @@ final class KeyboardAccessibilityNodeProvider extends AccessibilityNodeProviderC return true; case AccessibilityNodeInfoCompat.ACTION_CLICK: sendAccessibilityEventForKey(key, AccessibilityEvent.TYPE_VIEW_CLICKED); + mDelegate.performClickOn(key); return true; case AccessibilityNodeInfoCompat.ACTION_LONG_CLICK: sendAccessibilityEventForKey(key, AccessibilityEvent.TYPE_VIEW_LONG_CLICKED); + mDelegate.performLongClickOn(key); return true; default: return false; |