ScrollerCompat的使用

来源:互联网 发布:第五代软件下载 编辑:程序博客网 时间:2024/06/09 14:56

ScrollerCompat的使用

先说点题外话:ScrollerCompat一般会在自定义View中使用,自定义view很多时候都会重写onDraw()方法,则

 @Override    protected void onDraw(Canvas canvas) {        //对于canvas画板,因其是该控件本身提供的,所以canvas的坐标也是相对自己而言的        super.onDraw(canvas);    }

也就是说,canvas.drawCircle(CircleX,CircleY,radius,backgroundPaint);这个方法中的圆心坐标,其实是以自身的左上角的(0,0)坐标原点而确定的,而不是参照手机屏幕的坐标原点,这点需要注意下;

再顺便说几个方法:

view.setLayoutParams()---重新布局;  

view.invalidate(要在主线程中用);调用onDraw()方法; 

view.postInvalidate(可以在子线程中使用); 

view.postDelayed(Runnable action, long delayMillis);其底层也是有mHandler的 ; 

view.computeScroll();


好了言归正传,ScrollerCompat其用法与Scroller用法差不多,在自定义的view中可以这样设置:

 scrollerCompat = ScrollerCompat.create(context);   scrollerCompat.startScroll(0, 100, 500, 8, 1000);   view.postInvalidate(); 
 
完成滚动后,ondraw内部会调用下边这个方法: 
@Override  public void computeScroll() {  super.computeScroll();   if(scrollerCompat.computeScrollOffset()) {  button.layout(scrollerCompat.getCurrX(), button.getTop(), scrollerCompat.getCurrX() + button.getMeasuredWidth(), button.getBottom());  postInvalidate();  }  }  

先举例说明下,自定义一个CustomView,使用Scroller实现滚动:

  1. public class CustomView extends LinearLayout {   
  2.    
  3.     private static final String TAG = "Scroller";   
  4.    
  5.     private Scroller mScroller;   
  6.    
  7.     public CustomView(Context context, AttributeSet attrs) {   
  8.         super(context, attrs);   
  9.         mScroller = new Scroller(context);   
  10.     }   
  11.    
  12.     //调用此方法滚动到目标位置   
  13.     public void smoothScrollTo(int fx, int fy) {   
  14.         int dx = fx - mScroller.getFinalX();   
  15.         int dy = fy - mScroller.getFinalY();   
  16.         smoothScrollBy(dx, dy);   
  17.     }   
  18.    
  19.     //调用此方法设置滚动的相对偏移   
  20.     public void smoothScrollBy(int dx, int dy) {   
  21.    
  22.         //设置mScroller的滚动偏移量   
  23.         mScroller.startScroll(mScroller.getFinalX(), mScroller.getFinalY(), dx, dy);   
  24.         invalidate();//这里必须调用invalidate()才能保证computeScroll()会被调用,否则不一定会刷新界面,看不到滚动效果   
  25.     }   
  26.        
  27.     @Override   
  28.     public void computeScroll() {   
  29.        
  30.         //先判断mScroller滚动是否完成   
  31.         if (mScroller.computeScrollOffset()) {   
  32.            
  33.             //这里调用View的scrollTo()完成实际的滚动   
  34.             scrollTo(mScroller.getCurrX(), mScroller.getCurrY());   
  35.                
  36.             //必须调用该方法,否则不一定能看到滚动效果   
  37.             postInvalidate();   
  38.         }   
  39.         super.computeScroll();   
  40.     }   
  41. }   

相关API介绍如下:

  1. mScroller.getCurrX() //获取mScroller当前水平滚动的位置   
  2. mScroller.getCurrY() //获取mScroller当前竖直滚动的位置   
  3. mScroller.getFinalX() //获取mScroller最终停止的水平位置   
  4. mScroller.getFinalY() //获取mScroller最终停止的竖直位置   
  5. mScroller.setFinalX(int newX) //设置mScroller最终停留的水平位置,没有动画效果,直接跳到目标位置   
  6. mScroller.setFinalY(int newY) //设置mScroller最终停留的竖直位置,没有动画效果,直接跳到目标位置   
  7.    
  8. //滚动,startX, startY为开始滚动的位置,dx,dy为滚动的偏移量, duration为完成滚动的时间   
  9. mScroller.startScroll(int startX, int startY, int dx, int dy) //使用默认完成时间250ms   
  10. mScroller.startScroll(int startX, int startY, int dx, int dy, int duration)   
  11.    
  12. mScroller.computeScrollOffset() //返回值为boolean,true说明滚动尚未完成,false说明滚动已经完成。这是一个很重要的方法,通常放在View.computeScroll()中,用来判断是否滚动是否结束。   

最后说下ScrollerCompat 的注意事项:

可以模拟滚动,但实际上是没有让任何一个View滚动.

ScrollerCompat 一般 在View中使用.
startScroll执行后, 不会发生任何 事情.
注意1: 
startScroll 记得 调用 
postInvalidate
这样就会调用
computeScroll. 我们可以复写
computeScroll,对View中的一些子View进行滚动后的布局处理.
这个时候
注意2:
if(scrollerCompat.computeScrollOffset()) {
}
要等scrollerCompat计算完毕.
计算完毕后,可以对子View进行滚动后布局处理.如
button.layout(scrollerCompat.getCurrX(), button.getTop(), scrollerCompat.getCurrX() + button.getMeasuredWidth(), button.getBottom());
注意3:
处理后,记得再次调用postInvalidate,否则,View产生的滚动效果会非常的不流畅问题哦!

0 0