这篇文章是我在看一个解决滑动冲突的例子的时候遇到一些不明白的地方,后来自己做了一些研究才明白这些代码的意义
参考的例子
代码片段如下:
@Override
public boolean onTouchEvent(MotionEvent event)
{
switch (event.getAction())
{
case MotionEvent.ACTION_DOWN:
return true;
case MotionEvent.ACTION_MOVE:
mXMove = event.getRawX();
int xScrolled = (int) (mXLastMove - mXMove);
System.out.println(getScrollX() + xScrolled + getWidth());
//getScrollx并不是一个确定的值
System.out.println("scrollx="+getScrollX());
//左移为正。右移为负 xcscrolled表示的正方向为右,跟大部分的正方向是一致的
System.out.println("xscrolled="+xScrolled);
//getwidth表示的就是当前View的宽度
System.out.println("getwidth="+getWidth());
//leftBoard 固定为0
System.out.println("leftboard="+leftBoard);
//rightboard 固定值
System.out.println("rightboard="+rightBoard);
if (getScrollX() + xScrolled < leftBoard)
{
//滑动出左边界的时候返回到第一个页面
scrollTo(leftBoard, 0);
return true;
} else if (getScrollX() + xScrolled + getWidth() > rightBoard)
{
//滑动出右边界的时候返回到最后一个页面
scrollTo(rightBoard - getWidth(), 0);
return true;
}
mXLastMove = mXMove;
//这里才是真正滑动的方法,也就是相对于上次位置进行滑动,自带invalidate函数
scrollBy(xScrolled, 0);
break;
case MotionEvent.ACTION_UP:
System.out.println("action up scrollx="+getScrollX());
//getwidth表示的就是当前View的宽度
System.out.println("action up getwidth="+getWidth());
//下面这三行代码是用来判断滚动到哪一个页面的。
//是经典代码,很多判断都是用的这三行代码
//下面这三行代码的意思就是屏幕左边界在View的左半边则移到前一页,View的右半边则移到后一页
int index = (getScrollX() + getWidth() / 2) / getWidth();
System.out.println("action up index="+index);
int distance = index * getWidth() - getScrollX();
//那么getScrollX就是屏幕左边界处的位置相对于父View左边界的距离
//其实这个distance是精心计算的。
mScroller.startScroll(getScrollX(), 0, distance, 0,100);
invalidate();//开始动画
break;
default:
break;
}
return super.onTouchEvent(event);
}
//invalidate函数调用draw函数,draw函数调用computeScroll函数
@Override
public void computeScroll()
{
//如果绘画还没有完成,继续调用invalidate函数
if (mScroller.computeScrollOffset())
{
scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
invalidate();
}
}
其实最主要的问题就是getScrollX 代表的意思,为了这个问题还跑去技术问答区发了问题,然而并没有人回答。
自己去网上查有人这么说getScrollX
而Android自己的api则是这样说的
如果代入当前的例子,就必须说明这个View是ScrollLayout,因为我一直以为这个View是我放在GroupView里面的Fragment。
导致这个问题的原因还有一个就是fragment的match_parent表示的是适配屏幕。而不是父View。