2012-06-04 3 views
-1

редактироватьпреобразования изображений на стороне сервера в CanvasPixelArray

так это выглядит, как я должен каким-то образом преобразовать изображение в

https://developer.mozilla.org/en/DOM/CanvasPixelArray ServerSide

мои нынешние попытки были в *

Пропустить кодированное изображение 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

Если ваша цель состоит в том, чтобы избежать использования яваскрипт и просто вставлять изображения на странице, вы можете просто

<img src="..."> 

Если base64 является полученным динамически в ajax, тогда использование библиотеки декодирования - это создание объекта Image с кодом, который вы создали.

Альтернативным решением было бы послать непосредственно значения RGB в двоичном массиве (base64, закодированном, если вы используете json), и итерации на стороне клиента в этом массиве, чтобы изменить изображение imageData вашего холста. Это кажется достаточно простым, но несколько неэффективным, поскольку у вас не будет сжатия PNG или JPEG.

+0

heh ... так img теги в основном по-прежнему создают объект изображения в памяти. – samccone

+0

Да, нет реального объекта javascript, но я не думаю, что разница между памятью между объектом js и внутренним буфером изображений больше, чем несколько октетов. Я не уверен в вашей конкретной цели. Надеюсь, это не какая-то оптимизация. –

+0

Так что вам нужно изображение без картинки?!? Другой вариант - написать собственный декодер base64 и рендеринг изображений, что будет стоить больше памяти и процессора, чем использование возможностей браузера. – core1024