如何输出HTML5画布作为图像?

时间:2012-01-08 19:42:53

标签: javascript html5

我已经在本教程中研究了如何在HTML5中使用canvas来创建剪贴蒙版。 http://www.benbarnett.net/2011/06/02/using-html5-canvas-for-image-masks/

我现在的问题是可以将画布保存为图像(包括蒙版效果)吗?

感谢

2 个答案:

答案 0 :(得分:6)

可以使用canvas.toDataURL()来获取PNG输出。

也可以在Chrome / Firefox上获得JPEG输出。下面是将HTML数据转换为HTML5 Blob的代码。

   /**
    * http://stackoverflow.com/questions/4998908/convert-data-uri-to-file-then-append-to-formdata/5100158
    *
    *
    */
    function dataURItoBlob(dataURI, callback) {
        // convert base64 to raw binary data held in a string
        // doesn't handle URLEncoded DataURIs

        var byteString;
        if (dataURI.split(',')[0].indexOf('base64') >= 0) {
            byteString = atob(dataURI.split(',')[1]);
        } else {
            byteString = unescape(dataURI.split(',')[1]);
        }

        // separate out the mime component
        var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];

        // write the bytes of the string to an ArrayBuffer
        var ab = new ArrayBuffer(byteString.length);
        var ia = new Uint8Array(ab);
        for (var i = 0; i < byteString.length; i++) {
            ia[i] = byteString.charCodeAt(i);
        }

        // write the ArrayBuffer to a blob, and you're done
        var BlobBuilder = window.WebKitBlobBuilder || window.MozBlobBuilder;
        var bb = new BlobBuilder();
        bb.append(ab);
        return bb.getBlob(mimeString);
    }

   function getAsJPEGBlob(canvas) {
        if(canvas.mozGetAsFile) {
            return canvas.mozGetAsFile("foo.jpg", "image/jpeg");
        } else {
            var data = canvas.toDataURL('image/jpeg', 0.7);
            var blob = dataURItoBlob(data);
            return blob;
        }
    }

答案 1 :(得分:0)

canvas.toDataURL();

function,可以为您提供Data URL,您可以将其放入图片代码中。从那里你可以保存它。

如果您希望自动将其保存到硬盘驱动器,则标准JavaScript无法实现