From 22582f247de71d0696cfa46ce303c37c74f99528 Mon Sep 17 00:00:00 2001 From: Eric House Date: Thu, 27 Aug 2020 22:55:25 -0700 Subject: [PATCH] work around fast-scrolling eating taps for nearby objects As happened with expander arrows on the right when I turned on fast scrolling, the on-left-side scrollbar was preventing selecting rows when there were enough list elements for fast scrolling to be enabled. So use a listener to turn it on only after the user starts to scroll. And move the bar back to the right side since that's where people expect it. --- .../android/app/src/main/assets/changes.html | 1 + .../android/xw4/GamesListDelegate.java | 44 ++++++++++++++++--- .../app/src/main/res/layout/game_list.xml | 4 -- 3 files changed, 40 insertions(+), 9 deletions(-) diff --git a/xwords4/android/app/src/main/assets/changes.html b/xwords4/android/app/src/main/assets/changes.html index 204b805ce..a313a8687 100644 --- a/xwords4/android/app/src/main/assets/changes.html +++ b/xwords4/android/app/src/main/assets/changes.html @@ -30,6 +30,7 @@ without an invitation (but: you should still use an invitation when you can)
  • Indicate selected games and groups with a checkmark
  • +
  • Move games list scrollbar to the right side
  • Tweak layout of wordlist filter
  • Improve player-config dialog
  • Fix occasional problems remembering game groups diff --git a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/GamesListDelegate.java b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/GamesListDelegate.java index 27ea493d9..794ad40d5 100644 --- a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/GamesListDelegate.java +++ b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/GamesListDelegate.java @@ -31,11 +31,14 @@ import android.net.Uri; import android.os.Build; import android.os.Bundle; import android.os.Handler; +import android.text.TextUtils; import android.view.ContextMenu.ContextMenuInfo; import android.view.ContextMenu; import android.view.Menu; import android.view.MenuItem; import android.view.View; +import android.widget.AbsListView.OnScrollListener; +import android.widget.AbsListView; import android.widget.AdapterView.OnItemLongClickListener; import android.widget.AdapterView; import android.widget.Button; @@ -43,7 +46,6 @@ import android.widget.EditText; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.TextView; -import android.text.TextUtils; import org.eehouse.android.xw4.DBUtils.GameChangeType; import org.eehouse.android.xw4.DBUtils.GameGroupInfo; @@ -614,6 +616,7 @@ public class GamesListDelegate extends ListDelegateBase private boolean m_haveShownGetDict; private Bundle m_rematchExtras; private Object[] m_newGameParams; + private int mCurScrollState; public GamesListDelegate( Delegator delegator, Bundle sis ) { @@ -982,10 +985,41 @@ public class GamesListDelegate extends ListDelegateBase }; mkListAdapter(); - getListView().setOnItemLongClickListener( this ); - // Only works if scroller's on left side, as it otherwise steals - // events from the expander arrow things - getListView().setFastScrollEnabled( true ); + + final ListView lv = getListView(); + lv.setOnItemLongClickListener( this ); + + // Can't just enable fast scrolling because the scroller's wide touch + // area disables taps on what's underneath. The expander arrows in + // this case. So these two listener callbacks enable fast scrolling + // only after the user's started scrolling and disable it when [s]he's + // done + // + // See https://stackoverflow.com/questions/33619453/scrollbar-touch-area-in-android-6 + mCurScrollState = OnScrollListener.SCROLL_STATE_IDLE; + lv.setOnScrollListener( new OnScrollListener() { + @Override + public void onScroll( AbsListView absListView, int ii, int i1, int i2 ) + { + if ( mCurScrollState == OnScrollListener.SCROLL_STATE_TOUCH_SCROLL ) { + lv.setFastScrollEnabled( true ); + } + } + @Override + public void onScrollStateChanged( AbsListView absListView, int state ) + { + if ( state == OnScrollListener.SCROLL_STATE_IDLE + && mCurScrollState != state ) { + lv.postDelayed( new Runnable() { + @Override + public void run() { + lv.setFastScrollEnabled( false ); + } + }, 500 ); + } + mCurScrollState = state; + } + } ); NetUtils.informOfDeaths( m_activity ); diff --git a/xwords4/android/app/src/main/res/layout/game_list.xml b/xwords4/android/app/src/main/res/layout/game_list.xml index 55aaa4d74..e3a5941ae 100644 --- a/xwords4/android/app/src/main/res/layout/game_list.xml +++ b/xwords4/android/app/src/main/res/layout/game_list.xml @@ -12,11 +12,8 @@ android:layout_height="fill_parent" android:layout_weight="1" android:drawSelectorOnTop="false" - android:verticalScrollbarPosition="left" /> -