使用序列帧实现动画

序列帧图片:https://lk-webfont.oss-cn-beijing.aliyuncs.com/web/play-qx/LKW/识别动效61张600\*600.png

这个链接有元素的宽高+张数

vue项目

动画组件 test.vue

复制代码
<template>
    <div class="frame_wrap" :style="{'--width': width+'px','--height': height+'px','--count': count, '--duration': duration+'s', '--bgSize': bgSize+'px', '--bgSize1': -bgSize+'px' }"> </div>
</template>
<script lang="ts" setup>
import { computed } from 'vue'
const props:any = defineProps({
    count: {
        type: Number,
        vlaue: 0
    },
    width: {
        type: Number,
        value: 0
    },
    height: {
        type: Number,
        value: 0
    },
    duration: {
        type: Number,
        value: 0
    }
})
const bgSize = computed(() => props.width * props.count)
</script>
<style lang="scss">
.frame_wrap {
    width: var(--width);
    height: var(--height);
    position: absolute;
    background: pink;
    -webkit-animation: frames var(--duration) steps(var(--count)) infinite;
    animation: frames var(--duration) steps(var(--count)) infinite;
    background-position: 0 0;
    background-size:  var(--bgSize) var(--height);
    background-repeat: no-repeat;
    background-image: url(https://lk-webfont.oss-cn-beijing.aliyuncs.com/web/play-qx/LKW/%E8%AF%86%E5%88%AB%E5%8A%A8%E6%95%8861%E5%BC%A0600*600.png);
}

@keyframes frames {
    from {
        background-position-x: 0;
    }

    to {
        background-position-x: var(--bgSize1);
    }
}

@-webkit-keyframes frames {
    from {
        background-position-x: 0;
    }

    to {
        background-position-x: var(--bgSize1);
    }
}
</style>

父组件调用:

<test :width="300" :height="300" :count="61" :duration="6"></test>

微信小程序开发

子组件:

复制代码
子组件:
wxml:
<view class="frame_wrap" style="background-image: url({{url}});--width:{{width}}rpx;--height:{{height}}rpx;--count:{{count}};--duration:{{duration}};"></view>

js:
Component({
  properties: {
    url: {
      type: String,
      value: ""
    },
    count: {
      type: String,
      value: 3
    },
    width:{
      type:String,
      value:360
    },
    height:{
      type:String,
      value:300
    },
    duration:{
      type: String,
      value: 0.3
    },
  },
  data: {

  },
  methods: {

  }
})
wxss:
.frame_wrap {
    width: var(--width);
    height: var(--height);
    animation: frames calc(var(--duration) * 1s) steps(var(--count)) infinite;
    background-position: 0 0;
    background-size: calc(var(--width) * var(--count)) var(--height);
  }
  
  @keyframes frames {
    from {
      background-position-x: 0;
    }
  
    to {
      background-position-x: calc(var(--width) *-1 *var(--count));
    }
  }

父组件调用:

复制代码
<css-animation wx:if="{{hasUnreadMsg == false}}" class="animation-qi" width="300" height="300" count="61" duration="6"
      url="https://lk-webfont.oss-cn-beijing.aliyuncs.com/web/play-qx/LKW/%E8%AF%86%E5%88%AB%E5%8A%A8%E6%95%8861%E5%BC%A0600*600.png"></css-animation>
相关推荐
JustHappy5 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
snow@li5 小时前
SEO-文章标题:写文章时候,分类+主标题+大纲+解释 作为标题 / 不点进去也知道全文覆盖什么 / 标题即架构
前端
kyriewen6 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
小和尚同志6 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.07 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕7 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@7 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#9 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar9 小时前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github
weixin_471383039 小时前
Taro-02-页面路由
前端·taro