html5使用canvas压缩图片的示例代码


Posted in HTML / CSS onSeptember 11, 2018

前俩天做了一个图片转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
      }
    })
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
详解CSS3伸缩布局盒模型Flex布局
Aug 20 HTML / CSS
css3背景图片透明叠加属性cross-fade简介及用法实例
Jan 08 HTML / CSS
css3一款3D字体带阴影效果的实现步骤
Mar 20 HTML / CSS
canvas之万花筒效果的简单实现(推荐)
Aug 16 HTML / CSS
CSS3标注引用的出处和来源的方法
Feb 25 HTML / CSS
CSS3 rgb and rgba(透明色)的使用详解
Sep 25 HTML / CSS
用HTML5实现网站在windows8中贴靠的方法
Apr 21 HTML / CSS
html5的websockets全双工通信详解学习示例
Feb 26 HTML / CSS
HTML5 CSS3实现一个精美VCD包装盒个性幻灯片案例
Jun 16 HTML / CSS
HTML5新增的表单元素和属性实例解析
Jul 07 HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
Feb 03 HTML / CSS
css filter和getUserMedia的联合使用
Feb 24 HTML / CSS
canvas像素点操作之视频绿幕抠图
Sep 11 #HTML / CSS
HTML5中使用json对象的实例代码
Sep 10 #HTML / CSS
html5 figure和figcaption的使用方法
Sep 10 #HTML / CSS
用canvas画心电图的示例代码
Sep 10 #HTML / CSS
Html5 canvas实现粒子时钟的示例代码
Sep 06 #HTML / CSS
canvas离屏技术与放大镜实现代码示例
Aug 31 #HTML / CSS
使用PDF.JS插件在HTML中预览PDF文件的方法
Aug 29 #HTML / CSS
You might like
探讨方法的重写(覆载)详解
2013/06/08 PHP
php5.3 不支持 session_register() 此函数已启用的解决方法
2013/11/12 PHP
PHP判断来访是搜索引擎蜘蛛还是普通用户的代码小结
2015/09/14 PHP
详解PHP用substr函数截取字符串中的某部分
2016/12/03 PHP
PHP实现浏览器格式化显示XML的方法示例
2019/01/22 PHP
PHP封装XML和JSON格式数据接口操作示例
2019/03/06 PHP
网页javascript精华代码集
2007/01/24 Javascript
基于prototype扩展的JavaScript常用函数库
2010/11/30 Javascript
javaScript同意等待代码实现心得
2011/01/01 Javascript
jquery中的工具使用方法$.isFunction, $.isArray(), $.isWindow()
2015/08/09 Javascript
js带缩略图的图片轮播效果代码分享
2015/09/14 Javascript
jQuery获得字体颜色16位码的方法
2016/02/20 Javascript
JavaScript Math 对象常用方法总结
2016/04/28 Javascript
JS Canvas定时器模拟动态加载动画
2016/09/17 Javascript
JQuery中解决重复动画的方法
2016/10/17 Javascript
js自制图片放大镜功能
2017/01/24 Javascript
jQuery实现的事件绑定功能基本示例
2017/10/11 jQuery
使用vue-cli编写vue插件的方法
2018/02/26 Javascript
JavaScript 复制对象与Object.assign方法无法实现深复制
2018/11/02 Javascript
利用jsonp解决js读取本地json跨域的问题
2018/12/11 Javascript
JavaScript使用小插件实现倒计时的方法讲解
2019/03/11 Javascript
Python中MySQL数据迁移到MongoDB脚本的方法
2016/04/28 Python
深入理解NumPy简明教程---数组3(组合)
2016/12/17 Python
基于Python os模块常用命令介绍
2017/11/03 Python
轻松实现TensorFlow微信跳一跳的AI
2018/01/05 Python
Python深拷贝与浅拷贝用法实例分析
2019/05/05 Python
python 实现查找文件并输出满足某一条件的数据项方法
2019/06/12 Python
用python3 urllib破解有道翻译反爬虫机制详解
2019/08/14 Python
Django 允许局域网中的机器访问你的主机操作
2020/05/13 Python
基于python实现坦克大战游戏
2020/10/27 Python
HTML5通用接口详解
2016/06/12 HTML / CSS
中国电视购物:快乐购
2017/02/04 全球购物
信息管理与信息系统专业求职信
2014/06/21 职场文书
完整版商业计划书
2014/09/15 职场文书
CSS实现九宫格布局(自适应)的示例代码
2022/02/12 HTML / CSS
宝塔更新Python及Flask项目的部署
2022/04/11 Python