• 微信小程序接入lottie动画


    1、注意:canvas渲染出来的层级太高,当有弹窗的情况会暴露在弹窗外

    模拟器上会有这个问题,线上版本不会有

    2、需求

    需要把lottie动画在小程序的环境下进行展示

    3、什么是lottie动画

    由Airbnb开发并开源。允许设计师将复杂的矢量动画导出为JSON文件,并通过lottie库在移动应用或者Web上无缝地渲染这些动画。这些动画可以在iOS、Android和Web等多个平台上使用,并且可以以高性能和高质量进行呈现。
    和传统的GIF、Canvas有什么区别:

    矢量动画:lottie动画是基于矢量图形的,动画中的所有元素都是以数学形式描述的,可以无限缩放而不会失真。GIF和Canvas动画通常是基于位图的,因此在缩放时可能会失去清晰度。
    文件大小:相同动画的产生的文件,lottie的更小
    可控制性:lottie有能够控制播放次数、播放快慢、播放开始和结束的监听等。
    跨平台:类似java jvm,不同的平台有专门的处理,使得lottie只要数据一致,动画就会一致。

    4、小程序如何引入lottie

    在这里插入图片描述

    package.json

    {
      "dependencies": {
       "lottie-miniprogram": "^1.0.12"
      }
    }
    
    
    const lottieCharging = require('../../lottie/lottiename')
    
    initialLottie() {
        if (this._inited) {
          return
        }
        const devicePixelRatio = wx.getSystemInfoSync().devicePixelRatio
        wx.createSelectorQuery().select('#c0').node((res) => {
          const canvas = res.node
          const context = canvas.getContext('2d')
          canvas.width = 38 * devicePixelRatio
          canvas.height = 38 * devicePixelRatio
          lottie.setup(canvas)
          this.ani = lottie.loadAnimation({
            loop: true,
            autoplay: true,
            animationData: lottieCharging,
            rendererSettings: {
              context
            }
          })
          this._inited = true
        }).exec()
      },
    
     <canvas id="c0" type="2d" style="width: 38px; height: 38px;"></canvas> 
    
  • 相关阅读:
    go语言中的锁底层分析(二)
    SW - 清除零件实体表面上无用的凸起
    RK平台ADB不识别问题排查
    Keras深度学习实战(17)——使用U-Net架构进行图像分割
    libusb开源库使用说明
    ES6 入门教程 16 Reflect 16.1 概述
    GraphQL 实践与服务搭建
    LeetCode解法汇总2591. 将钱分给最多的儿童
    k8s基于kubectl命令管理资源并分配
    FastAPI 学习之路(八)路径参数和数值的校验
  • 原文地址:https://blog.csdn.net/u010194271/article/details/139774064