2014-12-07 65 views
1

我确信有一些关于它的帖子,我之前通过它们浏览过,但现在找不到它们。当用户从页面的边缘向页面边缘滑动viewpager时检测到

我想检测用户从页面边缘(例如左边缘)滑动viewpager时的操作。我想为这种轻扫做一些特殊处理,比如显示菜单。

是否有任何ViewPager内置(?)支持?我隐约记得它是。否则,我必须执行我自己的逻辑来检测这些行为。

任何人都可以指点我一些信息吗?

enter image description here

回答

0

我认为,你应该覆盖你的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的最佳方式。

祝你好运!

0

有了这个例子中,你可以控制所有类型的手势在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 
    } 
} 
}); 

我希望这对你有所帮助。

4

简单的检查edge mask

public void onTouchEvent(MotionEvent event){ 

    if (ev.getAction() == MotionEvent.ACTION_DOWN && ev.getEdgeFlags() == MotionEvent.EDGE_LEFT) { 

    } 

} 

同样的逻辑,如果你把片段内onInterceptTouchEvent(MotionEvent event)倍率工作。