我确信有一些关于它的帖子,我之前通过它们浏览过,但现在找不到它们。当用户从页面的边缘向页面边缘滑动viewpager时检测到
我想检测用户从页面边缘(例如左边缘)滑动viewpager时的操作。我想为这种轻扫做一些特殊处理,比如显示菜单。
是否有任何ViewPager内置(?)支持?我隐约记得它是。否则,我必须执行我自己的逻辑来检测这些行为。
任何人都可以指点我一些信息吗?
我确信有一些关于它的帖子,我之前通过它们浏览过,但现在找不到它们。当用户从页面的边缘向页面边缘滑动viewpager时检测到
我想检测用户从页面边缘(例如左边缘)滑动viewpager时的操作。我想为这种轻扫做一些特殊处理,比如显示菜单。
是否有任何ViewPager内置(?)支持?我隐约记得它是。否则,我必须执行我自己的逻辑来检测这些行为。
任何人都可以指点我一些信息吗?
我认为,你应该覆盖你的ViewPager容器的几个方法。例如,如果是的LinearLayout
public class Liner extends LinearLayout {
public Liner(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
// TODO Auto-generated constructor stub
}
//Remember start points
float mInitX;
float mInitY;
// TouchSlop value
float mSomeValue=20F;
//
boolean mCatched=false;
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
mInitX=ev.getX();
mInitY=ev.getY();
break;
default:
break;
}
mCatched=mInitX<10 && Math.abs(ev.getX()-mInitX)>mSomeValue;
return mCatched;
}
@Override
public boolean onTouchEvent(MotionEvent event) {
if(mCatched){
//Do all you want here
}
return true;
}
}
如果合并有TeRRo anrwer(把自己内部的onTouchEvent探测器()),你可能有好的结果。但使用DrawerLayout的最佳方式。
祝你好运!
有了这个例子中,你可以控制所有类型的手势在ViewPager,现在只需要添加一些条件处理在onSwipeLeft()
边缘和onSwipeRight()
public class OnSwipeTouchListener implements OnTouchListener {
@SuppressWarnings("deprecation")
private final GestureDetector gestureDetector = new GestureDetector(new GestureListener());
public boolean onTouch(final View v, final MotionEvent event) {
return gestureDetector.onTouchEvent(event);
}
private final class GestureListener extends SimpleOnGestureListener {
private static final int SWIPE_THRESHOLD = 100;
private static final int SWIPE_VELOCITY_THRESHOLD = 100;
@Override
public boolean onDown(MotionEvent e) {
return true;
}
@Override
public boolean onSingleTapConfirmed(MotionEvent e) {
onTouch(e);
return true;
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
boolean result = false;
try {
float diffY = e2.getY() - e1.getY();
float diffX = e2.getX() - e1.getX();
if (Math.abs(diffX) > Math.abs(diffY)) {
if (Math.abs(diffX) > SWIPE_THRESHOLD && Math.abs(velocityX) > SWIPE_VELOCITY_THRESHOLD) {
if (diffX > 0) {
onSwipeRight();
} else {
onSwipeLeft();
}
}
} else {
// onTouch(e);
}
} catch (Exception exception) {
exception.printStackTrace();
}
return result;
}
}
public void onTouch(MotionEvent e) {
}
public void onSwipeRight() {
//call this only if your condition was set
}
public void onSwipeLeft() {
//nothing, this means,swipes to left will be ignored
}
public void onSwipeTop() {
}
public void onSwipeBottom() {
}
}
设置你的自定义OnTouchListener in your viewpager object:
viewPager.setOnTouchListener(new OnSwipeTouchListener() {
public void onSwipeRight() {
if(your conditionIsMet){
// move your pager view to the right
}
}
});
我希望这对你有所帮助。
简单的检查edge mask
public void onTouchEvent(MotionEvent event){
if (ev.getAction() == MotionEvent.ACTION_DOWN && ev.getEdgeFlags() == MotionEvent.EDGE_LEFT) {
}
}
同样的逻辑,如果你把片段内onInterceptTouchEvent(MotionEvent event)
倍率工作。