|
|
前言5 [8 a4 J3 s5 t9 A
& r E# P0 u" u( r! b' J& {本次使用的是canvas.drawImage()实现截图功能, 关于api支持的dom元素、基本参数,可点击查询下面连接 CanvasRenderingContext2D.drawImage(). L# P3 I8 C" r$ l6 o
处理过程
' H# @3 ]$ t$ Y; q6 O2 L- Q$ f- J+ m" S9 J1 Q) k
我本次的需求是多人视频中对某一视频某一刻的截图,展示视频直接用的原生video标签
" y4 R4 z( n* }8 I1 ~4 |1、首先获取video元素和创建canvas- const video = document.getElementById('video');const canvas = document.createElement("canvas");const canvasCtx = canvas.getContext("2d")
复制代码 2、截图的像素大小及优化/ }, Z8 X# W6 ~9 b+ W6 ?, K+ V
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了( D9 ?) u t5 j2 B
- canvasCtx.drawImage(video, 0, 0, canvas.width, canvas.height)const imgBase64 = canvas.toDataURL("image/png");
复制代码 到此这篇关于使用canvas对video视频某一刻截图的文章就介绍到这了,更多相关canvas视频截图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
& _. D2 `% i5 R. I6 b' {# X; X( Q$ E( Y4 S
来源:http://www.jb51.net/html5/790425.html
$ L& a: w8 h% z& V免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
|