使用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 相关文章推荐
IE矩阵Matrix滤镜旋转与缩放及如何结合transform
Nov 29 HTML / CSS
css3实现一款模仿iphone样式的注册表单
Mar 20 HTML / CSS
实现CSS3中的border-radius(边框圆角)示例代码
Jul 19 HTML / CSS
CSS3中各种颜色属性的使用教程
May 17 HTML / CSS
使用CSS3滤镜的filter:blur属性制作毛玻璃模糊效果的方法
Jul 08 HTML / CSS
HTML5 Canvas绘制文本及图片的基础教程
Mar 14 HTML / CSS
HTML5 canvas实现雪花飘落特效
Mar 08 HTML / CSS
canvas实现俄罗斯方块的方法示例
Dec 13 HTML / CSS
使用HTML5里的classList操作CSS类
Jun 28 HTML / CSS
html5自动播放mov格式视频的实例代码
Jan 14 HTML / CSS
用canvas显示验证码的实现
Apr 10 HTML / CSS
详解flex:1什么意思
Jul 23 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
php的list()的一步操作给一组变量进行赋值的使用
2011/05/18 PHP
ThinkPHP3.1新特性之内容解析输出详解
2014/06/19 PHP
ThinkPHP之M方法实例详解
2014/06/20 PHP
ThinkPHP提示错误Fatal error: Allowed memory size的解决方法
2015/02/12 PHP
[原创]PHP简单开启curl的方法(测试可行)
2016/01/11 PHP
PHP实现的链式队列结构示例
2017/09/15 PHP
PDO::errorCode讲解
2019/01/28 PHP
用Javascript数组处理多个字符串的连接问题
2009/08/20 Javascript
js控制div及网页相关属性的代码
2009/12/19 Javascript
Jquery提交表单 Form.js官方插件介绍
2012/03/01 Javascript
改进版通过Json对象实现深复制的方法
2012/10/24 Javascript
jQuery语法高亮插件支持各种程序源代码语法着色加亮
2013/04/27 Javascript
jquery简单的拖动效果实现原理及示例
2013/07/26 Javascript
js实现无缝滚动特效
2015/12/20 Javascript
Node.js环境下编写爬虫爬取维基百科内容的实例分享
2016/06/12 Javascript
基于JS实现二维码图片固定在右下角某处并跟随滚动条滚动
2017/02/08 Javascript
JavaScript实现打地鼠小游戏
2020/04/23 Javascript
不得不看之JavaScript构造函数及new运算符
2017/08/21 Javascript
JavaScript实现像雪花一样的Hexaflake分形
2020/07/07 Javascript
jQuery使用hide()、toggle()函数实现相机品牌展示隐藏功能
2021/01/29 jQuery
用python实现简单EXCEL数据统计的实例
2017/01/24 Python
深入理解Python中的内置常量
2017/05/20 Python
scrapy爬虫实例分享
2017/12/28 Python
Python中偏函数用法示例
2018/06/07 Python
Python拼接字符串的7种方法总结
2018/11/01 Python
使用Python轻松完成垃圾分类(基于图像识别)
2019/07/09 Python
HTML5和以前HTML4的区别整理
2013/10/20 HTML / CSS
Monnier Frères美国官网:法国知名奢侈品网站
2016/11/22 全球购物
企业车辆管理制度
2014/01/24 职场文书
校园学雷锋活动月总结
2014/03/09 职场文书
教师四风对照检查材料思想汇报
2014/09/17 职场文书
施工安全协议书范本
2014/09/26 职场文书
退休职工欢送会致辞
2015/08/01 职场文书
MySQL磁盘碎片整理实例演示
2022/04/03 MySQL
德劲DE1107指针试高灵敏度全波段收音机机评
2022/04/05 无线电
pandas中pd.groupby()的用法详解
2022/06/16 Python