Интеграция Canvas в ваше веб-приложение

Введение

В этой статье я собираюсь обсудить, как использовать элемент холста HTML5 для создания, редактирования, открытия и экспорта изображений. Я также представлю несколько инструментов с открытым исходным кодом, которые имеют отношение к этой технологии, и дам несколько советов о том, как эти методы можно применить к существующему веб-приложению.

Проверьте поддержку холста

Первое, что нужно сделать, это убедиться, что ваш браузер полностью поддерживает холст HTML5. Самый простой способ сделать это — использовать Modernizr для проверки определенной функции:

if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}

Создание элемента холста и импорт изображения в виде двоичного кода или URI данных.

Во-первых, вам понадобится элемент холста на вашей странице. Используя JavaScript, вы делаете следующее:

var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}

В этом коде первым шагом является получение 2D-контекста, который дает нам доступ к API , определяющему все методы и свойства рисования. Затем мы создаем объект изображения и устанавливаем для свойства src местоположение двоичного изображения. Когда изображение загружается, мы используем метод drawImage() для импорта изображения в элемент холста. Вы также можете использовать URI данных вместо URL-адреса изображения. Поэтому вместо URL-адреса выше вы можете сделать следующее:

img.src=""

Вы можете спросить: «Зачем нам использовать URI данных вместо двоичного изображения?» Есть много преимуществ . Далее в этой статье вы увидите, как легко мы можем экспортировать изображение холста как URI данных. Вот инструмент для преобразования двоичного файла изображения в URI данных .

Манипулирование изображением холста

Если вы когда-либо занимались программированием логотипов , при рисовании на холсте используется та же концепция. В книге Марка Пилигрима «Погружение в HTML5» есть глава, посвященная холсту . Основываясь на примере из этой главы, мы можем добавить сетку к изображению, которое мы импортировали выше, используя следующее:.

var img2 = new Image();
img2.onload = function () {
  var context2 = document.getElementById('new_canvas2').getContext('2d');
  /* vertical lines then horizontal ones */
  for (var x = 0.5; x < 800; x += 10) { context2.moveTo(x, 0); context2.lineTo(x, 500); } 
  for (var y = 0.5; y < 500; y += 10) { context2.moveTo(0, y); context2.lineTo(800, y); }
  context2.strokeStyle = "#bbb";
  context2.stroke();
  context2.drawImage(img2,0,0);
}
img2.src = "html5.gif";

Вы можете проявить больше творчества, но я оставляю это другим руководствам, перечисленным в приложении к этой статье, для получения дополнительных инструкций по этому вопросу. Мы еще не увидели ничего интересного, но следующий раздел изменит это.

Экспорт изображения холста как URI данных

Элемент холста имеет метод toDataURL() , который принимает в качестве параметра тип MIME. Благодаря этому мы можем экспортировать холст, который мы использовали выше.

window.open(document.getElementById('ctx').toDataURL("image/png"));

При этом холст экспортируется как изображение PNG в новое окно браузера. Однако изображение не является обычным двоичным изображением, а представляет собой URI данных в кодировке Base64, который может отображаться браузером. Таким образом, с точки зрения пользователя нет никакой разницы между этим и двоичным эквивалентом. Обратите внимание, что приведенную выше строку кода необходимо запустить на веб-сервере. Запуск toDataURL() для локального файла завершится неудачно. См. этот билет , чтобы узнать о статусе этой проблемы в Chrome.

Интеграция в ваше веб-приложение

Canvas может быть очень мощным дополнением к любому веб-приложению, хранящему загруженные пользователем изображения.

Коробка холста

Например, у нас есть онлайн-приложение для хранения файлов, в котором хранятся загруженные пользователем изображения. Мы можем добавить кнопку редактирования, чтобы открыть файл изображения в редакторе изображений на основе холста. Если вы не хотите писать свой собственный редактор холста, Harmony — один из немногих общедоступных редакторов холста. Он отличается простым добавлением кистей, которые удовлетворят ваши художественные вкусы. Когда вы выбираете «редактировать изображение» в меню, показанном выше, должен открыться редактор холста, который вызовет специальную функцию read_file() в функции init() редактора следующим образом:

function read_file() {
   var url = file_id;
   // hide a copy of the original image if it is needed to load
   document.getElementById('editableImage').src = url; 
   image = new Image();
   image.src = url;
   image.onload = function() {
      context.drawImage(image,0,0); // context, defined above, as canvas.getContext('2d')
   }
}
Гармония

Добавление HTML5 LocalStorage

Небольшая доработка, которую всегда следует учитывать, если вас волнует удобство использования, — это применение LocalStorage. Например, если у вас большая текстовая область, требующая от пользователя ввода большого количества информации. Когда пользователь собирается отправить форму, он случайно закрывает браузер (или браузер выходит из строя). Пользователь может быть разочарован и не будет переписывать сообщение снова. В приведенной ниже демонстрации вместо сохранения данных на сервере просто сохраните изображение в LocalStorage как URI данных:

// Save Image
function saveToLocalStorage() {
    localStorage.setItem('canvas', canvas.toDataURL('image/png'));
}

// Load Image
function init() {
        // for demo purpose, all variables are declared in the parent scope
        canvas = document.createElement('canvas');
        context = canvas.getContext('2d');

        // Use Modernizr to detect whether localstorage is supported by the browser
        if (Modernizr.localstorage && localStorage.getItem('canvas'))
        {
            localStorageImage = new Image();
            localStorageImage.addEventListener("load", function (event) {
                //...
                context.drawImage(localStorageImage, 0, 0);
            }, false);
            localStorageImage.src = localStorage.getItem('canvas');
        }
//...
}

Сохранение холста в виде двоичного файла на сервере.

Возможно, вы захотите сохранить изображение холста в виде двоичного файла. Есть много способов сделать это. Например, вы можете выполнить действие POST, чтобы передать URI данных в внутренний код. Используя jQuery, это будет выглядеть так:

var url = '/api/write/' + file_id + '?data_url_to_binary=1';
var data_url = flattenCanvas.toDataURL('image/png');
var params = { contents: data_url };

$j.post(url, params, function(json){
   if (json.status == 'upload_ok')
   {
      //ok
   }
}, 'json');

При этом создается вызов XHR, содержимым которого является URI данных. Затем вам необходимо декодировать URI данных base64 на сервере. Например, в PHP вы можете сделать следующее:

if ($_GET['data_url_to_binary'])
{
   $contents_split = explode(',', $contents);
   $encoded = $contents_split[count($contents_split)-1];
   $decoded = "";
   for ($i=0; $i < ceil(strlen($encoded)/256); $i++) {
      $decoded = $decoded . base64_decode(substr($encoded,$i*256,256)); 
   }
   $contents = $decoded; // output
}

В первых двух строках URI данных ($contents) разделен на две части. 'data:image/png;base64' и 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' Затем мы воспользуемся base64_decode() для декодирования строки URI данных. Хитрость здесь в том, что существуют проблемы с декодированием строки размером более 5 КБ, и этот подход «разделяй и властвуй» сможет декодировать строку. Наконец, используя fwrite() , вы можете сохранить двоичный файл $contents на своем сервере.

Включение «сохранения изображения» в браузере

Canvas — это HTML-элемент. Оно очень похоже на изображение, но ваш браузер не предоставляет для него опции «Сохранить изображение как», поскольку на самом деле оно не является элементом изображения. Чтобы включить «Сохранить изображение как», вы можете динамически создать элемент Img и установить в качестве src URI данных элемента холста. Вы также можете использовать утилиту Canvas2image .

Более продвинутый редактор холста.

Если вы ищете более продвинутый редактор холста, вероятно, стоит попробовать PaintWeb . Его написал Михай Сукан, румынский студент, во время Google Summer of Code 2009. Он также является автором нескольких руководств по написанию собственного онлайн-приложения для рисования.

Краска Паутина

Если вы хотите получить более профессиональную библиотеку, обязательно посетите Pixati .

С холстом веселее?

Пол Айриш объединил Harmony и Unistroke Recouncer за 1 доллар, чтобы создать на своем веб-сайте маленькое пасхальное яйцо .

Вы также можете узнать, как проверять холст с помощью Chrome DevTools, используя наши последние функции проверки.

Пойдите глубже с дополнительными уроками по холсту