From 16d676948a63ab38c908bfdf462186044c859583 Mon Sep 17 00:00:00 2001 From: Manuel Martin Date: Thu, 19 Mar 2020 23:10:06 +0100 Subject: [PATCH] Adds support for gaze devices hover in keyboard & Pico flicker issues (#2995) * Adds support for gaze devices hover in keyboard * Fix Pico dual typing flicker issue --- .../ui/views/CustomKeyboardView.java | 53 ++++++++++++++----- 1 file changed, 39 insertions(+), 14 deletions(-) diff --git a/app/src/common/shared/org/mozilla/vrbrowser/ui/views/CustomKeyboardView.java b/app/src/common/shared/org/mozilla/vrbrowser/ui/views/CustomKeyboardView.java index 8c78092a9..6179066e4 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/ui/views/CustomKeyboardView.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/ui/views/CustomKeyboardView.java @@ -214,7 +214,8 @@ public interface OnKeyboardActionListener { private int mLastCodeY; private int mCurrentKey = NOT_A_KEY; // Fork - private int[] mHoveredKey = new int[2]; + private int[] mHoveredKey = new int[3]; + private int[] mPrevHoveredKey = new int[3]; private int mDownKey = NOT_A_KEY; private long mLastKeyTime; private long mCurrentKeyTime; @@ -344,8 +345,7 @@ public CustomKeyboardView(Context context, AttributeSet attrs, int defStyleAttr, mShadowColor = 0; mShadowRadius = 0; mBackgroundDimAmount = 0.5f; - mHoveredKey[0] = NOT_A_KEY; - mHoveredKey[1] = NOT_A_KEY; + clearHover(); mPreviewPopup = new PopupWindow(context); if (previewLayout != 0) { @@ -759,7 +759,7 @@ private void onBufferDraw() { int[] drawableState = key.getCurrentDrawableState(); if (((CustomKeyboard)mKeyboard).isKeyEnabled(i)) { - if ((mHoveredKey[0] == i || mHoveredKey[1] == i) && !key.pressed) { + if (isKeyHovered(i) && !key.pressed) { // Fork: implement hovered key drawableState = KEY_STATE_HOVERED; } @@ -1146,8 +1146,7 @@ private void sendAccessibilityEventForUnicodeCharacter(int eventType, int code) * @see #invalidateKey(int) */ public void invalidateAllKeys() { - mHoveredKey[0] = NOT_A_KEY; - mHoveredKey[1] = NOT_A_KEY; + clearHover(); mDirtyRect.union(0, 0, getWidth(), getHeight()); mDrawPending = true; invalidate(); @@ -1263,12 +1262,14 @@ public boolean onHoverEvent(MotionEvent event) { keyIndex = getKeyIndices(touchX, touchY, null); } - int prevHovered = mHoveredKey[event.getDeviceId()]; + mPrevHoveredKey[event.getDeviceId()] = mHoveredKey[event.getDeviceId()]; mHoveredKey[event.getDeviceId()] = keyIndex; - if (mHoveredKey[event.getDeviceId()] != NOT_A_KEY && prevHovered != mHoveredKey[event.getDeviceId()]) { - invalidateKey(mHoveredKey[event.getDeviceId()]); + int prevHovered = mPrevHoveredKey[event.getDeviceId()]; + int currentHovered = mHoveredKey[event.getDeviceId()]; + if (currentHovered != NOT_A_KEY && prevHovered != currentHovered) { + invalidateKey(currentHovered); } - if (prevHovered != NOT_A_KEY && prevHovered != mHoveredKey[event.getDeviceId()]) { + if (prevHovered != NOT_A_KEY && prevHovered != currentHovered) { invalidateKey(prevHovered); } return result; @@ -1277,16 +1278,40 @@ public boolean onHoverEvent(MotionEvent event) { @Override public void setHovered(boolean hovered) { if (!hovered) { - mHoveredKey[0] = NOT_A_KEY; - mHoveredKey[1] = NOT_A_KEY; - invalidateAllKeys(); + boolean hasChanged = false; + for (int i=0; i