博客
关于我
酒店管理系统(源码+数据库)
阅读量:808 次
发布时间:2019-03-25

本文共 2213 字,大约阅读时间需要 7 分钟。

基于京东到家APP引导页的滑动切换及旋转效果实现

引导页功能分析

京东到家APP引导页采用了简洁直观的滑动切换结合旋转动效的设计方式。本文将从布局、动画、资源及代码实现等方面对其技术细节进行深入分析。

分布局分析

引导页面采用ConstraintLayout作为容器布局,主要由ViewPager、Lottie动画视图以及其他组件构成。视图页面切换采用UltraViewPager实现,每个页面都包含一个Lottie动画,动画播放完成后自动切换页面。

资源分析

引导页所需背景图、Lottie动画及切换动效等资源均存放于src/main/assets目录下。通过LottieConfig.json文件 controlling各个页面的动画表现,包括动画时间、重复次数及旋转效果等设置。

蕴含技术要点

  • 背景图片与动画文件:引导页面使用了背景Lottie动画Lottie_bg,每个切换页面都有对应的Lottie动画文件 э� realizing alignment
  • ViewPager滑动切换:采用了UltraViewPager实现页面滑动切换,动画效果可以根据ViewPagerரPageTransformer实现旋转效果
  • 切换动画效果:页面切换时会伴随旋转动效,旋转中心根据页面状态变化
  • 标题与内容显示:每个页面都带有标题图及内容图,并通过Lottie动画实现动态展示
  • 技术实现详解

    ViewPage برrinkTransformer实现旋转效果

    class GuideTransformer(context: Context, private val mRadius: Int) : ViewPager.PageTransformer {    private var mMaxRotate = 0f    init {        if (mRadius > 0) {            mMaxRotate = 2.0 * Math.toDegrees(atan2(                ScreenHelper.getScreenWidth(context).toDouble() / 2,                mRadius.toDouble()            )) .toFloat()        }    }    override fun transformPage(page: View, position: Float) {        if (mRadius == 0) {            return        }        when {            position < -1.0f -> {                page.rotation = -1.0f * mMaxRotate                page.pivotX = (page.width.toFloat())                page.pivotY = (page.height.toFloat())            }            position <= 1.0f -> {                if (position < 0.0f) {                    page.pivotX = (page.width * (0.5f + 0.5f * -position)).toFloat()                    page.pivotY = (page.height.toFloat())                    page.rotation = position * mMaxRotate                } else {                    page.pivotX = (0.5f * page.width * (1.0f - position)).toFloat()                    page.pivotY = (page.height.toFloat())                    page.rotation = position * mMaxRotate                }            }            else -> {                page.rotation = mMaxRotate                page.pivotX = 0f                page.pivotY = (page.height.toFloat())            }        }    }}

    代码实现总结

    整个引导页实现采用了以下关键技术组合:

  • ViewPager + UltraViewPager:实现滑动切换功能
  • Lottie动画框架:动态加载Lotte动画文件
  • ConstraintLayout:实现布局与动效控制
  • ObjectAnimator:用于动画效果实现
  • 自定义PageTransformer:实现旋转效果
  • 建议在实际开发中,按照上述引导页架构进行扩展和优化,确保各类动画效果正常运行。

    转载地址:http://axtyk.baihongyu.com/

    你可能感兴趣的文章
    Pinia:$subscribe()的使用场景
    查看>>
    Pinpoint对Kubernetes关键业务模块进行全链路监控
    查看>>
    Pinterest 大规模缓存集群的架构剖析
    查看>>
    pintos project (2) Project 1 Thread -Mission 1 Code
    查看>>
    PinYin4j库的使用
    查看>>
    PIP
    查看>>
    pip install goose-extractor // SyntaxError: Missing parentheses in call to 'print'
    查看>>
    pip install mysqlclient报错
    查看>>
    pip install 出现报asciii码错误的解决
    查看>>
    pip throws TypeError: parse() got an unexpected keyword argument ‘transport_encoding‘ 在尝试安装新软件包时
    查看>>
    pip 下载慢
    查看>>
    pip 升级报错AttributeError: ‘NoneType’ object has no attribute ‘bytes’
    查看>>
    pip 安装opencv-python卡死
    查看>>
    pip 安装出现异常
    查看>>
    Pip 安装失败:需要 SSL
    查看>>
    Pip 安装挂起
    查看>>
    pip 或 pip3 为 Python 3 安装包?
    查看>>
    pip 文件损坏导致 pip无法使用 报错 ImportError: cannot import name 'main' from 'pip._int
    查看>>
    pip 无法从 requirements.txt 安装软件包
    查看>>
    pip/pip3更换国内源
    查看>>