当前位置: 首页 > news >正文

最新的ffmepg.js前端VUE3实现视频、音频裁剪上传功能

package.json

"dependencies": {"@ffmpeg/ffmpeg": "^0.12.10","@ffmpeg/util": "^0.12.1"
}

vue3组件代码

根据需要更改

<script setup lang="ts">
import { FFmpeg } from '@ffmpeg/ffmpeg';
import { fetchFile, toBlobURL } from '@ffmpeg/util';
import useInject from '@/utils/useInject';import { reactive, onUnmounted } from 'vue';
const { $global, $fn } = useInject();const props: any = defineProps<{params?: any;url?: any;
}>();let ffmpegObj: any = reactive({file: null,urlpre: null,url: null,params: {...(props?.params || {}),ext: '',starttime: 0,endtime: 3,maxtime: 0,},
});const ffmpeg = new FFmpeg();function filechange(e: any) {ffmpegObj.file = e.target.files[0];// 原视频预览方案一const reader: any = new FileReader();reader.readAsDataURL(ffmpegObj.file);reader.onload = () => {ffmpegObj.url = '';ffmpegObj.urlpre = reader.result;const audioElement: any = new Audio(ffmpegObj.urlpre);audioElement.addEventListener('loadedmetadata', () => {ffmpegObj.params.maxtime = audioElement.duration;ffmpegObj.params.starttime = 0;ffmpegObj.params.endtime = audioElement.duration;});};// 原视频预览方案二// const reader: any = new FileReader();// reader.readAsArrayBuffer(ffmpegObj.file);// let blob = null;// reader.onload = (e: any) => {//     if (typeof e.target.result === 'object') {//         blob = new Blob([e.target.result]);//     } else {//         blob = e.target.result;//     }//     ffmpegObj.url = '';//     if (blob == null) return;//     const url = URL.createObjectURL(blob);//     ffmpegObj.urlpre = url;//     const audioElement = new Audio(url);//     audioElement.addEventListener('loadedmetadata', function () {//         ffmpegObj.params.maxtime = audioElement.duration;//         ffmpegObj.params.starttime = 0;//         ffmpegObj.params.endtime = audioElement.duration;//     });// };
}
async function doffmpeg() {try {if (!ffmpegObj.file) {return;}ffmpegObj.fileext = ffmpegObj.file.name.split('.').pop();const inputName = `input.${ffmpegObj.fileext}`;const outputName = `output.${ffmpegObj.params.ext ? ffmpegObj.params.ext : ffmpegObj.fileext}`;console.log(666.001, ffmpeg, ffmpegObj);ffmpeg.on('log', ({ message: msg }) => {ffmpegObj.msglogger = msg;});await ffmpeg.load({coreURL: await toBlobURL('./ffmpeg/ffmpeg-core.js','text/javascript'),wasmURL: await toBlobURL('./ffmpeg/ffmpeg-core.wasm','application/wasm'),workerURL: await toBlobURL(`./ffmpeg/ffmpeg-core.worker.js`,'text/javascript'),});await ffmpeg.writeFile(inputName, await fetchFile(ffmpegObj.urlpre));await ffmpeg.exec(['-ss',`${ffmpegObj.params.starttime !== undefined? ffmpegObj.params.starttime: 0}`,'-t',`${(ffmpegObj.params.endtime !== undefined? ffmpegObj.params.endtime: 3) -(ffmpegObj.params.starttime !== undefined? ffmpegObj.params.starttime: 0)}`,'-i',inputName,outputName,]);ffmpegObj.data = await ffmpeg.readFile(outputName);ffmpegObj.blob = new Blob([ffmpegObj.data.buffer], {type:'video/' + ffmpegObj.params.ext? ffmpegObj.params.ext: ffmpegObj.fileext,});ffmpegObj.url = URL.createObjectURL(ffmpegObj.blob);ffmpegObj.urlpre = ''; // 清空原预览视频} catch (err) {alert('出错了');throw err;}
}
function blobToBase64(blob: any) {console.log(666.3002, blob);return new Promise((resolve, reject) => {const fileReader = new FileReader();fileReader.readAsDataURL(blob);fileReader.onload = () => {resolve(fileReader.result);};fileReader.onerror = () => {reject(new Error('文件流异常'));};});
}
// function convertBlobToFile(blob, fileName) {
//     blob.lastModifiedDate = new Date();
//     blob.name = fileName;
//     return blob;
// }
async function submit() {await doffmpeg();const resdata: any = await blobToBase64(ffmpegObj.blob);// const resdata: any = convertBlobToFile(ffmpegObj.blob, 'aaa');console.log(666.30002, resdata);$fn.useApiFiles().request({data: props.url? { url: props.url }: {dir: 'chat/chat',uid: $fn.As.Uuid('CU'),ext:'.' +(ffmpegObj.params.ext? ffmpegObj.params.ext: ffmpegObj.fileext),data: resdata,},}).then((res: any) => {console.log(666.789, res);props?.params?.fn(res);}).catch((err: any) => {$global.tipsfn({ type: 'err', con: err });});
}//下载
function downffmpeg() {const oA: any = document.createElement('a');oA.download ='video_' +Date.now() +'.' +(ffmpegObj.params.ext ? ffmpegObj.params.ext : ffmpegObj.fileext);oA.href = ffmpegObj.url;document.body.appendChild(oA);oA.click();// 释放 URL 对象URL.revokeObjectURL(oA.href);oA.remove();
}
onUnmounted(() => {ffmpegObj = null;
});
</script>
<template><div class="as-ff-area"><div class="as-show-area"><!-- <template v-if="ffmpegObj.urlpre"> -->原视频<video :src="ffmpegObj.urlpre" controls></video><!-- </template> --><!-- <template v-else> -->裁剪后视频<video :src="ffmpegObj.url" controls></video><!-- </template> -->日志:{{ ffmpegObj.params.starttime }}-{{ ffmpegObj.params.endtime }}({{ ffmpegObj.params.maxtime }})<inputtype="range"v-model="ffmpegObj.params.starttime"min="0":max="ffmpegObj.params.maxtime"/><inputtype="range"v-model="ffmpegObj.params.endtime"min="0":max="ffmpegObj.params.maxtime"/><!-- <input type="number" v-model="ffmpegObj.params.starttime" /><input type="number" v-model="ffmpegObj.params.endtime" /> -->{{ ffmpegObj.msglogger }}{{ ffmpegObj.msgprogress }}</div><div class="as-file-area">选择图片:<input class="file" type="file" @change="filechange" /></div><div class="as-btn-area"><button @click="doffmpeg()">裁剪</button><button @click="downffmpeg()">下载</button><button @click="submit()">提交</button></div></div>
</template><style scoped>
.as-ff-area {width: 100%;height: 100%;display: flex;flex-direction: column;
}
.as-btn-area {text-align: center;height: auto;
}
.as-btn-area > button {user-select: none;padding: 5px 12px;margin: 15px 5px 0 5px;
}
.as-file-area {padding: 5px 12px;text-align: center;height: auto;width: auto;display: inline-block;background-color: var(--ch1);
}
.as-show-area {flex-grow: 1;width: 100%;overflow: auto;display: flex;justify-content: center;align-items: center;flex-direction: column;
}
</style>

相关文章:

最新的ffmepg.js前端VUE3实现视频、音频裁剪上传功能

package.json "dependencies": {"ffmpeg/ffmpeg": "^0.12.10","ffmpeg/util": "^0.12.1" }vue3组件代码 根据需要更改 <script setup lang"ts"> import { FFmpeg } from ffmpeg/ffmpeg; import { fetchF…...

“Apache Kylin 实战指南:从安装到高级优化的全面教程

Apache Kylin是一个开源的分布式分析引擎,它提供了在Hadoop/Spark之上的SQL查询接口及多维分析(OLAP)能力,支持超大规模数据的亚秒级查询。以下是Kylin的入门教程,帮助您快速上手并使用这个强大的工具。 1. 安装Kylin Apache Kylin的安装是一个关键步骤,它要求您具备一…...

【iOS】内存泄漏检查及原因分析

目录 为什么要检测内存泄漏&#xff1f;什么是内存泄漏&#xff1f;内存泄漏排查方法1. 使用Zombie Objects2. 静态分析3. 动态分析方法定位修改Leaks界面分析Call Tree的四个选项&#xff1a; 内存泄漏原因分析1. Leaked Memory&#xff1a;应用程序未引用的、不能再次使用或释…...

“深入探讨Java中的对象拷贝:浅拷贝与深拷贝的差异与应用“

前言&#xff1a;在Java编程中&#xff0c;深拷贝&#xff08;Deep Copy&#xff09;与浅拷贝&#xff08;Shallow Copy&#xff09;是两个非常重要的概念。它们涉及到对象在内存中的复制方式&#xff0c;对于理解对象的引用、内存管理以及数据安全都至关重要。 ✨✨✨这里是秋…...

Docker 进入指定容器内部(以Mysql为例)

文章目录 一、启动容器二、查看容器是否启动三、进入容器内部 一、启动容器 这个就不多说了 直接docker run… 二、查看容器是否启动 查看正在运行的容器 docker ps查看所有的容器 docker ps -a结果如下图所示&#xff1a; 三、进入容器内部 通过CONTAINER ID进入到容器…...

计算机网络-数制转换与子网划分

目录 一、了解数制 1、计算机的数制 2、二进制 3、八进制 4、十进制 5、十六进制 二、数制转换 1、二进制转十进制 2、八进制转十进制 3、十六进制转十进制 4、十进制转二进制 5、十进制转八进制 6、十进制转十六进制 三、子网划分 1、IP地址定义 2、IP的两种协…...

【ssh命令】ssh登录远程服务器

命令格式&#xff1a;ssh 用户名主机IP # 使用非默认端口: -p 端口号 ssh changxianrui192.168.100.100 -p 1022 # 使用默认端口 22 ssh changxianrui192.168.100.100 然后输入密码&#xff0c;就可以登录进去了。...

【区块链】truffle测试

配置区块链网络 启动Ganache软件 使用VScode打开项目的wordspace 配置对外访问的RPC接口为7545&#xff0c;配置项目的truffle-config.js实现与新建Workspace的连接。 创建项目 创建一个新的目录 mkdir MetaCoin cd MetaCoin下载metacoin盒子 truffle unbox metacoincontra…...

【AIGC调研系列】chatTTS与GPT-SoVITS的对比优劣势

ChatTTS和GPT-SoVITS都是在文本转语音&#xff08;TTS&#xff09;领域的重要开源项目&#xff0c;但它们各自有不同的优势和劣势。 ChatTTS 优点&#xff1a; 多语言支持&#xff1a;ChatTTS支持中英文&#xff0c;并且能够生成高质量、自然流畅的对话语音[4][10][13]。细粒…...

LLVM Cpu0 新后端10

想好好熟悉一下llvm开发一个新后端都要干什么&#xff0c;于是参考了老师的系列文章&#xff1a; LLVM 后端实践笔记 代码在这里&#xff08;还没来得及准备&#xff0c;先用网盘暂存一下&#xff09;&#xff1a; 链接: https://pan.baidu.com/s/1yLAtXs9XwtyEzYSlDCSlqw?…...

k8s面试题大全,保姆级的攻略哦(二)

目录 三十六、pod的定义中有个command和args参数&#xff0c;这两个参数不会和docker镜像的entrypointc冲突吗&#xff1f; 三十七、标签及标签选择器是什么&#xff0c;如何使用&#xff1f; 三十八、service是如何与pod关联的&#xff1f; 三十九、service的域名解析格式…...

Mysql:通过一张表里的父子级,递归查询并且分组分级

递归函数WITH RECURSIVE语法 WITH RECURSIVE cte_name (column_list) AS (SELECT initial_query_resultUNION [ALL]SELECT recursive_queryFROM cte_nameWHERE condition ) SELECT * FROM cte_name; WITH RECURSIVE 关键字&#xff1a;表示要使用递归查询的方式处理数据。 c…...

数据结构之排序算法

目录 1. 插入排序 1.1.1 直接插入排序代码实现 1.1.2 直接插入排序的特性总结 1.2.1 希尔排序的实现 1.2.2 希尔排序的特性总结 2. 选择排序 2.1.1 选择排序 2.1.2 选择排序特性 2.2.1 堆排序 2.2.2 堆排序特性 3. 交换排序 3.1.1 冒泡排序 3.1.2 冒泡排序的特性 …...

移动安全赋能化工能源行业智慧转型

随着我国能源化工企业的不断发展&#xff0c;化工厂中经常存在火灾爆炸的危险&#xff0c;特别是生产场所&#xff0c;约有80%以上生产场所区域存在爆炸性物质。而目前我国化工危险场所移动通信设备的普及率高&#xff0c;但是对移动通信设备的安全防护却有所忽视&#xff0c;包…...

今天是放假带娃的一天

端午节放假第一天 早上5点半宝宝就咔咔乱叫了&#xff0c;几乎每天都这个点醒&#xff0c;准时的很&#xff0c;估计他是个勤奋的娃吧&#xff0c;要早起锻炼婴语&#xff0c;哈哈 醒来后做饭、洗锅、洗宝宝的衣服、给他吃D3&#xff0c;喂200ml奶粉、给他洗澡、哄睡&#xff0…...

linux Ubuntu安装samba服务器与SSH远程登录

目录 1&#xff0c;下载安装包 2&#xff0c;添加服务器 3&#xff0c;修改服务器配置 3.1 备份配置文件 3.2 修改配置 4&#xff0c;开启samba服务器 5&#xff0c;开关电脑与服务器设置 6&#xff0c; SSH远程登录 1&#xff0c;下载samba服务器安装包 sudo apt in…...

纳什均衡:博弈论中的运作方式、示例以及囚徒困境

文章目录 一、说明二、什么是纳什均衡&#xff1f;2.1 基本概念2.2 关键要点 三、理解纳什均衡四、纳什均衡与主导策略五、纳什均衡的例子六、囚徒困境七、如何原理和应用7.1 博弈论中的纳什均衡是什么&#xff1f;7.2 如何找到纳什均衡&#xff1f;7.3 为什么纳什均衡很重要&a…...

Linux之进程信号详解【上】

&#x1f30e; Linux信号详解 文章目录&#xff1a; Linux信号详解 信号入门 技术应用角度的信号 信号及信号的产生       信号的概念       信号的处理方式 信号的产生方式         键盘产生信号         系统调用产生信号         软件…...

【Spring Cloud】Eureka详细介绍及底层原理解析

目录 底层原理详解 1. 服务注册与发现 2. 心跳机制 3. 服务剔除与自我保护机制 Eureka Server 核心组件 Eureka Client 核心组件 使用场景 结语 Eureka 是 Netflix 开源的一款服务发现框架&#xff0c;用于构建分布式系统中的服务注册与发现。 它包含两个核心组件&…...

【清华大学】《自然语言处理》(刘知远)课程笔记 ——NLP Basics

自然语言处理基础&#xff08;Natural Language Processing Basics, NLP Basics&#xff09; 自然语言处理( Natural Language Processing, NLP)是计算机科学领域与人工智能领域中的一个重要方向。它研究能实现人与计算机之间用自然语言进行有效通信的各种理论和方法。自然语言…...

【Python】 -- 趣味代码 - 小恐龙游戏

文章目录 文章目录 00 小恐龙游戏程序设计框架代码结构和功能游戏流程总结01 小恐龙游戏程序设计02 百度网盘地址00 小恐龙游戏程序设计框架 这段代码是一个基于 Pygame 的简易跑酷游戏的完整实现,玩家控制一个角色(龙)躲避障碍物(仙人掌和乌鸦)。以下是代码的详细介绍:…...

云计算——弹性云计算器(ECS)

弹性云服务器&#xff1a;ECS 概述 云计算重构了ICT系统&#xff0c;云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台&#xff0c;包含如下主要概念。 ECS&#xff08;Elastic Cloud Server&#xff09;&#xff1a;即弹性云服务器&#xff0c;是云计算…...

centos 7 部署awstats 网站访问检测

一、基础环境准备&#xff08;两种安装方式都要做&#xff09; bash # 安装必要依赖 yum install -y httpd perl mod_perl perl-Time-HiRes perl-DateTime systemctl enable httpd # 设置 Apache 开机自启 systemctl start httpd # 启动 Apache二、安装 AWStats&#xff0…...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例

文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

Keil 中设置 STM32 Flash 和 RAM 地址详解

文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...

Java-41 深入浅出 Spring - 声明式事务的支持 事务配置 XML模式 XML+注解模式

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持续更新中&#xff01;&#xff08;长期更新&#xff09; 目前2025年06月05日更新到&#xff1a; AI炼丹日志-28 - Aud…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(一)

宇树机器人多姿态起立控制强化学习框架论文解析 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架&#xff08;一&#xff09; 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化…...

PL0语法,分析器实现!

简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...

如何在网页里填写 PDF 表格?

有时候&#xff0c;你可能希望用户能在你的网站上填写 PDF 表单。然而&#xff0c;这件事并不简单&#xff0c;因为 PDF 并不是一种原生的网页格式。虽然浏览器可以显示 PDF 文件&#xff0c;但原生并不支持编辑或填写它们。更糟的是&#xff0c;如果你想收集表单数据&#xff…...

Springboot社区养老保险系统小程序

一、前言 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;社区养老保险系统小程序被用户普遍使用&#xff0c;为方…...