From 13d336235b9ef9bd4a0695d4843a82fb7b9b5fd6 Mon Sep 17 00:00:00 2001 From: Daron Walters Date: Thu, 28 May 2020 16:12:50 -0400 Subject: [PATCH] Fixes #2948 - Added hover listener for the full media control to handle case when over exits outside of controls (#3386) --- .../ui/widgets/MediaControlsWidget.java | 20 ++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/MediaControlsWidget.java b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/MediaControlsWidget.java index cdb78f8c9..af0e78c31 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/MediaControlsWidget.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/MediaControlsWidget.java @@ -207,6 +207,25 @@ public void onSeekPreview(String aText, double aRatio) { } mVolumeControl.requestFocusFromTouch(); }); + + + this.setOnHoverListener((v, event) -> { + if (mMedia == null) { + return false; + } + /*this handles the case where the user + holds the volume slider up/down past the volume control + control then hovers, which wont be picked up by the + volume control hover listener. in this case the widget itself + needs to handle this case + */ + if ((event.getX() < 0) || (event.getY() < 0)) { + mHideVolumeSlider = true; + startVolumeCtrlHandler(); + } + + return false; + }); mMediaVolumeButton.setOnHoverListener((v, event) -> { float startY = v.getY(); float maxY = startY + v.getHeight(); @@ -214,7 +233,6 @@ public void onSeekPreview(String aText, double aRatio) { if ((event.getX() <= 0) || (event.getX() >= v.getWidth()) || (!(event.getY() > startY && event.getY() < maxY))) { mHideVolumeSlider = true; startVolumeCtrlHandler(); - } else { mVolumeControl.setVisibility(View.VISIBLE); mHideVolumeSlider = false;