一起来实现网易云音乐引导页效果

开始之前先看效果

网易云原效果

我实现的效果

质量有所压缩,具体可去下载网易云音乐自行查看效果
本demo apk文件下载

分析

  • 目测布局:分为两个viewpager,上面展示文字的viewpager和下面的图片viewpager;
  • 进一步观察:上面的文字viewpager滑动有延迟,而图片viewpager是没有滑动自带动画的,而且都没有自带滑动手势效果;
  • 分析得出:两个viewpager都拦截滑动事件,文字viewpager需要设置切换时间,有动画效果,图片viewpager去掉自带动画;
  • 分析图片viewpager动画效果,都是两张图片,一张背景,一张上浮图片;打开之后,背景:透明度由0到1;上浮图片:由下往上冒出;第三张图片,头像上浮之外还有个变小的过程

分析完毕,接下来具体实现

实现

  • 先实现viewpager滑动拦截,拦截点击事件就行,具体看代码不多说
public class MyInterceptViewPager extends ViewPager {
    private boolean isScrollable = true;

    public MyInterceptViewPager(Context context) {
        super(context);
    }

    public MyInterceptViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
    }


    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        return isScrollable && super.onTouchEvent(ev);
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return isScrollable && super.onInterceptTouchEvent(ev);
    }

    @Override
    public void setCurrentItem(int item) {
        super.setCurrentItem(item, false);//表示切换的时候,不需要切换时间。
    }

    @Override
    public void setCurrentItem(int item, boolean smoothScroll) {
        super.setCurrentItem(item, smoothScroll);
    }
}
  • 通过反射,实现viewpager切换动画速度修改,新建一个类继承于Scroller
public class FixedSpeedScroller extends Scroller {
    private int mDuration = 1500;

    public FixedSpeedScroller(Context context) {
        super(context);
    }

    public FixedSpeedScroller(Context context, Interpolator interpolator) {
        super(context, interpolator);
    }

    @Override
    public void startScroll(int startX, int startY, int dx, int dy, int duration) {
        // Ignore received duration, use fixed one instead
        super.startScroll(startX, startY, dx, dy, mDuration);
    }

    @Override
    public void startScroll(int startX, int startY, int dx, int dy) {
        // Ignore received duration, use fixed one instead
        super.startScroll(startX, startY, dx, dy, mDuration);
    }

    public void setmDuration(int time) {
        mDuration = time;
    }

    public int getmDuration() {
        return mDuration;
    }
}

  • 具体使用
 try {
            Field field = ViewPager.class.getDeclaredField("mScroller");
            field.setAccessible(true);
            FixedSpeedScroller scrollerText = new FixedSpeedScroller(this, new AccelerateInterpolator());
            field.set(mTextViewPager, scrollerText);
            scrollerText.setmDuration(400);
        } catch (Exception e) {

        }
  • 实现两个viewpager的联动,根据横向滑动距离和方向判断是否应该翻页
mTouchLayout.setOnTouchListener(new View.OnTouchListener() {
            float startX;
            float startY;//没有用到
            float endX;
            float endY;//没有用到
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                switch (event.getAction()) {
                    case MotionEvent.ACTION_DOWN:
                        startX = event.getX();
                        startY = event.getY();
                        break;
                    case MotionEvent.ACTION_UP:
                        endX = event.getX();
                        endY = event.getY();
                        WindowManager windowManager = (WindowManager) getApplicationContext().getSystemService(Context.WINDOW_SERVICE);
                        Point size = new Point();
                        windowManager.getDefaultDisplay().getSize(size);
                        int width = size.x;
                        if (startX - endX >= (width / 8)){// startX - endX 大于0 且大于宽的1/8 可以往后翻页
                            if (pageIndex == 0){
                                mImageViewPager.setCurrentItem(1);
                                mTextPager.setCurrentItem(1, true);
                            }else if (pageIndex == 1){
                                mImageViewPager.setCurrentItem(2);
                                mTextPager.setCurrentItem(2, true);
                            }
                        }else if (endX - startX  >= (width / 8)){ // endX - startX   大于0 且大于宽的1/8 可以往前翻页
                            if (pageIndex == 2){
                                mImageViewPager.setCurrentItem(1);
                                mTextPager.setCurrentItem(1, true);
                            }else if (pageIndex == 1){
                                mImageViewPager.setCurrentItem(0);
                                mTextPager.setCurrentItem(0, true);
                            }
                        }

                        break;
                }
                return true;
            }
        });

最后

  • 本demo资源来自解压网易云音乐apk,因为喜欢,所以模仿。
  • 本demo github地址Music163GuideDemo如果能点个star,感激不尽
  • 如果本demo对你有帮助,来个共赢的事吧,扫个红包也没损失↓↓↓


    1547192479521.jpg
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 余额宝收益一跌再跌,我们的闲钱是否已无处安放 今年下半年以来,受到央行不断向市场释放流动性的影响,货币基金的收益持...
    郭丽敬阅读 197评论 0 1
  • 曾经想过无数次的出走,终于小心翼翼的掂起了脚尖,迈出了这一步。 5点,做梦醒来,能感觉到眼球快速的转动,就像梦里一...
    463c6b66459c阅读 197评论 0 0
  • 陪伴是最长情的告白。 图片来自百度 01 世界上所有和你关系亲密的人,几乎都是肯时间陪伴你最多的人。...
    七梦的悠闲时光阅读 1,012评论 -1 3
  • 远方 远方 哪里才是远方 新疆抑或藏地 漠河还是腾冲 其实 离开了你的地方 就是远方
    墨莫陌茉呀阅读 214评论 0 3
  • 听同学说起,我才知道,原来剑桥就在我们隔壁的城市,坐火车一个多小时便可到达。说到剑桥,马上想到了剑桥大学,虽然之前...
    阳光心程阅读 981评论 2 4