博客
关于我
酒店管理系统(源码+数据库)
阅读量: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/

    你可能感兴趣的文章
    MySQL与Informix数据库中的同义表创建:深入解析与比较
    查看>>
    mysql与mem_细说 MySQL 之 MEM_ROOT
    查看>>
    MySQL与Oracle的数据迁移注意事项,另附转换工具链接
    查看>>
    mysql丢失更新问题
    查看>>
    MySQL两千万数据优化&迁移
    查看>>
    MySql中 delimiter 详解
    查看>>
    MYSQL中 find_in_set() 函数用法详解
    查看>>
    MySQL中auto_increment有什么作用?(IT枫斗者)
    查看>>
    MySQL中B+Tree索引原理
    查看>>
    mysql中cast() 和convert()的用法讲解
    查看>>
    mysql中datetime与timestamp类型有什么区别
    查看>>
    MySQL中DQL语言的执行顺序
    查看>>
    mysql中floor函数的作用是什么?
    查看>>
    MySQL中group by 与 order by 一起使用排序问题
    查看>>
    mysql中having的用法
    查看>>
    MySQL中interactive_timeout和wait_timeout的区别
    查看>>
    mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
    查看>>
    mysql中json_extract的使用方法
    查看>>
    mysql中json_extract的使用方法
    查看>>
    mysql中kill掉所有锁表的进程
    查看>>