美文网首页
前端使用canvas实现图片压缩

前端使用canvas实现图片压缩

作者: QRFF | 来源:发表于2018-06-29 10:22 被阅读0次

代码来源于廖雪峰博客,是最实用的,也是最简洁的,但有个问题就是图片过小,‘压缩’后会更大,这个区间大概是1.5M以内,所以超过1.5M才进行此canvas压缩

<input id="file" type="file">
JS代码:
var eleFile = document.querySelector('#file');

// 压缩图片需要的一些元素和对象
var reader = new FileReader(), img = new Image();

// 选择的文件对象
var file = null;

// 缩放图片需要的canvas
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');

// base64地址图片加载完毕后
img.onload = function () {
    // 图片原始尺寸
    var originWidth = this.width;
    var originHeight = this.height;
    // 最大尺寸限制
    var maxWidth = 400, maxHeight = 400;
    // 目标尺寸
    var 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对图片进行缩放
    canvas.width = targetWidth;
    canvas.height = targetHeight;
    // 清除画布
    context.clearRect(0, 0, targetWidth, targetHeight);
    // 图片压缩
    context.drawImage(img, 0, 0, targetWidth, targetHeight);
    // canvas转为blob并上传
    canvas.toBlob(function (blob) {
        // 图片ajax上传
        var xhr = new XMLHttpRequest();
        // 文件上传成功
        xhr.onreadystatechange = function() {
            if (xhr.status == 200) {
                // xhr.responseText就是返回的数据
            }
        };
        // 开始上传
        xhr.open("POST", 'upload.php', true);
        xhr.send(blob);    
    }, file.type || 'image/png');
};

// 文件base64化,以便获知图片原始尺寸
reader.onload = function(e) {
    img.src = e.target.result;
};
eleFile.addEventListener('change', function (event) {
    file = event.target.files[0];
    // 选择的文件是图片
    if (file.type.indexOf("image") == 0) {
        reader.readAsDataURL(file);    
    }
});

相关文章

  • 前端使用canvas实现图片压缩

    代码来源于廖雪峰博客,是最实用的,也是最简洁的,但有个问题就是图片过小,‘压缩’后会更大,这个区间大概是1.5M以...

  • 前端使用canvas对图片进行压缩

    纯前端对图片压缩 纯前端因为可以调用FileReader和canvas接口,在图片压缩方面非常便捷.思路就是获取图...

  • 前端使用Canvas进行图片压缩

    文章已迁移至http://www.liyajie.net/posts/2018/11/07/5be2e3bba62...

  • 21天习惯养成打卡-day1

    遇到的问题 前端进行图片压缩 bootstrap框架表单的使用 解决方法 张鑫旭博客上的解决方案前端实现图片压缩上...

  • 前端图片压缩Canvas

    ?‍?图片压缩Canvas #关于如何实现压缩 查阅MDN找到的是这个API: HTMLCanvasElement...

  • 前端实现图片裁剪和压缩

    前端实现图片的裁剪和压缩1、压缩图片drawImage,压缩图片长宽或者质量参数来实现压缩 2、图片base64转...

  • 移动端添加图片裁剪的坑

    本文关键:阻止冒泡、canvas压缩、canvas裁剪、生成黑色图片。 最近项目需要在添加图片时实现裁剪功能,虽然...

  • h5上传图片压缩

    涉及知识点 uniapp项目h5,涉及到前端图片压缩上传 uni.chooseImage() canvas压缩 参...

  • canvas实现图片压缩

    为什么要实现图片压缩? 在当前各大手机厂商比赛摄像头大战的时候,带来的就是一张随随便便的照片就能达到10M-100...

  • html2canvas And FileSaver保存图片到本地

    最近做项目为了解决把html保存一个图片,使用了html2canvas前端插件实现。 html2canvas Gi...

网友评论

      本文标题:前端使用canvas实现图片压缩

      本文链接:https://www.haomeiwen.com/subject/zeereftx.html