用Scroller实现简单viewpager滑动
看了guolin大神的一篇博客,介绍的很详细,不适合小白。
viewpager可以左右滑动,如何做的呢,viepager的实现代码太多了3千多行,不做深究了。我们实现简单的滑动即可。说到滑动大家一定会想到scrollTo(x,y)和scrollBy(x,y)。现在来看一下他们的起源,从View控件中可以找到。
public class View implements Drawable.Callback, KeyEvent.Callback,AccessibilityEventSource {
public void scrollBy(int x, int y) {
scrollTo(mScrollX + x, mScrollY + y);
}
public void scrollTo(int x, int y) {
if (mScrollX != x || mScrollY != y) {
int oldX = mScrollX;
int oldY = mScrollY;
mScrollX = x;
mScrollY = y;
invalidateParentCaches();
onScrollChanged(mScrollX, mScrollY, oldX, oldY);
if (!awakenScrollBars()) {
postInvalidateOnAnimation();
}
}
}
}
代码可以看到这两个函数已经实现,不是抽象方法,而且我查了ViewGroup,LinearLayout,TextView里面都没有这两个方法的复写,只在TextView中使用过,所以可以这样认为,scrollTo(x,y)和scrollBy(x,y)在View类中就是最后的实现。所以查看它们到View中看就OK了。另一方面说明了,其他所有继承View控件都存在这两个方法,并且控件内容都可以移动。
说了这么多废话,现在进入正题,scrollTo(x,y)和scrollBy(x,y)有什么区别呢。从scrollBy(x,y)的实现上可以看到,scrollBy(x,y)其实内部调用的就是scrollTo(x,y),唯一的区别就是在原有移动距离上加上新的移动距离。假设现在x轴已经移动了sx,y轴移动sy,如果在次调用scrollBy(x,y),在x轴上的移动距离变成x+sx,y轴上的一定距离y+sy。如果是scrollTo(x,y)无论调用多少次,只会在第一次调用时移动,除非改变x,y值。
说道现在,大家可能已经明白了,viewpager的滑动与scrollTo(x,y)和scrollBy(x,y)有关。是的,就是他们实现了viewpager的滑动。下面是我写的滑动容器:
public class ScollerContainer extends ViewGroup {
private Scroller scroller;
private float XDown;
private float XMove;
private float XLastMove;
private int leftBorder;
private int rightBorder;
private int touchSlop;
public ScollerContainer(Context context) {
super(context);
ini