Android ScrollView 嵌套RecyclerView滑動卡頓問題,并支持加載更多

ScrollView 和RecyclerView都是滑動組件具则,因此存在滑動事件沖突問題即纲,解決思路就是在事件分發(fā)函數(shù)中將其中下層View的滑動事件做攔截處理

布局示例代碼如下:

    <com.xxx.xxx.widget.ScrollInterceptScrollView
        android:id="@+id/scrollView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/white">
         <View
           android:id="@+id/divider2"
            android:layout_width="match_parent"
             android:layout_height="match_parent"
            android:background="#BBBBBB"
             app:layout_constraintEnd_toEndOf="parent"
              app:layout_constraintStart_toStartOf="parent"
              app:layout_constraintTop_toTopOf="parent" />

            <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:descendantFocusability="blocksDescendants"
                app:layout_constraintTop_toBottomOf="@+id/linearLayout3">


                <androidx.recyclerview.widget.RecyclerView
                    android:id="@+id/rv_menu"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_marginTop="24dp"
                    app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
                    app:layout_behavior="@string/appbar_scrolling_view_behavior" />


            </RelativeLayout>
         </View>
    </com.xxx.xxx.widget.ScrollInterceptScrollView>

注意:在布局中包裹一層RelativeLayout,并且加上這個屬性
android:descendantFocusability="blocksDescendants"
blocksDescendants這個屬性的官方解釋是viewgroup會覆蓋子類控件而直接獲得焦點

繼承ScrollView類自定義ScrollView

import android.annotation.TargetApi;
import android.content.Context;
import android.os.Build;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.ViewConfiguration;
import android.widget.ScrollView;

public class ScrollInterceptScrollView extends ScrollView {
    private int downX, downY;
    private int mTouchSlop;

    public ScrollInterceptScrollView(Context context) {
        this(context, null);
    }

    public ScrollInterceptScrollView(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public ScrollInterceptScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
    }

    @TargetApi(Build.VERSION_CODES.LOLLIPOP)
    public ScrollInterceptScrollView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
        mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        int action = ev.getAction();
        switch (action) {
            case MotionEvent.ACTION_DOWN:
                downX = (int) ev.getRawX();
                downY = (int) ev.getRawY();
                break;
            case MotionEvent.ACTION_MOVE:
                int moveY = (int) ev.getRawY();
                // 判斷是否滑動博肋,若滑動就攔截事件
                if (Math.abs(moveY - downY) > mTouchSlop) {
                    return true;
                }
                break;
            default:
                break;
        }

        return super.onInterceptTouchEvent(ev);
    }

}
ScrollView滑動加載更多

判斷的思路就是當前滑動的y坐標是否大于等于當前ScrollView 的高度

//這個標志位是為了方式加載更多重復執(zhí)行
    private var isLoadMore = true
  //頁碼
    private var page=0

        //滑動處理低斋,實現(xiàn)滑動監(jiān)聽方法
        scrollView.setOnScrollChangeListener { v, scrollX, scrollY, oldScrollX, oldScrollY ->
            //加載更多
            if (scrollY >= scrollView.getChildAt(0)
                    .measuredHeight - scrollView.measuredHeight
            ) {
                if (isLoadMore) {
                    Log.i("allyn", "加載更多")
                    isLoadMore = false;
                    page++
                    getData()
                }
            }
        }

講解完了,希望對遇到問題的朋友有幫助7朔病膊畴!

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市病游,隨后出現(xiàn)的幾起案子唇跨,更是在濱河造成了極大的恐慌,老刑警劉巖衬衬,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件买猖,死亡現(xiàn)場離奇詭異,居然都是意外死亡滋尉,警方通過查閱死者的電腦和手機玉控,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來狮惜,“玉大人高诺,你說我怎么就攤上這事碌识。” “怎么了虱而?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵筏餐,是天一觀的道長。 經(jīng)常有香客問我薛窥,道長胖烛,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任诅迷,我火速辦了婚禮佩番,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘罢杉。我一直安慰自己趟畏,他們只是感情好,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布滩租。 她就那樣靜靜地躺著赋秀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪律想。 梳的紋絲不亂的頭發(fā)上猎莲,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機與錄音技即,去河邊找鬼著洼。 笑死,一個胖子當著我的面吹牛而叼,可吹牛的內(nèi)容都是我干的身笤。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼葵陵,長吁一口氣:“原來是場噩夢啊……” “哼液荸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起脱篙,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤娇钱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后绊困,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體忍弛,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年考抄,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蔗彤。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡川梅,死狀恐怖疯兼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情贫途,我是刑警寧澤吧彪,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站丢早,受9級特大地震影響姨裸,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜怨酝,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一傀缩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧农猬,春花似錦赡艰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至揍堕,卻和暖如春料身,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背衩茸。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工芹血, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人递瑰。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓祟牲,卻偏偏與公主長得像,于是被迫代替她去往敵國和親抖部。 傳聞我的和親對象是個殘疾皇子说贝,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容