使用JavaScript来膨胀blob?

我正在使用websocket以blob格式发送Jpeg图像.我已经压缩(gzipped)blob但我无法找到使用JavaScript解压缩它的方法.有谁知道怎么样?

这是我用来读取blob然后将其转换为base64字符串的代码

var r = new FileReader();

r.onload = function(){
    draw(btoa(r.result));
};
r.readAsBinaryString(e.data);

draw()函数基本上使用base64字符串将图像绘制到HTML5画布上.

我发现this library膨胀字符串,但它不支持blob. (据我所知/已经测试过)如果有人知道某种方式,我会赞同它. :) 谢谢!

最佳答案
我为我的particle system editor做了一个非常类似的事情,它支持阅读Cocos2D plist文件.在plist文件中是纹理数据,这是一个用gzip压缩然后转换为base64的png.我是这样做的:

var input = 'byu9g1RZpINUpVtoKoiKIqJYoris...'; // really long string

// from base64 to ascii binary string
var decodedAsstring = atob(input);

// ascii string to bytes in gzipped format
var data = this._binaryStringToArray(decodedAsstring);

// raw,uncompressed,binary image data into an array using gzip.js
var uncompressed = require('gzip-js').unzip(data);

// Now take the raw uncompressed png and convert it
// back to base64 to use it as a data url
var asstring = this._arrayToBinaryString(uncompressed);
var encodedForDataUrl = btoa(asstring);

var img = new Image();
img.src = encodedForDataUrl;

我正在使用gzip.js进行繁重的工作.你可以在here中看到所有这些,你可以得到一些plist加载到它here.BoilingFoam.plist将工作,只需在“导入/导出”部分加载它.

在上面的代码中我调用了两个方法,它们是:

 _binaryStringToArray: function(binaryString) {
        var data = [];

        for (var i = 0; i < binaryString.length; ++i) {
            data[i] = binaryString.charCodeAt(i);
        }

        return data;
    },_arrayToBinaryString: function(array) {
        var str = '';
        for (var i = 0; i < array.length; ++i) {
            str += String.fromCharCode(array[i]);
        }
        return str;
    },

整个shebang是here

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...