经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
使用Canvas压缩图片
来源:cnblogs  作者:伤心小王子  时间:2019/7/24 8:51:42  对本文有异议

讲干货,不啰嗦,当涉及对图片有质量压缩要求的时候,可以使用Canvas实现图片压缩。

步骤:

1.获取img元素,既要压缩的图片

2.创建canvas对象

3.使用canvas的drawImage方法绘制图片

4.通过canvas toDataURl方法获取图像base64编码,设置quality参数,实现压缩

参考示例:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Canvas图片压缩测试</title>
  6. <script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
  7. </head>
  8. <body>
  9. <div class="container">
  10. <h2>压缩前图片</h2>
  11. <img id="originalImg" src="test.jpg">
  12. <h2>压缩后图片</h2>
  13. <img id="compressedImg" src="">
  14. </div>
  15. <script>
  16. $(document).ready(function(){
  17. compressImg(300,0.2)
  18. });
  19. function compressImg(width,quality ) {
  20. // 图片压缩方法,接受2个参数
  21. // width:压缩后图片宽度,高度按比例计算
  22. // quality:压缩比例参数,范围0-1
  23. var img=$("#originalImg")[0];//获取图像元素
  24. var height=width/img.width*img.height;
  25. //生成canvas
  26. var canvas = document.createElement('canvas');
  27. var ctx = canvas.getContext('2d');
  28. canvas.width = width;
  29. canvas.height = height;
  30. //通过canvas drawImage方法绘制图片
  31. ctx.drawImage(img,0,0,width,height);//后四个为位置参数,左上角x,y坐标,右下角x,y坐标
  32. //通过canvas toDataURl方法获取图像base64编码,quality为压缩质量参数,值越小图像越模糊
  33. var base64 = canvas.toDataURL('image/jpeg', quality);
  34. //测试展示
  35. $("#compressedImg").attr("src",base64)
  36. //获取到base64后可做进一步处理,如传到后端并储存
  37. }
  38. </script>
  39. <style>
  40. #originalImg{
  41. width: 300px;
  42. }
  43. </style>
  44. </body>
  45. </html>

压缩前后图片对比:

  生成的base64码:

  能力有限,水平一般,错误之处,欢迎指正,感谢关注和评论!

原文链接:http://www.cnblogs.com/wwlstc/p/11233046.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号