扣丁学堂HTML5培训简述如何使用canvas压缩图片

2019-04-04 10:51:07 1324浏览

图片压缩我们在工作或者是生活中会经常的用到,那么利用HTML5开发技术如何使用canvas压缩图片,对HTML5开发感兴趣或者是正想参加HTML5培训学习的读者们就来了解一下吧。


扣丁学堂HTML5培训简述如何使用canvas压缩图片


本篇文章以图片转base64上传的功能为例给读者们分享一下:


一个图片转base64上传的功能,如果图片的base64过大的话,请求会变的很慢,严重的直接超时了,所以需要在上传前压缩一下图片,然后再上传到后台,这样可以大大的提高效率,在这里记录一下分享canvas 压缩图片遇到的几个坑,完整代码会在文末给出。


第一个坑,在压缩图片的时候没获取图片本身的宽高,给了一个600*480 的定宽定高,因为是手机端的,在上传图片的时候都是几兆的图片,所以这块没任何问题。出问题的地方在修改头像的时候,测试的时候上传的图片都是小图片,然后就出现了压缩后的图片显示不完全,大部分都是空白的现象,这就是因为在压缩的时候没有考虑图片原本的宽高的情况。


第二个坑,解决第一个坑的办法就是在图片加载完成后(onload),获取图片本身的宽高,然后赋值给canvas ,这样进行操作,但是这有个坑就是,图片加载是异步的,在你 return的时候,返回的可能是undefined而不是你需要的压缩后的base64。这里的解决方法是,新建一个Promise ,然后把结果resolve() 返回去,在调用的时候.then() 得到结果。



知识点:


canvas的toDataURL('image/png', 0.9) ;把canvas 画的图片转换为base64,第一个参数表示的是图片的类型,第二个参数表示的是图片的清晰度。


规定一个最大尺寸,如果图片本身的宽高大于这个尺寸,按照最大的一个边进行缩放,另一个根据图片的 比例 进行设置,然后设置给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;
    }else{
      console.log('----------------压缩图片-------------------');
      const canvas = document.createElement('canvas');
      let img = new Image();
      img.src = imgData.url;
      let ctx = canvas.getContext('2d');
      return new Promise((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));
            } else {
              targetHeight = maxHeight;
              targetWidth = Math.round(maxHeight * (originWidth / originHeight));
            }
          }
          canvas.width = targetWidth;
          canvas.height = targetHeight;
          ctx.drawImage(img, 0, 0, targetWidth, targetHeight);
          let base64 = canvas.toDataURL('image/png', 0.9);
          resolve(base64);
        }, false);
      }))
    }
}


调用:


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});
      });
    }else if(type === "remove") {
        previous.splice(index,1);
    }
    await this.props.dispatch({
      type: 'imagePicker/saveImage',
      payload: {
        files: previous
      }
    })
  }


最后想要了解更多HTML5开发内容的小伙伴可以登录扣丁学堂官网咨询,扣丁学堂有专业老师制定的HTML5学习路线图辅助学员学习,此外还有与时俱进的HTML5视频教程供大家学习,想要学好HTML5开发技术的同学请加入扣丁学堂H5技术交流群:673883249。


【扫码进入HTML5VIP免费公开课】                         【扫码进入HTML5进阶VIP免费公开课】


【扫码进入HTML5前端开发VIP免费公开课】       【扫码进入前端H5架构师进阶VIP体验课】



查看更多关于“HTML5开发技术资讯”的相关文章>>




标签: HTML5培训 HTML5视频教程 HTML5学习视频 HTML5在线视频 HTML5培训班 前端H5架构师进阶 HTML5公开课

热门专区

暂无热门资讯

课程推荐

微信
微博
15311698296

全国免费咨询热线

邮箱:codingke@1000phone.com

官方群:148715490

北京千锋互联科技有限公司版权所有   北京市海淀区宝盛北里西区28号中关村智诚科创大厦4层
京ICP备12003911号-6   Copyright © 2013 - 2019

京公网安备 11010802030908号