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教程(3):border-color网页边框色彩
Apr 02 HTML / CSS
css3选择器基本介绍
Dec 15 HTML / CSS
css3 矩阵的使用详解
Mar 20 HTML / CSS
video结合canvas实现视频在线截图功能
Jun 25 HTML / CSS
HTML5之多线程(Web Worker)
Jan 02 HTML / CSS
利用html5 canvas破解简单验证码及getImageData接口应用
Jan 25 HTML / CSS
有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题
Jul 19 HTML / CSS
html5模拟平抛运动(模拟小球平抛运动过程)
Jul 25 HTML / CSS
HTML5中新标签和常用标签详解
Mar 07 HTML / CSS
iframe在移动端的缩放的示例代码
Oct 12 HTML / CSS
HTML5逐步分析实现拖放功能的方法
Sep 30 HTML / CSS
Li list-style-image 图片垂直居中实现方法
May 21 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
php cookie的操作实现代码(登录)
2010/12/29 PHP
php在服务器执行exec命令失败的解决方法
2012/03/03 PHP
PHP中文乱码解决方案
2015/03/05 PHP
php压缩和解压缩字符串的方法
2015/03/14 PHP
使用PHP开发留言板功能
2019/11/19 PHP
Firefox 无法获取cssRules 的解决办法
2006/10/11 Javascript
jQuery 使用手册(四)
2009/09/23 Javascript
js setTimeout 参数传递使用介绍
2013/08/13 Javascript
jquery实现标签上移、下移、置顶
2015/04/26 Javascript
Javascript 调用 ActionScript 的简单方法
2016/09/22 Javascript
jQuery autoComplete插件两种使用方式及动态改变参数值的方法详解
2016/10/24 Javascript
JavaScript实现的原生态Tab标签页功能【兼容IE6】
2017/09/18 Javascript
JavaScript简单实现关键字文本搜索高亮显示功能示例
2018/07/25 Javascript
vue自定义全局共用函数详解
2018/09/18 Javascript
Angular value与ngValue区别详解
2019/11/27 Javascript
Vue 中使用 typescript的方法详解
2020/02/17 Javascript
使用JavaScript获取Django模板指定键值数据
2020/05/27 Javascript
[02:41]DOTA2亚洲邀请赛小组赛第三日 赛事回顾
2015/02/01 DOTA
用Python编写一个国际象棋AI程序
2014/11/28 Python
详解python调用cmd命令三种方法
2019/07/08 Python
Python实现的企业粉丝抽奖功能示例
2019/07/26 Python
Python Django 添加首页尾页上一页下一页代码实例
2019/08/21 Python
Django之form组件自动校验数据实现
2020/01/14 Python
python对一个数向上取整的实例方法
2020/06/18 Python
python实现按日期归档文件
2021/01/30 Python
AmazeUI 面板的实现示例
2020/08/17 HTML / CSS
THE OUTNET英国官网:国际设计师品牌折扣网站
2016/08/14 全球购物
为智能设备设计个性化保护套网站:caseable
2017/01/05 全球购物
UGG澳洲官网:UGG Australia
2018/04/26 全球购物
世界各地的旅游、观光和活动:Isango!
2019/10/29 全球购物
采购主管的岗位职责
2013/12/17 职场文书
学校师德师风整改措施
2014/10/27 职场文书
单位推荐信范文
2015/03/27 职场文书
首席执行官观后感
2015/06/03 职场文书
Python实现查询剪贴板自动匹配信息的思路详解
2021/07/09 Python
5道关于python基础 while循环练习题
2021/11/27 Python