標籤:
Scroller類
- Scroller類封裝了滾動,用於計算view滾動的位置,可以設定滾動發生的時間長度,滾動結束時computeScrollOffset函數會返回false,否則返回true。
- 常用函數:
- public void startScroll(int startX,int startY,int dx,int dy,int duration):設定滾動的起點座標,橫軸和縱軸滾動的距離以及滾動的時間。要注意的是dx<0是往右滾動,dy<0是往下滾動
- public boolean computeScrollOffset():返回true說明滾動尚未完成,false就說明滾動完成了,該函數通常放在View.computeScroll函數中用於判斷滾動是否結束。在duration時間內一直返回false
- pubilc final int getCurrX():相對於滾動開始點的橫軸距離,即相對於startX的距離,注意不是相對於螢幕左上方。在滾動未完成時這個值一直在變。
- public final int getFinalX():返復原動的距離,即dx的值.往右滾動返回負值
- View與滾動相關的函數:
- public void computeScroll():是View類的一個空函數,在父容器重畫自己的孩子時,會調用孩子的computeScroll方法
- public void scrollTo(int x,int y):滾動view到指定位置,這個位置是相對於view的初始位置的距離.
- public void scrollBy(int x,int y):滾動view的距離,往右和往下是負值
- 使用Scroller類自訂ViewGroup的執行個體:
public class MyViewGroup extends LinearLayout { private boolean recover=true; Scroller mScroller=null; public MyViewGroup(Context context, AttributeSet attrs) { super(context, attrs); mScroller=new Scroller(context); }//實際發生滾動的函數 @Override public void computeScroll() { if (mScroller.computeScrollOffset()) { int deltX=mScroller.getCurrX(); int deltY=mScroller.getCurrY(); scrollTo(deltX, deltY); postInvalidate(); } } public void beginScroll(){ if (!recover) { mScroller.startScroll(0, 0, 0, 0, 10000); recover = true; } else { mScroller.startScroll(0, 0, -100, -100, 10000); recover = false; } invalidate(); }}
- VelocityTracker類:用於跟蹤觸屏事件的速度,通常使用VelocityTracker的步驟如下:
- static VelocityTracker obtain():擷取一個VelocityTracker執行個體
- void addMovement(MotionEvent event):添加motion event到VelocityTracker執行個體中
- void computeCurrentVelocity(int units):計算當前的速度,units用於設定速度單位,units為1表示每毫秒多少像素,units為1000表示每秒多少像素
- float getXVelocity():計算沿橫軸的速度,getYVelocity擷取縱軸方向的速度
Android Scroller類和VelocityTracker類