2010-09-08 39 views
5

是否可以在Adobe AIR中使用canvas.toDataURL()如何使用canvas.toDataURL()在Adobe AIR中獲取圖像的base64?

當我嘗試,我得到以下錯誤:

Error: SECURITY_ERR: DOM Exception 18

+0

解釋,請,你想通過這算什麼?也許最好把這個畫布放在其他容器中,你可以鏈接到其他容器中? – Eugene 2010-09-10 10:50:59

+0

加載圖像,剪切圖像的一部分,然後將圖像從畫布保存到文件,數據庫或服務器 – kefi 2010-09-10 16:40:27

+1

好吧,我發現爲什麼我得到SECURITY_ERR http://www.whatwg.org/specs/web- apps/current-work/multipage/the-canvas-element.html#security-with-canvas-elements有沒有一種方法可以在將圖像發送到使用JS的JS服務器或JS的某些sfw庫之前在本地調整圖像大小? – kefi 2010-09-10 20:02:02

回答

4

的Adobe AIR強制在畫布API中使用的圖像相同的起源。一旦您在畫布中使用了另一個域中的內容,則無法從中取回像素數據。但是,您可以使用Loader類來獲取像素數據,並將其轉換爲畫布ImageData。

例如:

function getDataURL(url, callback) { 
    var loader = new air.Loader(); 
    loader.contentLoaderInfo.addEventListener(air.Event.COMPLETE, function(event) { 
    var bitmapData = loader.content.bitmapData; 

    var canvas = document.createElement('canvas'); 
    canvas.width = bitmapData.width; 
    canvas.height = bitmapData.height; 
    var context = canvas.getContext('2d'); 
    var imageData = context.createImageData(canvas.width, canvas.height); 

    var dst = imageData.data; 
    var src = bitmapData.getPixels(bitmapData.rect); 
    src.position = 0; 

    var i = 0; 
    while (i < dst.length) { 
     var alpha = src.readUnsignedByte(); 
     dst[i++] = src.readUnsignedByte(); 
     dst[i++] = src.readUnsignedByte(); 
     dst[i++] = src.readUnsignedByte(); 
     dst[i++] = alpha; 
    } 

    context.putImageData(imageData, 0, 0); 
    callback(canvas.toDataURL()); 
    }); 
    loader.load(new air.URLRequest(url)); 
} 

window.addEventListener('load', function() { 
    getDataURL('http://www.google.com/images/logo.gif', function(dataURL) { 
    air.trace(dataURL); 
    }); 
}, false); 
+0

我試過這段代碼,我得到一個TypeError:未定義的值不允許函數調用。 ?? – user899641 2012-04-10 21:54:33

+0

@ user899641這是由於'trace'而不是'air.trace' - 我編輯了答案。 – 2013-07-09 23:17:39

相關問題