首页 / 操作系统 / Linux / Android Scroller与computeScroll的调用机制关系
Android ViewGroup中的Scroller与computeScroll的有什么关系?答:没有直接的关系知道了答案,是不是意味着下文就没必要看了,如果说对ViewGroup自定义控件不感兴趣,可以不用看了。1.Scroller到底是什么?答:Scroller只是个计算器,提供插值计算,让滚动过程具有动画属性,但它并不是UI,也不是辅助UI滑动,反而是单纯地为滑动提供计算。无论从构造方法还是其他方法,以及Scroller的属性可知,其并不会持有View,辅助ViewGroup滑动2.Scroller只是提供计算,那谁来调用computeScroll使得ViewGroup滑动答:computeScroll也不是来让ViewGroup滑动的,真正让ViewGroup滑动的是scrollTo,scrollBy。computeScroll的作用是计算ViewGroup如何滑动。而computeScroll是通过draw来调用的。3.computeScroll和Scroller都是计算,两者有啥关系?答:文章开始已作答,没有直接的关系。computeScroll和Scroller要是飞得拉关系的话,那就是computeScroll可以参考Scroller计算结果来影响scrollTo,scrollBy,从而使得滑动发生改变。也就是Scroller不会调用computeScroll,反而是computeScroll调用Scroller。4.滑动时连续的,如何让Scroller的计算也是连续的?这个就问到了什么时候调用computeScroll了,如上所说computeScroll调用Scroller,只要computeScroll调用连续,Scroller也会连续,实质上computeScroll的连续性又invalidate方法控制,scrollTo,scrollBy都会调用invalidate,而invalidate回去触发draw,从而computeScroll被连续调用,综上,Scroller也会被连续调用,除非invalidate停止调用。5.computeScroll如何和Scroller的调用过程保持一致。computeScroll参考Scroller影响scrollTo,scrollBy,实质上,为了不重复影响scrollTo,scrollBy,那么Scroller必须终止计算currX,currY。要知道计算有没有终止,需要通过mScroller.computeScrollOffset()6.如上问题应该说的很清楚了吧,如果不明白,请留言。7.通过一个SlidePanel的例子,我们来深刻的了解一下注意:在移动平台中,要明确知道“滑动”与“滚动”的不同,具体来说,滑动和滚动的方向总是相反的。public class SlidingPanel extends RelativeLayout { private Context context; private FrameLayout leftMenu; private FrameLayout middleMenu; private FrameLayout rightMenu; private FrameLayout middleMask; private Scroller mScroller; public final int LEFT_ID = 0xaabbcc; public final int MIDEELE_ID = 0xaaccbb; public final int RIGHT_ID = 0xccbbaa;
private Point point = new Point(); private static final int SLIDE_SLOP = 20;
public SlidingPanel(Context context) { super(context); initView(context); }
public SlidingPanel(Context context, AttributeSet attrs) { super(context, attrs); initView(context); }
private void initView(Context context) {
this.context = context; mScroller = new Scroller(context, new DecelerateInterpolator()); leftMenu = new FrameLayout(context); middleMenu = new FrameLayout(context); rightMenu = new FrameLayout(context); middleMask = new FrameLayout(context); leftMenu.setBackgroundColor(Color.RED); middleMenu.setBackgroundColor(Color.GREEN); rightMenu.setBackgroundColor(Color.RED); middleMask.setBackgroundColor(0x88000000);