当前位置: 代码网 > it编程>网页制作>html5 > 使用canvas对video视频某一刻截图功能

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

2021年09月16日 html5 我要评论
使用canvas对video视频某一刻截图功能我本次的需求是多人视频中对某一视频某一刻的截图,展示视频直接用的原生video标签,今天通过使用canvas对video视频某一刻截图功能,感兴趣的朋友跟随小编一起看看吧... 21-09-16

前言

本次使用的是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视频截图内容请搜索代码网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com