在viewpager里面的horizo​​ntalscrollview

时间:2014-10-07 11:29:46

标签: android android-viewpager horizontalscrollview

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

由于horizo​​ntalscrollview和viewpager之间存在冲突,有时滚动不起作用。

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

我怎样才能实现这个目标?

1 个答案:

答案 0 :(得分:2)

最后我制作了一个自定义寻呼机并覆盖了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);
}