Объединение двух изображений base64 в Javascript - PullRequest
1 голос
/ 08 августа 2010

Можно ли выполнить простую конкатенацию строк, чтобы «объединить» 2 базовых 64 кодированных изображения вместе, если изображения имеют одинаковые характеристики (ширина / высота / глубина цвета и т. Д.)?

например,

img1 w=100, h=200
img2 w=100, h=200

img1+img2 приводит к

img3 w=100, h=400

, интуитивно это звучит как глупый вопрос, так как предположительно кодировка включает заголовки, содержащие метаданные, но я не знаю достаточно о base64, чтобы знать лучше;)

Пока мои предварительные тесты дали неверные результаты.

Спасибо, Элай

Ответы [ 3 ]

1 голос
/ 08 августа 2010

, так как предположительно кодировка включает заголовки, содержащие метаданные, но я не знаю достаточно о base64, чтобы знать лучше;)

Вы правы: содержание data: URI - это закодированное в base64 представление полных данных файла изображения, включая заголовки.Вам не повезет, объединяя их таким образом.

Единственный способ, которым может быть возможен на стороне клиента, - это использование Canvas. Вот SO вопрос, который идет в этом направлении (он извлекает изображение в объект canvas).

0 голосов
/ 02 октября 2012

Я сталкивался с этим постом с другой стороны фактической реализации решения. Вы можете объединить строки base64. Вам просто нужно убедиться, что во время кодирования (в нашем случае - время объединения) вы знаете точную длину двух строк или используете разделитель. Я написал формат файла для объединения файлов в base64, который клиент затем анализирует. Поскольку это для холст флеш-плеера называется ноль, формат файла называется .zwf. Вот формат. Кстати, вы можете рекурсивно кодировать целые каталоги с помощью этого формата.

шаблон

'<path>' <index> <length in characters> <encoding type (b64, b256, UTF8, etc.)> //HEADER these are entries in the zwf 
'<path>' <index> <length> <encoding>
'<path>' <index> <length> <encoding>
||||||||||                           //BREAK Indexes are relative to this
<file1><file2><file3>                //DATA All contents are here nose to tail

example.zwf

'hi.txt' 0 11 UTF8
'images/face.png' 11 1459 b64
||||||||||
Hello World%3D%3D

Используя .zwf, вы можете объединять произвольные типы файлов и сокращать HTTP-запросы. Вы можете упаковать весь сайт в ZWF.

JavaScript практически в любом браузере может обрабатывать очень большие строки base64. Я пошел до 2Mb во всех современных браузерах. Мое приложение не требует большего, во что бы то ни стало найти пределы.

На стороне клиента, когда пользователь запрашивает файл, ноль вызывает .slice () в разделе данных, чтобы получить его на основе индекса и длины в заголовке. Slice - один из самых быстрых методов, которые я знаю.

Единственная проблема в том, что браузеры

0 голосов
/ 08 августа 2010

Я думаю, что то, что вы предлагаете, имеет (как минимум) 2 проблемы:

  1. Вы не указали, в каком формате изображения в первую очередь (например, GIF, JPG, PNG и т. Д.) Base64 - это просто способ кодирования двоичных данных в текст. Возможность соединения двух изображений с помощью простой конкатенации битовых потоков зависит от основного двоичного формата изображений.

  2. Я не знаю ни одного современного графического формата, который поддерживал бы этот вид двоичной конкатенации. Ваше первоначальное беспокойство (что у изображений есть метаданные где-то в их двоичном представлении, которое определяет размер изображения, битовую глубину и т. Д.) Вполне обосновано.

Я думаю, что вы могли бы пойти с этим, чтобы найти библиотеку манипулирования изображениями, которая позволяет вам брать ваши двоичные изображения (однажды декодированные из Base64), сшивать их вместе, как вы считаете нужным, и затем перекодировать в результате увеличенное изображение как Base64.

Если вы ограничены только JavaScript, похоже, что http://www.pixastic.com/lib/ - это хорошая библиотека для работы с изображениями, но я не могу определить, поддерживает ли она необходимый вам тип вышивки. Это место для начала, хотя.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...