当前位置 博文首页 > 使用canvas对video视频某一刻截图功能

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

    作者:佚名 时间:2021-09-18 18:04

    前言

    本次使用的是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");
    jsjswy
    下一篇:没有了