设为首页收藏本站

安徽论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 10406|回复: 0

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

[复制链接]

63

主题

513

回帖

968

积分

高级会员

Rank: 4

积分
968
发表于 2022-3-26 11:01:37 | 显示全部楼层 |阅读模式
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
前言

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

我本次的需求是多人视频中对某一视频某一刻的截图,展示视频直接用的原生video标签
1、首先获取video元素和创建canvas
  1. const video = document.getElementById('video');
  2. const canvas = document.createElement("canvas");
  3. const canvasCtx = canvas.getContext("2d")
复制代码
2、截图的像素大小及优化
devicePixelRatio 能够返回当前显示设备的物理像素分辨率与 CSS 像素分辨率的比率,能够更好还原真实的视频场景,具体参考官方
  1. const ratio = window.devicePixelRatio || 1;
  2. canvasCtx.scale(ratio, ratio);
复制代码
3、处理canvas画布
  1. // canvas大小与图片大小保持一致,截图没有多余
  2. canvas.width = video.offsetWidth * ratio;
  3. canvas.height = video.offsetHeight * ratio;
复制代码
4、生成canvas并转化成自己需要的格式,我这里就直接转成base64了
  1. canvasCtx.drawImage(video, 0, 0, canvas.width, canvas.height)
  2. const imgBase64 = canvas.toDataURL("image/png");
复制代码
到此这篇关于使用canvas对video视频某一刻截图的文章就介绍到这了,更多相关canvas视频截图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
                                                                                               
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表