前端画布canvas.toDataURL()导出时为空解决办法
·
最近项目中的是个视频缩略图好多都不能用了,鄙人调试了一天也没发现什么问题,然后就发现是谷歌浏览器升级的原因,77.0版本以前的只要加了跨域的代码就可以支持导出,但是77.0就不可以,原来代码如下
function getVideoFirstFrame(src, img, width, height) {
var video = document.createElement('video');
video.crossOrigin = "anonymous";
video.addEventListener('loadeddata', function () {
var canvas = document.createElement("canvas"); // 创建一个画布
canvas.width = width;
canvas.height = height;
canvas.getContext('2d').drawImage(video, 0, 0, width, height); // getContext:设置画布环境;drawImage:画画
img.src = canvas.toDataURL("image/png"); // 获取图片的url
});
video.src = src;
}
谷歌浏览器升级后canvas.toDataURL()方法返回值都是一样的,后来偶然间发现升级后第一帧默认是空白的,只要加一个
video.currentTime=1;就可以
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐


所有评论(0)