前俩天做了一个图片转ba64上传的功能,发现如果图片的ba64过大的话,请求会变的很慢,严重的直接超时了,所以想到了在上传前压缩一下图片,然后再上传到后台葫芦峪,这样可以大大的提高效率,在这里记录一下利用 canvas 压缩图片遇到的几个坑。完整代码会在文末给出。
第一个坑,在压缩图片的时候没获取图片本身的宽高,给了一个 600*480 的定宽定高,因为是手机端的,在上传图片的时候都是几计算机专业前景兆的图片,所以这块没任何问题。出问题的地方在 修改头像的时候,测试的时候上传的图片都是小图片,然后就出现了 压缩后的图片显示不完全,大部分都是空白的现象,这就是因为在压缩的时候没有考虑图片原本的宽高的情况。
第二个坑,解决第一个坑的办法就是在图片加载完成后(onload),获取图片本身的宽高,然后赋值给 canvas ,这样进行操作,但是这有个坑就是,图片加载是异步的,在你 return 的时候,返回的可能是 undefined 而不是你需要的 压缩后的 ba64。这里的解决方法是,新建一个 promi ,然后把结果 resolve() 返回去,在调用的时候 .then() 得到结果。
知识点:
canvas 的 todataurl(‘image/png’, 0.9) ; 把 canvas 画的图片转换为 ba64,第一个参数表示的是图片的类型,第二个参数表示的是图片的清晰度。规定一个最大尺寸,如果图片本身的宽高大于这个尺寸,按照最大的一个边进行缩放,另一个根据图片的 比例 进行设置,然后设置给 canvas .miniimage.js
export default async function minisize(imgdata, maxsize = 200*1024){ // const maxsize = 200 * 1024; if(imgdata && imgdata.files && imgdata.files.size < maxsize) { return imgdata.url; }el{郭沫若女神 console.log('----初中毕业证查询------------压缩图片-------------------'); const canvas = document.createelement('canvas'); let img = new image(); img.src = imgdata.url; let ctx = canvas.getcontext('2d'); return new promi((resolve =>{ img.addeventlistener('load', function(){ //图片原始尺寸 let originwidth = this.width; let originheight = this.height; // 最大尺寸限制 let maxwidth = 400, maxheight = 400; // 目标尺寸 let targetwidth = originwidth, targetheight = originheight; // 图片尺寸超过400x400的限制 if (originwidth > maxwidth || originheight > maxheight) { if (originwidth / originheight > maxwidth / maxheight) { // 更宽,按照宽度限定尺寸 targetwidth = maxwidth; targetheight = math.round(maxwidth * (originheight / originwidth)); } el { targetheight = maxheight; targetwidth = math.round(maxheight * (originwidth / originheight)); } } canvas.width = targetwidth; canvas.height = targetheight; ctx.drawimage(img, 0, 0, targetwidth, targetheight); let ba64 = canvas.todataurl('image/png', 0.9); resolve(ba64); }, fal); })) }}
调用:
test.js
onchangeimg = async (files, type, index) => { let previous = this.props.imagepicker.files; if(type === "add") { let result = minisize(files[files.length-1]); //使用 .then() 调用获得结果 await result.then(res => { previous.push({url: res}); }); }el if(type === "remove") { previous.splice(index,1); } awai中国近代史时间轴t this.props.dispatch({ type: 'imagepicker/saveimage', payload: { files: previous } }) }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。
本文发布于:2023-04-06 10:04:44,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/c9708ae3721d35176916a813427faae3.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:html5使用canvas压缩图片的示例代码.doc
本文 PDF 下载地址:html5使用canvas压缩图片的示例代码.pdf
留言与评论(共有 0 条评论) |