怎么用Canvas压缩图片

互联网 18-1-11
这次给大家带怎么用Canvas压缩图片?用Canvas压缩图片 的注意事项有哪些,下面就是实战案例,一起来看一下。

一、本地图片输入

1. 获取本地文件

<!--HTML-->  <input type="file" id="choose-img" />
// JS  var chooseImg = document.getElementById("choose-img");  chooseImg.onchange = function(e){      var file = this.files[0];      // ……  (省略部分代码后续依次展示,下同)  };

很简单,就是通过type类型为file的按钮来获取本地文件。

2. 判断所获取的本地文件类型

<!--HTML-->  <div id="result"></div>
// JS  var result = document.getElementById("result");    // 用于显示图片输出结果,或者错误提示  if(/image/.test(file.type)){     // 判断文件类型是否为图片      // ……  }  else{      result.innerHTML = '<span style="color: red;">文件类型有误!</span>';  }

3. 将所获取的本地图片以base64格式输出

var img = new Image(),      // 创建图片对象,用于放置原始图片      reader = new FileReader();  reader.readAsDataURL(file);    // 以base64格式读取并存入FileReader对象的result属性中  reader.onload = function(){      img.src = this.result;   // 将图片base64字符串直接赋予Image对象的src中      document.body.insertBefore(img,chooseImg);   // 将输出的图片插入到文件按钮之前      img.onload = function(){          // ……      };  };

二、在Canvas画布中绘制图片

1. 创建画布

var canvas = document.createElement('canvas');  canvas.width = img.clientWidth;  canvas.height = img.clientHeight;  var context = canvas.getContext('2d');

注意:画布大小与所输入图片宽高相同。

2. 绘制图片

context.drawImage(img,0,0,canvas.width,canvas.height);

三、压缩图片并输出

<!--HTML-->  图片压缩比率 : <input id="rate" type="number" min="0" max="100" /> %  // JS  var chooseImg = document.getElementById("choose-img"),      result = document.getElementById("result");  chooseImg.onchange = function(e){      var file = this.files[0];      if(/image/.test(file.type)){          var img = new Image(),              reader = new FileReader();          reader.readAsDataURL(file);          reader.onload = function(){              img.src = this.result;              document.body.insertBefore(img,chooseImg);              img.onload = function(){                  var canvas = document.createElement('canvas');                  canvas.width = img.clientWidth;                  canvas.height = img.clientHeight;                  var context = canvas.getContext('2d');                  context.drawImage(img,0,0,canvas.width,canvas.height);                  var rate = document.getElementById("rate").value || 100;                  var imgUrl = canvas.toDataURL(file.type,rate/100);                  result.innerHTML = '压缩后:<img src="'+ imgUrl +'" />';                  result.style.display = 'block';                  img.style.display = 'none';              };          };      }      else{          result.innerHTML = '<span style="color: red;">文件类型有误!</span>';      }  };

经测试发现,通过Canvas压缩JPEG格式图片效果最佳,PNG压缩效果不明显,有时反而变得更大。

相信看了这些案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

相关阅读:

H5的块级标签汇总

H5的进阶段内联标签

怎样使用H5调用摄像头

以上就是怎么用Canvas压缩图片的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 压缩
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:h5怎样唤醒app

相关资讯