JavaScript 图片URL转DataURL,DataURL转Blob

问题描述

封装WebUploader,想实现信息修改的功能,就是一条记录可能有多个图片字段,每个字段又有可能有多张图片。当修改记录的时候,需要把图片字段中已经有的图片显示出来,实现旋转角度的功能,最重要的是实现删除功能。

实现思路:

  1. 针对一个图片字段,服务器返回多个已经上传的图片

  2. 遍历返回的多个地址,请求每个图片的字节流数据

  3. 将字节流数据转换为DataUrl,再将DataUrl转成Blob,这个Blob对象就是webuploader#addFile方法可以接受的对象了

实现代码(来自网络)

根据图片URL直接获取到DataUrl

function convertImgToDataURLviaCanvas(url, callback, outputFormat){
    var img = new Image();
    img.crossOrigin = 'Anonymous';
    img.onload = function(){
        var canvas = document.createElement('CANVAS');
        var ctx = canvas.getContext('2d');
        var dataURL;
        canvas.height = this.height;
        canvas.width = this.width;
        ctx.drawImage(this, 0, 0);
        dataURL = canvas.toDataURL(outputFormat);
        callback(dataURL);
        canvas = null; 
    };
    img.src = url;
}

function convertFileToDataURLviaFileReader(url, callback){
    var xhr = new XMLHttpRequest();
    xhr.responseType = 'blob';
    xhr.onload = function() {
        var reader  = new FileReader();
        reader.onloadend = function () {
            callback(reader.result);
        }
        reader.readAsDataURL(xhr.response);
    };
    xhr.open('GET', url);
    xhr.send();
}

上面两个方法来自 http://jsfiddle.net/handtrix/YvQ5y/

DataURL转Blob

function dataURLtoBlob(dataurl) {
            var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
            bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
            while(n--){
              u8arr[n] = bstr.charCodeAt(n);
            }
          return new Blob([u8arr], {type:mime});
        } 

上面的方法来自http://blog.csdn.net/cuixiping/article/details/45932793

你可能感兴趣的:(Javascrpit)