Flutter上线项目实战——Vap视频动画
Posted callme大帅
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Flutter上线项目实战——Vap视频动画相关的知识,希望对你有一定的参考价值。
背景
透明视频动画是目前比较流行的实现动画的一种, 大厂也相继开源自己的框架,最终我们选中腾讯vap,它支持了android、ios、Web,为我们封装flutter_vap提供了天然的便利,并且它提供了将帧图片生成带alpha通道视频的工具,这简直太赞了。
VAP(Video Animation Player)是企鹅电竞开发,用于播放酷炫动画的实现方案。
- 相比Webp, Apng动图方案,具有高压缩率(素材更小)、硬件解码(解码更快)的优点
- 相比Lottie,能实现更复杂的动画效果(比如粒子特效)
预览
安装
flutter_vap: $last_version
使用
- 播放本地视频
import 'package:flutter_vap/flutter_vap.dart';
/// return: play error: "status": "failure", "errorMsg": ""
/// play complete: "status": "complete"
Future<Map<dynamic, dynamic>> _playFile(String path) async
if (path == null)
return null;
var res = await VapController.playPath(path);
if (res["status"] == "failure")
showToast(res["errorMsg"]);
return res;
- 播放asset视频
Future<Map<dynamic, dynamic>> _playAsset(String asset) async
if (asset == null)
return null;
var res = await VapController.playAsset(asset);
if (res["status"] == "failure")
showToast(res["errorMsg"]);
return res;
- 停止播放
VapController.stop()
- 队列播放
_queuePlay() async
// 模拟多个地方同时调用播放,使得队列执行播放。
QueueUtil.get("vapQueue").addTask(() => VapController.playPath(downloadPathList[0]));
QueueUtil.get("vapQueue").addTask(() => VapController.playPath(downloadPathList[1]));
- 取消队列播放
QueueUtil.get("vapQueue").cancelTask();
例子
以上是关于Flutter上线项目实战——Vap视频动画的主要内容,如果未能解决你的问题,请参考以下文章