百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>html5教程> html5运用canvas紧缩图片的示例代码-
分享文章到:

html5运用canvas紧缩图片的示例代码-

发布时间:09/01 来源:未知 浏览: 关键词:
这篇文章主要介绍了html5运用canvas紧缩图片的示例代码的相干材料,小编觉得挺不错的,此刻分享给大家,也给大家做个参照 。一起追随小编过来看看吧 这篇文章主要介绍了html5运用canvas紧缩图片的示例代码的相干材料,小编觉得挺不错的,此刻分享给大家,也给大家做个参照 。

前俩天做了一个图片转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运用canvas紧缩图片的示例代码的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板