真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

為來安等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及來安網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、來安網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

具體效果可以對(duì)比一下:

Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制  

Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制

說到Gemini,我也是這兩天因?yàn)榱私釴estedScrolling時(shí)接觸到的,粗略看了一下資料和文章瀏覽數(shù),贊! 我的大神!

好,前番就到這了,開始正題NestedScrolling。

之前了解NestedScrolling的時(shí)候看過一些博客,其中就包括Gemini的segmentfault,當(dāng)時(shí)看的時(shí)候因?yàn)椴蛔屑?xì)不以為然,***才發(fā)現(xiàn)這篇博客是對(duì)NestedScrolling介紹最清楚的,作為懲罰也好膜拜也罷,把本來可以cv過來的博客手動(dòng)敲一遍,順便補(bǔ)充一下自己的一些額外理解。

再次感謝Gemini

Android 在發(fā)布 Lillipop  版本后,為了更好的用戶體驗(yàn),Google為Android的滑動(dòng)機(jī)制提供了NestedScrolling機(jī)制。

NestedScrolling的特性可以體現(xiàn)在哪兒呢?

比如你用了Toolbar,下面一個(gè)ScrollView,向上滾動(dòng)隱藏Toolbar,向下滾動(dòng)顯示Toolbar,這里在邏輯上就是一個(gè)NestedScrolling——因?yàn)槟阍跐L動(dòng)整個(gè)Toolbar在內(nèi)的View的過程中,又嵌套滾動(dòng)了里邊的ScrollView。

如圖:  

Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制

在這之前,我們知道Android對(duì)Touch事件分發(fā)是有自己的一套機(jī)制。主要是有三個(gè)函數(shù):

dispatchTouchEvent, onInterceptTouchEvent, onTouchEvent。

這種分發(fā)機(jī)制有一個(gè)漏洞:

如果子view獲得處理touch事件機(jī)會(huì)的時(shí)候,父view就再也沒有機(jī)會(huì)處理此次touch事件,直到下一次手指觸發(fā)。

也就是說,我們?cè)诨瑒?dòng)子view的時(shí)候,如果子view對(duì)這個(gè)滑動(dòng)事件不需要處理的時(shí)候,只能拋棄這個(gè)touch事件,而不會(huì)傳給父view去處理。

但Google新的NestedScrolling機(jī)制就很好的解決了這個(gè)問題。

NestedScrolling主要有四個(gè)類需要關(guān)注:

  • NestedScrollingChild

  • NestedScrollingChildHelper

  • NestedScrollingParent

  • NestedScrollingParentHelper

以上四個(gè)類都在support-v4包中提供,Lollipop中部分View默認(rèn)實(shí)現(xiàn)了NestedScrollingChild或NestedScrollingParent。

v4包中NestedScrollView同時(shí)實(shí)現(xiàn)了NestedScrollingChild和NestedScrollingParent。

一般實(shí)現(xiàn)NestedScrollingChild就可以了,父View用support-design提供的實(shí)現(xiàn)了NestedScrollingParent的CoordinatorLayout即可。

@Override     public void setNestedScrollingEnabled(boolean enabled) {         super.setNestedScrollingEnabled(enabled);         mChildHelper.setNestedScrollingEnabled(enabled);     }      @Override     public boolean isNestedScrollingEnabled() {         return mChildHelper.isNestedScrollingEnabled();     }      @Override     public boolean startNestedScroll(int axes) {         return mChildHelper.startNestedScroll(axes);     }      @Override     public void stopNestedScroll() {         mChildHelper.stopNestedScroll();     }      @Override     public boolean hasNestedScrollingParent() {         return mChildHelper.hasNestedScrollingParent();     }      @Override     public boolean dispatchNestedScroll(int dxConsumed, int dyConsumed, int dxUnconsumed, int dyUnconsumed, int[] offsetInWindow) {         return mChildHelper.dispatchNestedScroll(dxConsumed, dyConsumed, dxUnconsumed, dyUnconsumed, offsetInWindow);     }      @Override     public boolean dispatchNestedPreScroll(int dx, int dy, int[] consumed, int[] offsetInWindow) {         return mChildHelper.dispatchNestedPreScroll(dx, dy, consumed, offsetInWindow);     }      @Override     public boolean dispatchNestedFling(float velocityX, float velocityY, boolean consumed) {         return mChildHelper.dispatchNestedFling(velocityX, velocityY, consumed);     }      @Override     public boolean dispatchNestedPreFling(float velocityX, float velocityY) {         return mChildHelper.dispatchNestedPreFling(velocityX, velocityY);     }

簡(jiǎn)單邏輯這樣就可以實(shí)現(xiàn)嵌套滑動(dòng)。

以上接口都是業(yè)務(wù)邏輯中自己調(diào)用,NestedScrollingChildHelper是如何實(shí)現(xiàn)的呢?  先看一下startNestedScroll方法

/**      * Start a new nested scroll for this view.      *      * 

This is a delegate method. Call it from your {@link android.view.View View} subclass      * method/{@link NestedScrollingChild} interface method with the same signature to implement      * the standard policy.

      *      * @param axes Supported nested scroll axes.      *             See {@link NestedScrollingChild#startNestedScroll(int)}.      * @return true if a cooperating parent view was found and nested scrolling started successfully      */     public boolean startNestedScroll(int axes) {         if (hasNestedScrollingParent()) {             // Already in progress             return true;         }         if (isNestedScrollingEnabled()) {             ViewParent p = mView.getParent();             View child = mView;             while (p != null) {                 if (ViewParentCompat.onStartNestedScroll(p, child, mView, axes)) {                     mNestedScrollingParent = p;                     ViewParentCompat.onNestedScrollAccepted(p, child, mView, axes);                     return true;                 }                 if (p instanceof View) {                     child = (View) p;                 }                 p = p.getParent();             }         }         return false;     }

可以看到這里是幫你實(shí)現(xiàn)了與NestedScrollingParent交互的一些方法。

ViewParentCompat是一個(gè)和父View交互的兼容類,判斷API  version,如果在Lollipop上就調(diào)用View自帶的方法,否則判斷如果實(shí)現(xiàn)了NestedScrollingParent,則調(diào)用實(shí)現(xiàn)接口的方法。

子View與父View的交互流程如下:

一、startNestedScroll

首先子View需要開啟整個(gè)流程(通過屏幕滑動(dòng)觸發(fā)touch事件),通過NestedScrollingChildHelper找到并通知實(shí)現(xiàn)了NestedScrollingParent的父View中onStartNestedScroll和onNestedScrollAccepted方法。

二、dispatchNestedPreScroll

在子View的onIterceptTouchEvent和onTouch中(一般在MontionEvent.ACTION_MOVE事件里),調(diào)用改方法通知父View的滑動(dòng)距離,該方法的第三第四個(gè)參數(shù)返回父View消費(fèi)掉的scroll長度和子View的窗口偏移量,如果這個(gè)scroll沒有被消費(fèi)完,則子View處理剩余距離,由于窗口被移動(dòng),如果記錄了手指***的位置,需要根據(jù)第四個(gè)參數(shù)offsetInWindow計(jì)算偏移量,才能保證下一次touch事件的計(jì)算是正確的。

如果父View接受了滾動(dòng)參數(shù)并部分消費(fèi),則該函數(shù)返回true,否則返回false。該函數(shù)一般在子View處理Scroll前調(diào)用。

三、dispatchNestedScroll

向父View匯報(bào)滾動(dòng)情況,包括子View已消費(fèi)和未消費(fèi)的值。

如果父View接受了滾動(dòng)參數(shù),部分消費(fèi)則函數(shù)返回true,否則返回false。

該函數(shù)一般在子View處理Scroll后調(diào)用。

四、stopNestedScroll

結(jié)束整個(gè)嵌套滑動(dòng)流程。

流程中NestedScrollingChild和NestedScrollingParent對(duì)應(yīng)如下:

NestedScrollingChildImplNestedScrollingParentImpl
onStartNestedScrollonStartNestedScrollonNestedScrollAccepted
dispatchNestedPreScrollonNestedPreScroll
dispatchNestedScrollonNestedScroll
stopNestedScrollonStopNestedScroll

一般是子View發(fā)起調(diào)用,父View接受回調(diào)。

需要關(guān)注dispatchNestedPreScroll中的consumed參數(shù):

public boolean dispatchNestedPreScroll(int dx, int dy, int[] consumed, int[] offsetInWindow) ;

該參數(shù)是一個(gè)int類型的數(shù)組,長度為2,***個(gè)元素是父View消費(fèi)的x軸方向的滾動(dòng)距離,第二個(gè)元素是父View消費(fèi)的y軸方向的滾動(dòng)距離,如果兩個(gè)值均不為0,則表示父View已消費(fèi)滾動(dòng)距離,則需要對(duì)子View滾動(dòng)距離進(jìn)行修正,正因?yàn)橛性搮?shù),使得處理滾動(dòng)事件時(shí)思路更加清晰,不會(huì)像以前一樣被一堆滾動(dòng)參數(shù)搞混。

自己理解的NestedScrolling簡(jiǎn)要流程圖(不包含F(xiàn)ling事件及返回值的邏輯):

Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制

上述就是小編為大家分享的Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


名稱欄目:Android中怎么利用NestedScrolling實(shí)現(xiàn)嵌套滑動(dòng)機(jī)制
網(wǎng)頁鏈接:http://weahome.cn/article/pjispi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部