Skip to content

可全方位滑动,背景图片跟随手势滑动的ViewPager。

Notifications You must be signed in to change notification settings

zhe525069676/BgMoveViewPager

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 

Repository files navigation

BgMoveViewPager

背景图片跟随手势滑动的ViewPager,可各方向滑动或点击切换页面。

原效果参考 ANA Portuguese Airports(google play地址)

效果图

组成

项目由一个Activity和五个fragment组成。

主要代码介绍

1、横向背景移动的ViewPager中,重写dispatchDraw方法:

@Override
protected void dispatchDraw(Canvas canvas) {
   if (this.bg != null) {
        int width = this.bg.getWidth();
        int height = this.bg.getHeight();
        int count = getAdapter().getCount();
        int x = getScrollX();
        //子View中背景图片需要显示的宽度,放大背景图或缩小背景图。
        int n = height * getWidth() / getHeight();
        //(width - n) / (count - 1)表示除去显示第一个ViewPager页面用去的背景宽度,剩余的ViewPager需要显示的背景图片的宽度。
        //getWidth()等于ViewPager一个页面的宽度,即手机屏幕宽度。在该计算中可以理解为滑动一个ViewPager页面需要滑动的像素值。
        //((width - n) / (count - 1)) / getWidth()也就表示ViewPager滑动一个像素时,背景图片滑动的宽度。
        //x * ((width - n) / (count - 1)) / getWidth()也就表示ViewPager滑动x个像素时,背景图片滑动的宽度。
        //背景图片滑动的宽度的宽度可以理解为背景图片滑动到达的位置。
        int w = (x+getWidth()) * ((width - n) / (count - 1)) / getWidth();
        canvas.drawBitmap(this.bg, new Rect(w, 0, n + w, height), new Rect(x, 0, x + getWidth(), getHeight()), this.b);
    }
    super.dispatchDraw(canvas);
}

2、IScrollListener中控制是否可以方向滚动

void canScrollView(boolean isCanScroll);

3、添加FixedSpeedScroller类(继承Scroller),控制ViewPager调用setCurrentItem方法时的滚动速度。

private int mDuration = 800; // 默认为800ms
@Override
    public void startScroll(int startX, int startY, int dx, int dy, int duration) {
        super.startScroll(startX, startY, dx, dy, mDuration);
    }

    @Override
    public void startScroll(int startX, int startY, int dx, int dy) {
        super.startScroll(startX, startY, dx, dy, mDuration);
    }

最后

如果对您有帮助请Star,有问题随时联系我,谢谢.

关于我

QQ交流群: 496946393

邮箱: [email protected]

简书

个人博客

About

可全方位滑动,背景图片跟随手势滑动的ViewPager。

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages