简单说说svga的应用,留个案例自己用

2024-04-28 04:08
文章标签 简单 应用 案例 svga 留个

本文主要是介绍简单说说svga的应用,留个案例自己用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目上临时要用到svga,所以就去官网看了看用法。 写了个demo,记录一下,以便不时之需。

svga的githubhttps://github.com/svga/SVGAPlayer-Web

  • 按照步骤操作即可
  • url一定是http这样的全链接形式。
  • 这个demo是在html里用的,直接引入的cdn链接。想用在其他地方的,可以去官网看看。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>svga demo</title><style>#svga1 {width: 218px;height: 173px;}</style>
</head>
<body><!-- 第一步:建一个div,带上id属性 --><div id="svga1"></div><!-- 第二步,引入svga的cdn链接 --><script src="https://cdn.jsdelivr.net/npm/svgaplayerweb@2.1.0/build/svga.min.js"></script><script>// 第三步,实例化players和parsersvar players = [];var parsers = [];players[0] = new SVGA.Player("#svga1");parsers[0] = new SVGA.Parser("#svga1");var URLS = ["https://xxx.com/xxx.svga",]// 第四步,准备动画和使用动画svgaAnimation(players[0], parsers[0], URLS[0]);// loops 0 为循环 1为1次function svgaAnimation(player, parser, url){parser.load(url,function(videoItem){player.loops = 0;player.setVideoItem(videoItem);player.clearsAfterStop = false;  //默认是清空画布 ,这边设置不清空画布player.startAnimation();},function(err){console.log("svga播放失败");})}</script>
</body>
</html>

还有个api,是控制帧数的。

// 第一种写法,是在parser.load函数里写。控制所有的动画帧数
player.onFrame(function(i) {  // i 表示帧数// do something...i === 10 && console.log(1) // 比如 当动画播放到第10帧时,输出1
})// 第二种写法,单独控制一个player的动画帧数
players[x].onFrame(function(i) {// do something...
})

同一个svga动画在6个不同位置都循环播放
  • 这时候的svga盒子,就不能用id来表示了,因为id是唯一值,要是有6个位置,就要写6个不同的id值,相当麻烦。这时候可以用类名来一次性完成。
  • 详细demo如下:
<!--demo.html-->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>同一个svga动画在6个不同位置都循环播放</title><link rel="stylesheet" href="demo.css">
</head>
<body><div class="whitecaosvga"></div><div class="whitecaosvga"></div><div class="whitecaosvga"></div><div class="whitecaosvga"></div><div class="whitecaosvga"></div><div class="whitecaosvga"></div><!-- 一定不要忘了引入svga文件哟 --><script src="https://cdn.jsdelivr.net/npm/svgaplayerweb@2.1.0/build/svga.min.js"></script><script src="demo.js"></script>
</body>
</html>
/*demo.css*/
* {padding: 0;left: 0;
}
.whitecaosvga {width: 218px;height: 173px;
}
/*demo.js*/
window.addEventListener('load', function() {var log = console.log || window.console.log;var $ = document.querySelector.bind(document);var $$ = document.querySelectorAll.bind(document);var whitecaosvga = $$('.whitecaosvga');var playerswc = [];var parserswc = [];for(var i = 0; i < 6; i++) {playerswc[i] = new SVGA.Player(whitecaosvga[i]);parserswc[i] = new SVGA.Parser(whitecaosvga[i]);}var URLS = ['https://ares.kktv8.com/kktv/resource/2021-05-13/20210513101721_470.svga',]for(var i = 0; i < 6; i++) {svgaTimes(playerswc[i], parserswc[i], URLS[0], 0);}/**引入控制动画播放次数的函数 *//**svga播放1次还是循环播放, times为0 则表示无限循环播放, times为1 则表示只播放1次 */function svgaTimes(player, parser, url, times) {function svgaAnimation(player, parser, url, times){parser.load(url,function(videoItem){player.loops = times;player.setVideoItem(videoItem);player.clearsAfterStop = false;  //默认是清空画布 ,这边设置不清空画布player.startAnimation();},function(err){console.log("svga播放失败");})}svgaAnimation(player, parser, url, times);}
})

这篇关于简单说说svga的应用,留个案例自己用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942298

相关文章

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关