您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)Android scrollview監(jiān)聽滑動(dòng)狀態(tài)的方法的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
ScrollView
視圖的滾動(dòng)過程,其實(shí)是在不斷修改原點(diǎn)坐標(biāo)。當(dāng)手指觸摸后,ScrollView會(huì)暫時(shí)攔截觸摸事件,使用一個(gè)計(jì)時(shí)器。假如在計(jì)時(shí)器到點(diǎn)后沒有發(fā)生手指移動(dòng)事件,那么ScrollView發(fā)送tracking events到被點(diǎn)擊的subView;若是在計(jì)時(shí)器到點(diǎn)后發(fā)生了移動(dòng)事件,那么ScrollView取消tracking自己促發(fā)滾動(dòng)。
首先說一下 NestedScrollView 的滑動(dòng)事件的監(jiān)聽,
如果使用
nestedScrollView.setOnScrollChangeListener(new View.OnScrollChangeListener() { @Override public void onScrollChange(View v, int scrollX, int scrollY, int oldScrollX, int oldScrollY) { } });
這個(gè)方法在 API >= 23 時(shí)才可以使用,怎么解決呢 。我們可以自己定義一個(gè)ScrollView
public class MyScrollView extends NestedScrollView { private OnScrollChanged mOnScrollChanged; public MyScrollView(Context context) { this(context, null); } public MyScrollView(Context context, AttributeSet attributeSet) { this(context, attributeSet, 0); } public MyScrollView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } @Override protected void onScrollChanged(int l, int t, int oldl, int oldt) { super.onScrollChanged(l, t, oldl, oldt); if (mOnScrollChanged != null) { mOnScrollChanged.onScroll(l, t, oldl, oldt); } } public void setOnScrollChanged(OnScrollChanged onScrollChanged) { this.mOnScrollChanged = onScrollChanged; } public interface OnScrollChanged { void onScroll(int l, int t, int oldl, int oldt); } }
這樣我們就可以通過實(shí)現(xiàn) onScrollChanged() 監(jiān)聽滑動(dòng)事件了 ,其中可以監(jiān)測到滑動(dòng)距離,這樣就可以做好多事情了;
但是現(xiàn)在有一個(gè)需求就是【滑動(dòng)的時(shí)候隱藏 一個(gè)靠邊的懸浮框,不滑動(dòng)是懸浮框顯示出來】,這樣的話就需要監(jiān)測滑動(dòng)狀態(tài)了。scrollview 不像recyclerview一樣可以監(jiān)測滑動(dòng)狀態(tài)。
以下是我的一個(gè)實(shí)現(xiàn)方案,通過CountDownTimer 來實(shí)現(xiàn)
在剛才的onScrollChanged 接口中增加方法
public interface OnScrollChanged { void onScroll(int l, int t, int oldl, int oldt); void onTouch(boolean isDown); }
然后重寫onTouchEvent方法
@Override public boolean onTouchEvent(MotionEvent ev) { switch (ev.getAction()) { case MotionEvent.ACTION_UP: case MotionEvent.ACTION_CANCEL: if (mOnScrollChanged != null) { mOnScrollChanged.onTouch(false); } break; case MotionEvent.ACTION_DOWN: case MotionEvent.ACTION_MOVE: if (mOnScrollChanged != null) { mOnScrollChanged.onTouch(true); } break; } return super.onTouchEvent(ev); }
這里的isDown=true代表是按下或者滑動(dòng)的狀態(tài),對(duì)應(yīng)ACTION_DOWN和ACTION_MOVE,fale代表ACTION_UP和ACTION_CANCEL
下面使用這個(gè)自定義的scrollerview
//靜止?fàn)顟B(tài) private final static int SCROLL_STATE_IDLE = 1; //拖動(dòng)或者慣性滑動(dòng)狀態(tài) private final static int SCROLL_STATE_SCROLL = 2; //判斷是否是拖動(dòng)狀態(tài) boolean isDragState = false; int currentState = SCROLL_STATE_IDLE; //這里采用100ms來判斷是否已經(jīng)是靜止?fàn)顟B(tài),100ms結(jié)束后證明是靜止?fàn)顟B(tài) private CountDownTimer scrollCountTimer = new CountDownTimer(100, 1) { @Override public void onTick(long millisUntilFinished) { } @Override public void onFinish() { setScrollState(SCROLL_STATE_IDLE); } }; private void initScrollView() { scrollView.setOnScrollChanged(new MyScrollView.OnScrollChanged() { @Override public void onScroll(int l, int t, int oldl, int oldt) { if (isDragState) {//拖動(dòng)狀態(tài)單獨(dú)處理不再進(jìn)行滾動(dòng)狀態(tài)監(jiān)測 return; } //滑動(dòng)時(shí)先取消倒計(jì)時(shí),設(shè)置滑動(dòng)狀態(tài) scrollCountTimer.cancel(); if(currentState != SCROLL_STATE_SCROLL) { setScrollState(SCROLL_STATE_SCROLL); } scrollCountTimer.start(); } @Override public void onTouch(boolean isDown) { isDragState = isDown; //我這里把按下的狀態(tài)默認(rèn)為了滾動(dòng)的狀態(tài),當(dāng)然你也可以分開定義 if (isDown) { scrollCountTimer.cancel(); setScrollState(SCROLL_STATE_SCROLL); } else { scrollCountTimer.start(); } } }); //最后記得頁面銷毀時(shí),cancel掉timer
感謝各位的閱讀!關(guān)于“Android scrollview監(jiān)聽滑動(dòng)狀態(tài)的方法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。