如果在webview中存在触摸事件,则停止触摸事件被ViewPager拦截

时间:2015-09-03 07:39:04

标签: javascript android android-fragments webview

我有一个显示片段页面的ViewPager。每个片段都是显示脱机网站的WebView。其中一些网页视图中包含javascript滑动事件,以使其有效。

我想实现如果webview没有滑动事件(在javascript中),那么触摸事件将传递到ViewPager,如果不是由webview消耗的话。

我试过覆盖ViewPagers

@Override
public boolean onInterceptTouchEvent(MotionEvent event)
{
    return (this.swipeable) ? super.onInterceptTouchEvent(event) : false;
}

然而,这阻止了ViewPager可以滑动(如预期的那样),但也停止了滑动事件到达webview,因此我有两个不受欢迎的结果。

是否有任何方法可以先将触摸事件传递给webView,然后如果片段中没有将其传递回ViewPager

如果我在MyViewPager中犯了错误,我会有代码:

public class MyViewPager extends ViewPager implements   GestureDetector.OnGestureListener
{
private static final String TAG = MyViewPager.class.getSimpleName();
private boolean swipeable = true;
private float lastX   = 0;
private long lastTime = 0 ;
private GestureDetector mGestureDetector;
private boolean mScrolling = false;

public MyViewPager(Context context) {
    super(context);
    mGestureDetector = new GestureDetector(context, this);
}

public MyViewPager(Context context, AttributeSet attrs) {
    super(context, attrs);
    mGestureDetector = new GestureDetector(context, this);
}

public void setSwipeable(boolean swipeable) {
    this.swipeable = swipeable;
}

@Override
public boolean onInterceptTouchEvent(MotionEvent event)
{

   /* float speed = 0;
    if(event.getAction() == MotionEvent.ACTION_MOVE)
    {
        if(lastX!=0) {
            speed = (event.getRawX()- lastX) / (System.currentTimeMillis()-lastTime);
            if(speed < 0.0 ){speed *=-1;}
            Log.e(TAG, "Move at speed ->"+speed);
            if(speed >0.5){return false;}
        }
        lastX    = event.getRawX();
        lastTime = System.currentTimeMillis();
        return true;
    }*/
  // return true;

    return (this.swipeable) ? super.onInterceptTouchEvent(event) : false;
}

@Override
public boolean onTouchEvent(MotionEvent event)
{
    Log.i(TAG, "onTouch event");
  //  mGestureDetector.onTouchEvent(event);
    return false;
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velX, float velY) {
    Log.i(TAG, "flinging");
    return false;
}

@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distX, float distY)
{
    float displacement = distX;
    return false;
}

// Unused Gesture Detector functions below

@Override
public boolean onDown(MotionEvent event) {
    return false;
}

@Override
public void onLongPress(MotionEvent event) {
    // we don't want to do anything on a long press, though you should probably feed this to the page being long-pressed.
}

@Override
public void onShowPress(MotionEvent event) {
    // we don't want to show any visual feedback
}

@Override
public boolean onSingleTapUp(MotionEvent event) {
    // we don't want to snap to the next page on a tap so ignore this
    return false;
}

}

1 个答案:

答案 0 :(得分:8)

我现在有两个解决这个问题的方法是扩展一个ViewPager类并重写

public boolean onInterceptTouchEvent(MotionEvent event)
{
   // code  
}

然而,更好的解决方案是覆盖

protected boolean canScroll(View v, boolean checkV, int dx, int x, int y) {
  return true;
}

这里的完整性是整个班级

public class ZoltansViewPager extends ViewPager {

 private static final String TAG = ZoltansViewPager.class.getSimpleName();
 private boolean swipeable = true;
 private float lastX   = 0;
 private long lastTime = 0 ;
 private GestureDetector mGestureDetector;
 private boolean mScrolling = false;


 public ZoltansViewPager(Context context) {
    super(context);
 }

 public ZoltansViewPager(Context context, AttributeSet attrs) {
    super(context, attrs);
 }


 public void setSwipeable(boolean swipeable) {
    this.swipeable = swipeable;
 }

 @Override
 protected boolean canScroll(View v, boolean checkV, int dx, int x, int y) {
     Log.i(TAG , " boolean checkV ->"+checkV + ", int dx-> "+dx+", int x->"+x+", int y->"+y);
     if(x <300 || x >1700 ){return true;}
     return false;
 }
}

希望它可以帮助别人

相关问题