自定義滑動TAB

public class CustomScrollBarWidget extends FrameLayout implements ChangePage{
private Scroller mScroller;
private int mPageCount;
private int mWidth;
private ChangePage changePage;
private String TAG = "CustomScrollBarWidget";


public CustomScrollBarWidget(Context context, int pageCount, int width) {
super(context);
mScroller = new Scroller(context);
mPageCount = pageCount;
ImageView imageView = new ImageView(context);
mWidth = width / mPageCount;
LayoutParams params = new LayoutParams(mWidth, LayoutParams.WRAP_CONTENT);
imageView.setBackgroundResource(R.drawable.set_title_select);
addView(imageView, params);
}


@Override
public void computeScroll() {
if (mScroller.computeScrollOffset()) {
scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
postInvalidate();
}
}


private void setToScreen(int whichScreen) {
if (!mScroller.isFinished()) {
mScroller.abortAnimation(); // 終止Animation
}
scrollTo(whichScreen * mWidth, 0);
}


private void snapToScreen(int whichScreen) {
whichScreen = Math.max(0, Math.min(whichScreen, mPageCount - 1));
if(getScrollX() != (whichScreen * mWidth)){
final int delta = -whichScreen * mWidth - getScrollX();
mScroller.startScroll(getScrollX(), 0, delta, 0, Math.abs(delta) * 2);
invalidate(); // 重新佈局
}
}


public void setChagePage(ChangePage changePage){
this.changePage = changePage;
}

@Override
public void changePage(int pageNumber) {
snapToScreen(pageNumber);
if (changePage != null) {
changePage.changePage(pageNumber);
}

}


}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章