浏览器视频合成转码@ffmpeg/ffmpeg使用笔记

Vite + Vue项目使用@ffmpeg/ffmpeg0.12.x版本踩坑笔记

ffmpegwasm项目github仓库有一个 vue-vite-app 模板,其中 components 目录下的 FFmpegDemo.vue 组件有示例代码,想要快速验证使用@ffmpeg/ffmpeg 建议把模版克隆下来启动。

安装

sh 复制代码
npm install @ffmpeg/ffmpeg @ffmpeg/util @ffmpeg/core -D
sh 复制代码
yarn add @ffmpeg/ffmpeg @ffmpeg/util @ffmpeg/core -D
sh 复制代码
pnpm add @ffmpeg/ffmpeg @ffmpeg/util @ffmpeg/core -D

引用

javascript 复制代码
<script setup>
import { FFmpeg } from '@ffmpeg/ffmpeg';
import { fetchFile, toBlobURL } from '@ffmpeg/util';
const videoURL = 'https://raw.githubusercontent.com/ffmpegwasm/testdata/master/video-15s.avi';//远程视频地址
const ffmpeg = new FFmpeg();
// 加载 ffmpeg 核心
const transcode = async () => {
  ffmpeg.on('log', (e) => {
    console.log(e.message);
  });
  
  await ffmpeg.load({
  //coreURL 和 wasmURL 加载核心包 GitHub文档仓库的示例是加载CDN的,我们可以把包放到public目录
    let coreURL = await toBlobURL('/public/static/esm/ffmpeg-core.js', 'text/javascript');
    let wasmURL = await toBlobURL(`/public/static/esm/ffmpeg-core.wasm`, 'application/wasm');
    await ffmpeg.load({
      coreURL,
      wasmURL
    });
  });
  
  await ffmpeg.writeFile('test.avi', await fetchFile(videoURL));//将远程视频写入FFmpeg文件系统
  await ffmpeg.exec(['-i', 'test.avi', 'test.mp4']);//FFmpeg输出视频
  const data = await ffmpeg.readFile('test.mp4');// 读取生成的视频文件
  const videoBlob = new Blob([videoData.buffer], { type: 'video/mp4' });
  videoSrc = URL.createObjectURL(videoBlob);// 返回视频Blob的URL,可用于video标签的src属性
};

</script>

关键点

1.GitHub文档仓库的示例截图,我们根据关键点将本地代码稍做修改

2.关键的核心包位置,我们拷贝到public目录

相关推荐
摆烂工程师10 分钟前
今天 Cloudflare 全球事故,连 GPT 和你的网站都一起“掉线”了
前端·后端·程序员
拉不动的猪14 分钟前
一文搞懂:localhost和局域网 IP 的核心区别与使用场景
前端·javascript·面试
亿元程序员41 分钟前
你支持游戏内显示电量、信号或时间吗?
前端
阿珊和她的猫1 小时前
HTTP:Web 世界的基石协议详解
前端·网络协议·http
未来之窗软件服务1 小时前
自建开发工具IDE(二)文件托拽读取——东方仙盟炼气期
开发语言·前端·javascript·仙盟创梦ide·东方仙盟
conkl1 小时前
构建健壮的前端请求体系:从 HTTP 状态码到 Axios 实战
前端·网络协议·http
g***B7381 小时前
前端组件设计模式,复用与扩展
前端·设计模式
chxii1 小时前
第六章:MySQL DQL 表之间的关系 自连接 一对一、一对多、多对一、多对多
java·前端·mysql
U***49832 小时前
前端性能优化插件,图片压缩与WebP转换
前端
GISer_Jing2 小时前
OpenCV头文件路径配置终极修复指南
javascript·opencv·webpack