使用canvas对video视频某一刻截图功能


Posted in HTML / CSS onSeptember 25, 2021

前言

本次使用的是canvas.drawImage()实现截图功能, 关于api支持的dom元素、基本参数,可点击查询下面连接 CanvasRenderingContext2D.drawImage()

处理过程

我本次的需求是多人视频中对某一视频某一刻的截图,展示视频直接用的原生video标签

1、首先获取video元素和创建canvas

const video = document.getElementById('video');
const canvas = document.createElement("canvas");
const canvasCtx = canvas.getContext("2d")

2、截图的像素大小及优化

devicePixelRatio 能够返回当前显示设备的物理像素分辨率与 CSS 像素分辨率的比率,能够更好还原真实的视频场景,具体参考官方

const ratio = window.devicePixelRatio || 1;
canvasCtx.scale(ratio, ratio);

3、处理canvas画布

// canvas大小与图片大小保持一致,截图没有多余
canvas.width = video.offsetWidth * ratio;
canvas.height = video.offsetHeight * ratio;

4、生成canvas并转化成自己需要的格式,我这里就直接转成base64了
 

canvasCtx.drawImage(video, 0, 0, canvas.width, canvas.height)
const imgBase64 = canvas.toDataURL("image/png");

到此这篇关于使用canvas对video视频某一刻截图的文章就介绍到这了,更多相关canvas视频截图内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
css3实现垂直下拉动画菜单示例
Apr 22 HTML / CSS
目前不被任何主流浏览器支持的CSS3属性汇总
Jul 21 HTML / CSS
CSS3提交意见输入框样式代码
Oct 30 HTML / CSS
html5服务器推送_动力节点Java学院整理
Jul 12 HTML / CSS
canvas像素画板的实现代码
Nov 21 HTML / CSS
HTML5的结构和语义(5):交互
Oct 17 HTML / CSS
突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)
Jan 31 HTML / CSS
Html5 audio标签样式的修改
Jan 28 HTML / CSS
详解html2canvas截图不能截取圆角图片的解决方案
Jan 30 HTML / CSS
amazeui 验证按钮扩展的实现
Aug 21 HTML / CSS
html table呈现个人简历以及单元格宽度失效的问题解决
Jan 22 HTML / CSS
css3带你实现3D转换效果
Feb 24 HTML / CSS
使用CSS实现一个搜索引擎的原理解析
sass 常用备忘案例详解
Sep 15 #HTML / CSS
关于HTML编码导致的乱码问题
Sep 04 #HTML / CSS
使用CSS3实现按钮悬停闪烁动态特效代码
Aug 30 #HTML / CSS
深入理解CSS 中 transform matrix矩阵变换问题
Aug 30 #HTML / CSS
CSS+HTML 实现顶部导航栏功能
Aug 30 #HTML / CSS
HTML5 语义化标签(移动端必备)
Aug 23 #HTML / CSS
You might like
一个ORACLE分页程序,挺实用的.
2006/10/09 PHP
杏林同学录(五)
2006/10/09 PHP
php环境配置之CGI、FastCGI、PHP-CGI、PHP-FPM、Spawn-FCGI比较?
2011/10/17 PHP
ThinkPHP3.1新特性之对页面压缩输出的支持
2014/06/19 PHP
php处理单文件、多文件上传代码分享
2016/08/24 PHP
PHP生成指定范围内的N个不重复的随机数
2019/03/18 PHP
Jquery实战_读书笔记2 选择器
2010/01/22 Javascript
如何确保JavaScript的执行顺序 之实战篇
2011/03/03 Javascript
EasyUI 中 MenuButton 的使用方法
2012/07/14 Javascript
推荐9款炫酷的基于jquery的页面特效
2014/12/07 Javascript
jquery使用正则表达式验证email地址的方法
2015/01/22 Javascript
angularjs学习笔记之完整的项目结构
2015/09/26 Javascript
Javascript实现的SHA-256加密算法完整实例
2016/02/02 Javascript
微信小程序获取音频时长与实时获取播放进度问题
2018/08/28 Javascript
vue-router二级导航切换路由及高亮显示的实现方法
2019/07/10 Javascript
JavaScript中数组去重的5种方法
2020/07/04 Javascript
[53:29]完美世界DOTA2联赛循环赛 DM vs Matador BO2第二场 11.04
2020/11/05 DOTA
Python 字典(Dictionary)操作详解
2014/03/11 Python
Python深入学习之特殊方法与多范式
2014/08/31 Python
Python中的多重装饰器
2015/04/11 Python
Python编程之多态用法实例详解
2015/05/19 Python
Fiddler如何抓取手机APP数据包
2016/01/22 Python
基于Python新建用户并产生随机密码过程解析
2019/10/08 Python
python实现图片横向和纵向拼接
2020/03/05 Python
Python requests模块session代码实例
2020/04/14 Python
纯css3实现走马灯效果
2014/12/26 HTML / CSS
canvas绘制树形结构可视图形的实现
2020/04/03 HTML / CSS
西班牙最好的在线购买葡萄酒的商店:Vinoseleccion
2019/10/30 全球购物
Aurora London官网:奢华、负担得起的皮革手袋
2020/08/01 全球购物
北京一家公司的.net开发工程师笔试题
2012/04/17 面试题
人力资源管理毕业生自荐信
2013/11/21 职场文书
法律专业推荐信范文
2013/11/29 职场文书
中国央视网签名寄语
2014/01/18 职场文书
Python 流媒体播放器的实现(基于VLC)
2021/04/28 Python
详解Python自动化之文件自动化处理
2021/06/21 Python
CSS实现背景图片全屏铺满自适应的3种方式
2022/07/07 HTML / CSS