2012-06-04 87 views
-1

編輯將圖像轉換服務器端CanvasPixelArray

,所以它看起來像我有一個形象在某種程度上轉化爲

https://developer.mozilla.org/en/DOM/CanvasPixelArray 服務器端

我目前的嘗試已經爲*

傳遞來自服務器的base64編碼圖像...然後將其轉換爲二進制,並使用atob()

但後來我被卡住試圖得出這樣到畫布上,而不必像做

var i = new Image(); 
i.onload = function(){.....} 
i.src = "base64 string" 

所以更加籠統的說法

我試圖繞過創建圖片以任何方式顯示新圖像

+0

爲什麼?如果您不想顯示該圖像,則不顯示。 –

+0

我將在畫布上繪製它。 – samccone

+1

使用圖像作爲解碼器(和內存緩衝區)是正確的方法。 –

回答

0

使用html5你可以這樣做:

<script> 
window.onload = function() 
{ 
var img = new Image(); 
img.src = ""; 
document.body.appendChild(img); 
}; 
</script> 

這裏是一個工作示例:http://jsfiddle.net/4ZaUu/3/

+0

是的...所以這正是我不想要做的..因爲我們正在創建一個圖像對象在JS – samccone

1

如果你的目標是避免使用JavaScript和簡單地在您的網頁嵌入圖像,你可以簡單地做

<img src="..."> 

如果你的Base64是在ajax中動態獲取,那麼使用解碼庫的方法是用你創建的代碼創建一個Image對象。

另一種解決方案是直接發送二進制數組中的RGB值(如果使用json,則使用base64編碼),並在該數組上迭代客戶端以更改畫布的imageData。這似乎很容易,但效率不高,因爲你不會壓縮PNG或JPEG。

+0

heh ... so img標籤基本上仍然在內存中創建一個圖像對象.. – samccone

+0

是的,沒有真正的javascript對象,但我不認爲js對象和內部圖像緩衝區之間的內存差異超過幾個八位字節。我不確定你的確切目標。我希望這不是某種優化。 –

+0

所以基本上你需要一張沒有圖像的圖像?!?另一種選擇是編寫自己的base64解碼器和圖像渲染,這比使用瀏覽器的功能會花費更多的內存和CPU。 – core1024