解决SwipeRefreshLayout与Banner滑动冲突
生活随笔
收集整理的這篇文章主要介紹了
解决SwipeRefreshLayout与Banner滑动冲突
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
import android.content.Context;
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.ViewConfiguration;//解決SwipeRefreshLayout與Banner滑動沖突
public class VpSwipeRefreshLayout extends SwipeRefreshLayout {private float startY;private float startX;// 記錄viewPager是否拖拽的標記private boolean mIsVpDragger;private final int mTouchSlop;public VpSwipeRefreshLayout(Context context, AttributeSet attrs) {super(context, attrs);//觸發移動事件的最短距離mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();}@Overridepublic boolean onInterceptTouchEvent(MotionEvent ev) {int action = ev.getAction();switch (action) {case MotionEvent.ACTION_DOWN:// 記錄手指按下的位置startY = ev.getY();startX = ev.getX();// 初始化標記mIsVpDragger = false;break;case MotionEvent.ACTION_MOVE:// 如果viewpager正在拖拽中,那么不攔截它的事件,直接return false;if (mIsVpDragger) {return false;}// 獲取當前手指位置float endY = ev.getY();float endX = ev.getX();float distanceX = Math.abs(endX - startX);float distanceY = Math.abs(endY - startY);// 如果X軸位移大于Y軸位移,那么將事件交給viewPager處理。if (distanceX > mTouchSlop && distanceX > distanceY) {mIsVpDragger = true;return false;}break;case MotionEvent.ACTION_UP:case MotionEvent.ACTION_CANCEL:// 初始化標記mIsVpDragger = false;break;}// 如果是Y軸位移大于X軸,事件交給swipeRefreshLayout處理。return super.onInterceptTouchEvent(ev);}
}
?
總結
以上是生活随笔為你收集整理的解决SwipeRefreshLayout与Banner滑动冲突的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: android滚轮实现时间年月日选择
- 下一篇: 王者荣耀金银牌在哪看