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 {        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压缩图片的示例代码的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2908992.html

(0)
上一篇 2025年3月11日 03:18:19
下一篇 2025年2月22日 22:50:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • canvas像素点操作之视频绿幕抠图

    这篇文章主要介绍了canvas像素点操作之视频绿幕抠图的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧  本文介绍了canvas像素点操作之视频绿幕抠图,分享给大家,具体如下: 用法: context.…

    2025年3月11日 编程技术
    200
  • html5 figure和figcaption的使用方法

    这篇文章主要介绍了html5 figure和figcaption的使用方法的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 figure标签和figcaption标签是html5新增的语义化标签。 figure标…

    2025年3月11日
    200
  • 用canvas画心电图的示例代码

    这篇文章主要介绍了用canvas画心电图的示例代码的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 本文介绍了用canvas画心电图的示例代码,分享给大家,具体如下: 效果图: 思路: 1.模拟点(如果你有真实的…

    2025年3月11日
    200
  • Html5 canvas实现粒子时钟的示例代码

    这篇文章主要介绍了html5 canvas实现粒子时钟的示例代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 我们先看看粒子时钟的效果,如下: 下面我们将通过canvas和js实现, 首先要创建一个html文件并添加一…

    2025年3月11日
    200
  • canvas离屏技术与放大镜实现代码示例

    这篇文章主要介绍了canvas离屏技术与放大镜实现代码示例的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 利用 canvas 除了可以实现滤镜,还可以利用 离屏技术 放大镜功能。 为了方便讲解,本文分为 2 个…

    2025年3月11日
    200
  • Html5 video 上传预览图片视频,设置、预览视频某秒的海报帧

    这篇文章主要介绍了html5 video 上传预览图片视频,设置、预览视频某秒的海报帧的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 本文介绍了Html5 video 上传预览图片视频,设置、预览视频某秒的海报…

    2025年3月11日
    200
  • HTML5 input新增type属性color颜色拾取器的实例代码

    type 属性规定 input 元素的类型。本文较详细的给大家介绍了html5 input新增type属性color颜色拾取器的实例代码,感兴趣的朋友跟随脚本之家小编一起看看吧 定义和用法 type 属性规定 input 元素的类型。 注释…

    2025年3月11日
    200
  • html5中audio支持音频格式的解决方法

    html5 audio标签能够支持wav, mp3, ogg, acc, webm等格式,但有个很重要的音乐文件格式midi(扩展名mid)却在各大浏览器中都没有内置的支持。不是所有的浏览器都支持mp3 ogg之类的,每个浏览器因为版权的问…

    编程技术 2025年3月11日
    200
  • canvas学习和滤镜实现代码

    这篇文章主要介绍了canvas学习和滤镜实现代码,利用 canvas,前端人员可以很轻松地、进行图像处理,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在这个数码产品泛滥的时代里,拍照已经成为生活不可或缺的一部分,不管是…

    2025年3月11日
    200
  • 详解html5 postMessage解决跨域通信的问题

    这篇文章主要介绍了详解html5 postmessage解决跨域通信的问题的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 本文介绍了详解html5 postMessage解决跨域通信的问题,分享给大家,具体如下…

    2025年3月11日
    200

发表回复

登录后才能评论