上传本地视频前,获取视频时长,并以视频第一秒作为封面

2023-10-30

本文介绍的是,在本地添加了需要上传的视频文件后,先获取到视频的可播放时长,并且以视频的第一秒画面作为封面图片的实现方法,之后再调用上传接口,将相关数据进行上传。【网上搜到的大部分都是先上传文件,再使用接口返回的视频地址获取封面,不符合我的需求,所以作此文进行整理】
可以先使用上传组件获取到上传的视频文件对象,如elementUI或Antd的Upload组件。
此处以elementUI的el-upload组件举例,在beforeUpload方法中,先获取到file对象,然后进行以下代码操作。

const canvas = document.getElementById("mycanvas"); // 获取 canvas 对象
const ctx = canvas.getContext("2d"); // 绘制2d
let video = document.createElement("video");
video.src = URL.createObjectURL(file);
video.addEventListener("loadedmetadata", (_event) => {
  // 获取视频时长
  const duration = parseInt(video.duration);
  // 获取视频内容宽高比
  const scale = video.videoWidth / video.videoHeight;
});
video.currentTime = 1; // 设置视频播放进度为第一秒
video.oncanplay = () => {
  // 按视频内容原比例设置canvas宽度、高度
  // 此处198为按需求设置的视频展示区的高度
  canvas.width = 198 * scale;
  canvas.height = 198;
  // 利用canvas对象方法绘图
  ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
  // 转换成base64形式
  const imgSrc = canvas.toDataURL("image/png"); // 截取后的视频封面
};
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

上传本地视频前,获取视频时长,并以视频第一秒作为封面 的相关文章

随机推荐

  • Java之package语句和import语句

    Java之package语句和import语句
  • 机器学习人工智能中的Rubyyy或nay

    Ror是机器学习的最佳选择吗 IS ROR THE BEST CHOICE FOR MACHINE LEARNING Currently we see many web developers and tech enthusiasts tal
  • EXT.JS2.2ajax请求

    ext2 x ext3 x 不支持ajax的同步请求 ext4就开始支持 Ext Ajax request url adapterInfo do invoke queryAdapterDatabases method post params
  • 对于Java封装、继承、多态的新理解

    封装 封装包括两个字 封和装 先是装 后才封 在面向过程语言中 一般数据都是相互独立 例如姓名 年龄 性别这些数据 虽然它们都是在描述一个人 但是它们数据是离散的 这样就不便于数据的传递 例如方法需要的参数为姓名 年龄 性别等一系列参数 那
  • 1.3扩展演练---认识错误(BUG)

    1 3扩展演练 认识错误 BUG 第一个演练中常见的错误 1 gt 手误 例如使用pint hello world NameError name pint is not defined 名称错误 pint 名字没有定义 2 gt 将多条pr
  • java中super的三种用法

    java中super的用法 super只在子类中出现 super有三种用法 1 super xxx xxx可以是类的属性 例如super name 即从子类中获取父类name属性的值 2 super xxx xxx 可以是类中的方法名 su
  • el-select实现懒加载

    先看一个线上的演示示例 https code juejin cn pen 7273352811440504889 背景 我们在实际开发中经常遇到这样的需求 el select实现懒加载 用通俗的话说 为了增加响应速度 就是初始下拉只展示50
  • 「区块链+数字身份」:DID 身份认证的新战场

    美国经济学家布莱恩 阿瑟在其著作 技术的本质 中 写过这么一句话 技术总是进行着这样一种循环 为解决老问题去采用新技术 新技术又引发新问题 新问题的解决又要诉诸更新的技术 区块链技术之所以能流行 部分原因是它能解决互联网时代遗留下的问题 比
  • 手把手教你配置JAVA环境变量、安装IDEA,简单易懂,学会你给我点赞,学不会我给你点赞

    前言 保姆级教程 让你易如睡觉 学不会来叨我 我飞去给你配 如果车票报销的话 手把手教程 别人配置java的痛苦你体会不到 让你边配边笑 新手学java 看完这个就能开写啦 配置java环境 配置java环境就是安装jdk和配置环境变量 安
  • 动态库的链接和链接选项-L,-rpath-link,-rpath【转】

    转自 https my oschina net shelllife blog 115958 链接动态库 如何程序在连接时使用了共享库 就必须在运行的时候能够找到共享库的位置 linux的可执行程序在执行的时候默认是先搜索 lib和 usr
  • CPU的标志寄存器

    1 ZF 零标志位 执行指令后结果为0 ZF 1 否则ZF 0 2 PF 奇偶标识位 它记录相关指令执行后 其结果的所有二进制位中1的个数是否为偶数 如果是偶数 PF 1 否则PF 1 3 SF 符号标识位 它记录相关指令执行后 其结果是否
  • jQuery 入门教程(43): jQuery UI Tooltip 示例

    JQuery tooltip 的基本用法 可以把所有元素的的 title 属性做为Toolbar显示 比如 1 2
  • 云栖大会带热一座城,靠的是什么?

    云栖大会带热一座城 靠的是什么 这几年 每到九十月份 杭州都会热闹一阵子 几万人突然出现在杭州 然后到一个叫云栖小镇的 偏僻 地方开会 好像动物大迁徙 是什么吸引了近6万人从全国各地甚至世界各地赶来 大会的门票也跟明星演唱会那样一票难求 这
  • 微信小程序实现一些优惠券/卡券

    背景 前几周有小伙伴问我如何用css实现一些优惠券 卡券 今天就来分享一波吧 速速来Get吧 文末分享源代码 记得点赞 关注 收藏 1 实现效果 2 实现原理 2 1 实现内凹圆角 假设我们要实现这样的一个效果 两侧透明内圆角 外侧投影 有
  • Unity SpriteAtlas 打图集流程,与遇到的问题和解决方法

    Unity SpriteAtlas 打图集流程 与遇到的问题和解决方法 1 创建图集 2 遇到的问题 3 解决方法 1 创建图集 在unity里面使用SpriteAtlas 把需要用到的游戏贴图资源 创建成对应的图集
  • Spring Boot(七)logback配置

    简介 Java 日志框架众多 常用的有 java util logging log4j logback commons logging logback 是 log4j 框架的作者开发的新一代日志框架 它效率更高 能够适应诸多的运行环境 同时
  • 2分钟理解C++的条件表达式

    今天我们来学习下C 中的条件运算符和条件表达式 说个明白 条件运算符 是C 中唯一的三目运算符 由其构成的表达式称为条件表达式 它是这样的 s1 s2 s3 它的意思就是 如果s1为真 非零 则表达式的结果为s2 否则为s3 对应的if e
  • linux内核电源管理浅析

    一 重启 reboot 应用程序通过reboot系统调用实现机器重启 reboot系统调用定义在kernel sys c文件中 SYSCALL DEFINE4 reboot int magic1 int magic2 unsigned in
  • 【python】错误:UnboundLocalError: local variable ‘XXX‘ referenced before assignment

    topNSuccessor None def reverseTopN self head ListNode right int gt ListNode if right 1 topNSuccessor head next return he
  • 上传本地视频前,获取视频时长,并以视频第一秒作为封面

    本文介绍的是 在本地添加了需要上传的视频文件后 先获取到视频的可播放时长 并且以视频的第一秒画面作为封面图片的实现方法 之后再调用上传接口 将相关数据进行上传 网上搜到的大部分都是先上传文件 再使用接口返回的视频地址获取封面 不符合我的需求