ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

html与js实现视频截图

2022-06-25 23:34:04  阅读:167  来源: 互联网

标签:API 截图 dataURL canvas js html Blob https var


实现效果

先看看效果,而且点击图片即可查看demo

实现思路

1、分别获得远程mp4、本地摄像头、本地mp4上传文件预览,即准备好vedio节点。

如下代码:

<video id="video" width="320" height="auto" controls preload="auto">
    <source id="videoSource" src="mov_bbb.mp4" type="video/mp4">
    您的浏览器不支持Video标签。
</video>
 

2、向已有的或动态建立的 canvas 画布上绘制图片,代码如下:

ctx.drawImage(video, 0, 0, video.offsetWidth, video.offsetHeight);

具体用法请参考: https://www.w3school.com.cn/html5/canvas_drawimage.asp

3、canvas 转换为 dataURL,用来展示截图。

4、dataURL 转换为 Blob 对象,构造 FormData 对象,Ajax(或 fetch 和 axios)提交图片文件到服务器。

或者,在第3步,把 Canvas 转换为 Blob 对象,使用 URL.createObjectURL(blob) 来展示图片,在第4步就省去了“ dataURL 转换为 Blob 对象 ”操作。

参考文章

  1. https://www.zhangxinxu.com/wordpress/2013/10/understand-domstring-document-formdata-blob-file-arraybuffer/
  2. https://www.w3school.com.cn/tags/html_ref_audio_video_dom.asp
  3. https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLCanvasElement/toDataURL
  4. https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLCanvasElement/toBlob
  5. https://developer.mozilla.org/zh-CN/docs/Web/API/File_API/Using_files_from_web_applications
  6. https://developer.mozilla.org/zh-CN/docs/Web/API/MediaDevices/getUserMedia

附录:DataURL、Blob、File、Image之间的关系与js转换

1、canvas转dataURL

function canvasToDataURL(canvas, format, quality) {
    return canvas.toDataURL(format||'image/jpeg', quality||1.0);
}

2、dataURL转image

function dataURLToImage(dataurl){
    var img = new Image();
    img.src = d;
    return img;
}

3、 canvas2.toBlob转image

canvas.toBlob(function(blob){
    var url = URL.createObjectURL(blob);
    image.src = url;
    image2.onload = function(){
        URL.revokeObjectURL(url);
    };
});

4、dataURL转Blob对象

function dataURLToBlob (dataurl){
    var arr = dataurl.split(',');
    var mime = arr[0].match(/:(.*?);/)[1];
    var bstr = atob(arr[1]);
    var n = bstr.length;
    var u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], {type:mime});
}
   

标签:API,截图,dataURL,canvas,js,html,Blob,https,var
来源: https://www.cnblogs.com/xusx2014/p/16412709.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有