Android TouchListener實(shí)現(xiàn)拖拽刪實(shí)例代碼
Android TouchListener實(shí)現(xiàn)拖拽刪實(shí)例代碼
如果為一個(gè)控件設(shè)置了該觸摸監(jiān)聽, 控件會(huì)隨著用戶的拖動(dòng)而移動(dòng), 如果拖動(dòng)的距離大過設(shè)置的臨界值, 那么當(dāng)松開手指時(shí)會(huì)有回調(diào)onDragComplete, 用戶可在該方法中將該控件從父布局中刪除, 或這進(jìn)行其他操作。 如果用戶拖拽的距離小于臨界值, 那么當(dāng)用戶松開手指時(shí)控件會(huì)回談到原來的初始位置。這時(shí)會(huì)觸發(fā)onDragRebound回調(diào)。 如果用戶觸摸控件之后沒有拖拽而是直接松開手指, 會(huì)觸發(fā)onClick回調(diào), 這樣用戶就不用為該控件設(shè)置onClick監(jiān)聽。
源碼如下:
import android.util.Log; import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; /** * Created by zhangjg on 14-10-10. */ public class DragTouchListener implements View.OnTouchListener { /** * drag directions */ public static final int DIRECTION_UP = 0; public static final int DIRECTION_DOWN = 1; public static final int DIRECTION_LEFT = 2; public static final int DIRECTION_RIGHT = 3; private int mDragDirection = -1; private int mDragDistance = -1; private ViewGroup.MarginLayoutParams mParams; private ViewGroup.MarginLayoutParams mOriginParams; private int viewOriginMargin = -1000; private float mStartY = 0; private float mStartX = 0; private boolean isTouched = false; public DragTouchListener(int dragDirection, int dragDistance){ mDragDirection = dragDirection; mDragDistance = dragDistance; } protected void onClick(View view){ } protected void onDragComplete(View view){ } protected void onDragRebound(View view){ } @Override public boolean onTouch(View view, MotionEvent motionEvent) { if (viewOriginMargin == -1000){ mParams = (ViewGroup.MarginLayoutParams)view.getLayoutParams(); if (mDragDirection == DIRECTION_UP) { viewOriginMargin = mParams.bottomMargin; }else if (mDragDirection == DIRECTION_DOWN){ viewOriginMargin = mParams.topMargin; }else if (mDragDirection == DIRECTION_LEFT){ viewOriginMargin = mParams.rightMargin; }else if (mDragDirection == DIRECTION_RIGHT){ viewOriginMargin = mParams.leftMargin; } } int action = motionEvent.getAction(); switch (action){ case MotionEvent.ACTION_DOWN: isTouched = true; mStartY = motionEvent.getY(); mStartX = motionEvent.getX(); return true; case MotionEvent.ACTION_MOVE: float y = motionEvent.getY(); float x = motionEvent.getX(); if (mDragDirection == DIRECTION_UP){ if(y < mStartY){ mParams.bottomMargin = viewOriginMargin +(int) (mStartY - y); } }else if (mDragDirection == DIRECTION_DOWN){ if (y > mStartY){ mParams.topMargin = viewOriginMargin + (int) (y - mStartY); } }else if (mDragDirection == DIRECTION_LEFT){ if (x < mStartX){ mParams.rightMargin = viewOriginMargin + (int) (mStartX - x); } }else if (mDragDirection == DIRECTION_RIGHT){ if (x > mStartX){ mParams.leftMargin = viewOriginMargin + (int) (x - mStartX); } } view.setLayoutParams(mParams); break; case MotionEvent.ACTION_UP: float nowY = motionEvent.getY(); float nowX = motionEvent.getX(); int deltaX = (int)nowX - (int)mStartX; int deltaY = (int)nowY - (int)mStartY; if (isTouched && Math.abs(deltaX) < 5 && Math.abs(deltaY) < 5){ onClick(view); break; } if (mDragDirection == DIRECTION_UP){ if (isTouched && mStartY - nowY > mDragDistance){ // Log.i("test-drag", "direction up , startY = " + mStartY + ", nowY = " + nowY + // ", startY - nowY = " + (mStartY - nowY) + ", dragDistance : " + mDragDistance); onDragComplete(view); }else if (mStartY - nowY > 0 && mStartY - nowY < mDragDistance ){ mParams.bottomMargin = viewOriginMargin; view.setLayoutParams(mParams); onDragRebound(view); } }else if (mDragDirection == DIRECTION_DOWN){ if (isTouched && nowY - mStartY > mDragDistance){ onDragComplete(view); }else if ( nowY - mStartY > 0 && nowY - mStartY < mDragDistance ){ mParams.topMargin = viewOriginMargin; view.setLayoutParams(mParams); onDragRebound(view); } }else if (mDragDirection == DIRECTION_LEFT){ if (isTouched && mStartX - nowX > mDragDistance){ onDragComplete(view); }else if ( mStartX - nowX > 0 && mStartX - nowX < mDragDistance ){ mParams.rightMargin = viewOriginMargin; view.setLayoutParams(mParams); onDragRebound(view); } }else if (mDragDirection == DIRECTION_RIGHT){ if (isTouched && nowX - mStartX > mDragDistance){ onDragComplete(view); }else if ( nowX - mStartX > 0 && nowX - mStartX < mDragDistance ){ mParams.leftMargin = viewOriginMargin; view.setLayoutParams(mParams); onDragRebound(view); } } isTouched = false; break; } return false; } }
在使用時(shí)繼承該類, 并覆蓋三個(gè)回調(diào)方法, 就可以在合適的時(shí)機(jī)得到回調(diào)。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
Android實(shí)現(xiàn)圖片異步加載并緩存到本地
這篇文章主要介紹了Android實(shí)現(xiàn)圖片異步加載并緩存到本地的相關(guān)資料,需要的朋友可以參考下2016-02-02Android開發(fā)之APP安裝后在桌面上不顯示應(yīng)用圖標(biāo)的解決方法
這篇文章主要介紹了Android開發(fā)之APP安裝后在桌面上不顯示應(yīng)用圖標(biāo)的解決方法,涉及Android activity相關(guān)屬性設(shè)置技巧,需要的朋友可以參考下2017-07-07Android中驗(yàn)證碼倒計(jì)時(shí)的簡單實(shí)現(xiàn)方法示例
最近開發(fā)中在注冊(cè)獲取驗(yàn)證碼時(shí)候需要一個(gè)倒計(jì)時(shí)按鈕,找了相關(guān)的資料終于實(shí)現(xiàn)了,所以現(xiàn)在分享給大家,下面這篇文章主要給大家介紹了關(guān)于Android中驗(yàn)證碼倒計(jì)時(shí)簡單實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考借鑒。2017-06-06Android WebView支持input file啟用相機(jī)/選取照片功能
這篇文章主要介紹了Android-WebView支持input file啟用相機(jī)/選取照片功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08Android實(shí)現(xiàn)仿今日頭條點(diǎn)贊動(dòng)畫效果實(shí)例
我想看到今日頭條的點(diǎn)贊效果,應(yīng)該都覺得很絢麗吧,下面這篇文章主要給大家介紹了關(guān)于Android實(shí)現(xiàn)仿今日頭條點(diǎn)贊動(dòng)畫效果的相關(guān)資料,文中通過示例代價(jià)介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02Android DataBinding單向數(shù)據(jù)綁定深入探究
看了谷歌官方文章確實(shí)寫的太簡略了,甚至看完之后有很多地方還不知道怎么回事兒或者怎么用,那么接下來我將通過文章全面介紹一下DataBinding單向數(shù)據(jù)綁定2022-11-11Android 使用AsyncTask實(shí)現(xiàn)斷點(diǎn)續(xù)傳
這篇文章主要介紹了Android 使用AsyncTask實(shí)現(xiàn)斷點(diǎn)續(xù)傳的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05