Android里OverScroller類(lèi)是為了實(shí)現(xiàn)View平滑滾動(dòng)的一個(gè)Helper類(lèi)。通常在自定義的View時(shí)使用舞萄,在View中定義一個(gè)私有成員mScroller = new OverScroller(context)眨补。設(shè)置mScroller滾動(dòng)的位置時(shí),并不會(huì)導(dǎo)致View的滾動(dòng)鹏氧,通常是用mScroller記錄/計(jì)算View滾動(dòng)的位置渤涌,再重寫(xiě)View的computeScroll()佩谣,完成實(shí)際的滾動(dòng)把还。 相關(guān)API介紹如下
mScroller.getCurrX() //獲取mScroller當(dāng)前水平滾動(dòng)的位置
mScroller.getCurrY() //獲取mScroller當(dāng)前豎直滾動(dòng)的位置
mScroller.getFinalX() //獲取mScroller最終停止的水平位置
mScroller.getFinalY() //獲取mScroller最終停止的豎直位置
mScroller.setFinalX(int newX) //設(shè)置mScroller最終停留的水平位置,沒(méi)有動(dòng)畫(huà)效果茸俭,直接跳到目標(biāo)位置
mScroller.setFinalY(int newY) //設(shè)置mScroller最終停留的豎直位置吊履,沒(méi)有動(dòng)畫(huà)效果,直接跳到目標(biāo)位置
//滾動(dòng)调鬓,startX, startY為開(kāi)始滾動(dòng)的位置艇炎,dx,dy為滾動(dòng)的偏移量, duration為完成滾動(dòng)的時(shí)間
mScroller.startScroll(int startX, int startY, int dx, int dy) //使用默認(rèn)完成時(shí)間250ms
mScroller.startScroll(int startX, int startY, int dx, int dy, int duration)
mScroller.computeScrollOffset() //返回值為boolean,true說(shuō)明滾動(dòng)尚未完成腾窝,false說(shuō)明滾動(dòng)已經(jīng)完成缀踪。這是一個(gè)很重要的方法居砖,通常放在View.computeScroll()中,用來(lái)判斷是否滾動(dòng)是否結(jié)束驴娃。
舉例說(shuō)明奏候,自定義一個(gè)CustomView,使用Scroller實(shí)現(xiàn)滾動(dòng):
import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.Scroller;
public class CustomView extends LinearLayout {
private static final String TAG = "Scroller";
private OverScroller mScroller;
public CustomView(Context context, AttributeSet attrs) {
super(context, attrs);
mScroller = new OverScroller(context);
}
//調(diào)用此方法滾動(dòng)到目標(biāo)位置
public void smoothScrollTo(int fx, int fy) {
int dx = fx - mScroller.getFinalX();
int dy = fy - mScroller.getFinalY();
smoothScrollBy(dx, dy);
}
//調(diào)用此方法設(shè)置滾動(dòng)的相對(duì)偏移
public void smoothScrollBy(int dx, int dy) {
//設(shè)置mScroller的滾動(dòng)偏移量
mScroller.startScroll(mScroller.getFinalX(), mScroller.getFinalY(), dx, dy);
invalidate();//這里必須調(diào)用invalidate()才能保證computeScroll()會(huì)被調(diào)用唇敞,否則不一定會(huì)刷新界面蔗草,看不到滾動(dòng)效果
}
@Override
public void computeScroll() {
//先判斷mScroller滾動(dòng)是否完成
if (mScroller.computeScrollOffset()) {
//這里調(diào)用View的scrollTo()完成實(shí)際的滾動(dòng)
scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
//必須調(diào)用該方法,否則不一定能看到滾動(dòng)效果
postInvalidate();
}
super.computeScroll();
}
}