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

    你可能感兴趣的文章
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    Net与Flex入门
    查看>>
    net包之IPConn
    查看>>
    NFinal学习笔记 02—NFinalBuild
    查看>>
    NFS共享文件系统搭建
    查看>>
    nfs复习
    查看>>
    NFS网络文件系统
    查看>>
    ng 指令的自定义、使用
    查看>>