zoukankan      html  css  js  c++  java
  • js 图片压缩 转成base64

    HTML:

    <!doctype html>  
    <html>  
        <head>  
            <meta charset="UTF-8">  
            <meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />  
            <title>测试</title>  
            <link rel="stylesheet" href="./css/index.css" />  
            <link rel="stylesheet" href="./css/index_1.css" />  
            <script type="text/javascript" src="script/jquery.min.js"></script>  
            <script type="text/javascript" src="script/ys.js"></script>  
        </head>  
        <body>  
            <div class="free-upload">  
    H5页面            <p>  
                    上传您的约会照片,上传图片  
                </p>  
                <div class="free-upload-photo">  
                    <span id="photo_img"></span>  
                    <input type="file" id="photo" onchange="start_upload(this)"/>  
                </div>  
            </div>  
            <img src="" id="csimg" width="200" height="200"/>  
        </body>  
        <script>  
            function start_upload(obj){  
                 if(!isCanvasSupported){  
                    console.log("2222");  
                 }else{  
                    compress(event, function(base64Img){  
                        $("#csimg").attr("src",base64Img);  
                        console.log(base64Img);  
                        // 如需保存  或 把base64转成图片  ajax提交后台处理  
                        // 我这里采用ajax方式 自己封装的   
                        ajax('qnl_app/tes_ac_img',{'base64Img':base64Img},function(date){  
                            console.log(JSON.stringify(date));  
                        });  
                    });  
                 }  
            }  
              
        </script>  
    </html>  

    JS:

    //判断是否存在画布  
    function isCanvasSupported() {  
        var elem = document.createElement('canvas');  
        return !!(elem.getContext && elem.getContext('2d'));  
    }  
      
    //压缩方法  
    function compress(event, callback) {  
        if ( typeof (FileReader) === 'undefined') {  
            console.log("当前浏览器内核不支持base64图标压缩");  
            //调用上传方式  不压缩  
        } else {  
            try {  
                var file = event.currentTarget.files[0];  
                 if(!/image/w+/.test(file.type)){     
                        alert("请确保文件为图像类型");    
                        return false;    
                 }   
                var reader = new FileReader();  
                reader.onload = function (e) {  
                var image = $('<img/>');  
                image.load(function () {  
                console.log("开始压缩");  
                var square = 700;  
                var canvas = document.createElement('canvas');  
                canvas.width = square;  
                canvas.height = square;  
                var context = canvas.getContext('2d');  
                context.clearRect(0, 0, square, square);  
                var imageWidth;  
                var imageHeight;  
                var offsetX = 0;  
                var offsetY = 0;  
                if (this.width > this.height) {  
                  imageWidth = Math.round(square * this.width / this.height);  
                  imageHeight = square;  
                  offsetX = - Math.round((imageWidth - square) / 2);  
                } else {  
                  imageHeight = Math.round(square * this.height / this.width);  
                  imageWidth = square;  
                  offsetY = - Math.round((imageHeight - square) / 2);  
                }  
                context.drawImage(this, offsetX, offsetY, imageWidth, imageHeight);  
                var data = canvas.toDataURL('image/jpeg');  
                    //压缩完成执行回调  
                   callback(data);  
                });  
                image.attr('src', e.target.result);  
                };  
                reader.readAsDataURL(file);  
            } catch(e) {  
                console.log("压缩失败!");  
                //调用上传方式  不压缩  
            }  
        }  
    }  
  • 相关阅读:
    ubuntu18.04 复制或剪切某文件夹下的前x个文件到另一个文件夹下
    VOC2012数据集提取自己需要的类的图片和对应的xml标签
    python面试题
    vi命令使用
    缓冲(Buffer)和缓存(Cache)区别和联系
    cpu相关概念
    pycharm
    jmeter分布式部署
    LeetCode#67 Add Binary
    LeetCode#70 Climbing Stairs
  • 原文地址:https://www.cnblogs.com/shcolo/p/7214794.html
Copyright © 2011-2022 走看看