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

    你可能感兴趣的文章
    OA项目之我的会议(查询)
    查看>>
    OA项目之我的审批(会议查询&会议签字)
    查看>>
    OA项目之项目简介&会议发布
    查看>>
    Object c将一个double值转换为时间格式
    查看>>
    object detection之Win10配置
    查看>>
    object detection训练自己数据
    查看>>
    object detection错误Message type "object_detection.protos.SsdFeatureExtractor" has no field named "bat
    查看>>
    object detection错误之Could not create cudnn handle: CUDNN_STATUS_INTERNAL_ERROR
    查看>>
    object detection错误之no module named nets
    查看>>
    Object of type 'ndarray' is not JSON serializable
    查看>>
    Object Oriented Programming in JavaScript
    查看>>
    object references an unsaved transient instance - save the transient instance before flushing
    查看>>
    Object 类的常见方法有哪些?
    查看>>
    Object-c动态特性
    查看>>
    Object.assign用法
    查看>>
    Object.create
    查看>>
    Object.defineProperty详解
    查看>>
    Object.keys()的详解和用法
    查看>>
    objectForKey与valueForKey在NSDictionary中的差异
    查看>>
    Objective - C 小谈:消息机制的原理与使用
    查看>>