2014-10-07 93 views
2

我有一个2到4页的viewpager。其中一个页面以表格的形式显示数据。为此,我使用垂直滚动和水平滚动。horizo​​nalscrollview viewpager里面

由于horizo​​ntalscrollview和viewpager之间存在冲突,有时滚动不做任何事情。

我想向左滚动页面。当到达边缘时,另一个轻扫手势将使其更改页面浏览器,遵循http://developer.android.com/design/patterns/swipe-views.html 的指导原则,其中规定:“如果视图包含超出屏幕宽度的内容,如广泛的电子邮件消息,请确保用户的初始滑动将在视图内水平滚动,一旦达到内容的结尾,额外的滑动应该导航到下一个视图。此外,当内容水平滚动时,支持使用边缘滑动来立即在视图之间导航。

我该如何做到这一点?

+0

这可能是棘手的。将需要编写自定义触摸侦听器并使用requestDisallowInterceptTouchEvent指令。看看它是如何在PhotoView库中完成的(它可以使用ViewPager进行滚动)https://github.com/chrisbanes/PhotoView – httpdispatch 2014-10-07 11:41:27

回答

2

最后我一个定制寻呼机和overrided方法canScroll喜欢这样

@Override 
protected boolean canScroll(View v, boolean checkV, int dx, int x, int y) { 
    if (v instanceof HorizontalScrollView) { 
     HorizontalScrollView scroll = (HorizontalScrollView) v; 

     int vScrollX = scroll.getScrollX(); 
     TableLayout table = (TableLayout) scroll.getChildAt(scroll 
       .getChildCount() - 1); 
     int diff = (table.getRight() - (scroll.getWidth() 
       + scroll.getScrollX() + table.getLeft())); 

     if (vScrollX == 0 && diff <= 0) {// table without scroll 
      if (dx > 20 && this.getCurrentItem() > 0) { 
       this.setCurrentItem(this.getCurrentItem() - 1, true); 
      } else if (dx < -20 
        && this.getCurrentItem() + 1 < this.getChildCount()) { 
       this.setCurrentItem(this.getCurrentItem() + 1, true); 
      } 
      return false; // change page 
     } 
     if (vScrollX == 0 && dx > 20) {// left edge, swiping right 
      if (this.getCurrentItem() > 0) { 
       this.setCurrentItem(this.getCurrentItem() - 1, true); 
      } 
      return false; // change page 
     } 
     if (vScrollX == 0 && dx < -20) {// left edge, swiping left 
      return true;// scroll 
     } 
     if (diff <= 0 && dx > 20) {// right edge, swiping right 
      return true;// scroll 
     } 
     if (diff <= 0 && dx < -20) {// right edge, swiping left 
      if (this.getCurrentItem() + 1 < this.getChildCount()) { 
       this.setCurrentItem(this.getCurrentItem() + 1, true); 
      } 
      return false;// change page 
     } 
    } 
    return super.canScroll(v, checkV, dx, x, y); 
} 
相关问题