使用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的resize属性使用初探
Sep 27 HTML / CSS
CSS3色彩模式有哪些?CSS3 HSL色彩模式的定义
Apr 26 HTML / CSS
详解css3中 text-fill-color属性
Jul 08 HTML / CSS
CSS3为背景图设置遮罩并解决遮罩样式继承问题
Jun 22 HTML / CSS
使用CSS3实现字体颜色渐变的实现
Aug 10 HTML / CSS
Html5+JS实现手机摇一摇功能
Apr 24 HTML / CSS
HTML5实现移动端复制功能
Apr 19 HTML / CSS
详解Canvas 跨域脱坑实践
Nov 07 HTML / CSS
浅析HTML5中的download属性使用
Mar 13 HTML / CSS
移动端html5判断是否滚动到底部并且下拉加载
Nov 19 HTML / CSS
AmazeUI导航的示例代码
Aug 14 HTML / CSS
css让页脚保持在底部位置的四种方案
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和C#可共用的可逆加密算法详解
2015/10/26 PHP
php实现的二叉树遍历算法示例
2017/06/15 PHP
自写的利用PDO对mysql数据库增删改查操作类
2018/02/19 PHP
layui数据表格自定义每页条数limit设置
2019/10/26 PHP
Gird组件 Part-3:范例RSSFeed Viewer
2007/03/10 Javascript
JS添加删除一组文本框并对输入信息加以验证判断其正确性
2013/04/11 Javascript
form表单action提交的js部分与html部分
2014/01/07 Javascript
javascript操作数组详解
2014/12/17 Javascript
js图片模糊切换显示特效的方法
2015/02/17 Javascript
详解微信小程序开发之城市选择器 城市切换
2017/01/17 Javascript
AngularJS读取JSON及XML文件的方法示例
2017/05/25 Javascript
十大 Node.js 的 Web 框架(快速提升工作效率)
2017/06/30 Javascript
详解如何优雅地在React项目中使用Redux
2017/12/28 Javascript
vuex直接赋值的三种方法总结
2018/09/16 Javascript
vue 利用路由守卫判断是否登录的方法
2018/09/29 Javascript
解决layer弹出层的内容页点击按钮跳转到新的页面问题
2019/09/14 Javascript
详解vue高级特性
2020/06/09 Javascript
浅谈Vue使用Cascader级联选择器数据回显中的坑
2020/10/31 Javascript
python使用socket进行简单网络连接的方法
2015/04/29 Python
Python使用cookielib模块操作cookie的实例教程
2016/07/12 Python
Python3实现的Mysql数据库操作封装类
2018/06/06 Python
解决vscode python print 输出窗口中文乱码的问题
2018/12/03 Python
pyqt5 实现多窗口跳转的方法
2019/06/19 Python
使用Pycharm分段执行代码
2020/04/15 Python
Linux安装Python3如何和系统自带的Python2并存
2020/07/23 Python
tensorflow与numpy的版本兼容性问题的解决
2021/01/08 Python
英国最大的婴儿监视器网上商店:Baby Monitors Direct
2018/04/24 全球购物
英国发展最快的在线超市之一:Click Marketplace
2021/02/15 全球购物
J2EE模式面试题
2016/10/11 面试题
五年级语文教学反思
2014/01/30 职场文书
小学中秋节活动方案
2014/02/06 职场文书
村庄绿化方案
2014/05/07 职场文书
社会体育专业大学生职业生涯规划书
2014/09/17 职场文书
刘胡兰观后感
2015/06/16 职场文书
导游词之山东红叶谷
2019/10/31 职场文书
MySQL root密码的重置方法
2021/04/21 MySQL