Wprowadzenie
Z tego artykułu dowiesz się, jak używać elementu HTML5 canvas do tworzenia, edytowania, otwierania i eksportowania obrazów. Przedstawię też kilka narzędzi open source związanych z tą technologią i podpowiem, jak można stosować te techniki w dotychczasowej aplikacji internetowej.
Sprawdzanie obsługi odbitek na płótnie
Najpierw sprawdź, czy Twoja przeglądarka w pełni obsługuje płótno HTML5. Najprostszym sposobem jest użycie narzędzia Modernizr do sprawdzenia, czy dana funkcja jest obsługiwana:
if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}
Tworzenie elementu kanwy i importowanie obrazu jako binarnego lub identyfikatora URI danych
Najpierw musisz mieć na stronie element canvas. Za pomocą JavaScriptu możesz:
var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}
W tym kodzie pierwszym krokiem jest uzyskanie kontekstu 2D, który daje nam dostęp do interfejsu API definiującego wszystkie metody i właściwości rysowania. Następnie tworzymy obiekt obrazu i ustawiamy właściwość src na lokalizację obrazu binarnego. Po załadowaniu obrazu używamy metody drawImage(), aby zaimportować obraz do elementu canvas. Zamiast adresu URL obrazu możesz też użyć identyfikatora URI danych. Zamiast podanego powyżej adresu URL możesz wykonać te czynności:
img.src=""
Możesz zapytać, dlaczego używać identyfikatora URI danych zamiast obrazu binarnego. Jest wiele zalet. W dalszej części tego artykułu zobaczysz, jak łatwo można wyeksportować obraz na płótnie jako identyfikator URI danych. Oto narzędzie do konwertowania binarnego pliku obrazu na identyfikator URI danych.
Modyfikowanie obrazu na płótnie
Jeśli kiedykolwiek zajmowałeś/zajmowałaś się programowaniem logo, rysowanie na płótnie wykorzystuje tę samą koncepcję. Mark Pilgrim poświęcił rozdział w książce Dive Into HTML5 (Zanurkuj w HTML5) tematowi canvas. Na podstawie przykładu w tym rozdziale możemy dodać diagram siatki do zaimportowanego wcześniej obrazu, wykonując te czynności:
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";
Możesz być bardziej kreatywny, ale dodatkowe instrukcje na ten temat znajdziesz w innych samouczkach wymienionych w aneksie tego artykułu. Nie widzieliśmy jeszcze niczego bardzo ekscytującego, ale w następnej sekcji to się zmieni.
Eksportowanie obrazu na płótnie jako identyfikatora URI danych
Element canvas ma metodę toDataURL(), która jako parametr przyjmuje typ MIME. Dzięki temu możemy wyeksportować użyty powyżej obszar roboczy. 
window.open(document.getElementById('ctx').toDataURL("image/png"));
Spowoduje to wyeksportowanie płótna jako obrazu PNG do nowego okna przeglądarki. Obraz nie jest jednak zwykłym obrazem binarnym, ale identyfikatorem URI danych zakodowanym w formacie Base64, który może być renderowany przez przeglądarkę. Z punktu widzenia użytkownika nie ma więc różnicy między tym a binarnym odpowiednikiem. 
Pamiętaj, że powyższy wiersz kodu musi być uruchomiony na serwerze WWW. Uruchomienie toDataURL() na pliku lokalnym zakończy się niepowodzeniem. Aby sprawdzić stan tego problemu w Chrome, otwórz ten zgłoszony problem. 
Integracja z aplikacją internetową
Canvas może być bardzo przydatnym dodatkiem do wszelkich aplikacji internetowych, które przechowują obrazy przesłane przez użytkowników.
Mamy na przykład aplikację do przechowywania plików online, która przechowuje obrazy przesłane przez użytkowników. Możemy dodać przycisk edycji, który otwiera plik obrazu w edytorze obrazów opartym na kanwie. 
Jeśli nie chcesz pisać własnego edytora kanwy, Harmony jest jednym z nielicznych dostępnych edytorów kanwy. Umożliwia łatwe dodawanie pędzli, które zaspokoją Twoje artystyczne potrzeby. 
Gdy w menu pokazanym powyżej wybierzesz „edytuj obraz”, otworzy się edytor kanwy, który wywoła niestandardową funkcję read_file() w funkcji init() edytora w ten sposób: 
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')
   }
}
Dodawanie HTML5 LocalStorage
Jeśli zależy Ci na komforcie użytkowników, pamiętaj o zaimplementowaniu LocalStorage. Jeśli na przykład masz duży obszar tekstowy, który wymaga od użytkownika podania wielu informacji. Gdy użytkownik ma przesłać formularz, przypadkowo zamyka przeglądarkę (lub przeglądarka się zawiesza). Użytkownik może się zdenerwować i nie chcieć ponownie pisać wiadomości. W poniżej zaprezentowanym przykładzie zamiast zapisywać dane na serwerze, po prostu zapisz obraz w pamięci lokalnej jako identyfikator URI danych:
// 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');
        }
//...
}
zapisywanie na serwerze płótna jako pliku binarnego,
Możesz zapisać obraz na płótnie jako plik binarny. Możesz to zrobić na wiele sposobów. Możesz na przykład wykonać działanie POST, aby przekazać identyfikator URI danych do kodu backendu. W przypadku jQuery wygląda to tak:
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');
Spowoduje to wywołanie XHR, którego treścią jest identyfikator URI danych. Następnie na serwerze musisz zdekodować identyfikator URI danych w formacie base64. W PHP możesz na przykład:
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
}
W pierwszych 2 wierszach identyfikator URI danych ($contents) jest podzielony na 2 części. 'data:image/png;base64' i 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' Następnie użyjemy base64_decode() do dekodowania ciągu identyfikatora URI danych. Chodzi o to, że występują problemy z dekodowaniem ciągu dłuższego niż 5 tys. znaków, a podejście „dzielić i rządzić” pozwoli na dekodowanie takiego ciągu. 
Na koniec za pomocą funkcji fwrite() możesz zapisać plik binarny $contents na serwerze. 
Włączanie opcji „Zapisz obraz” w przeglądarce
Płótno to element HTML. Wygląda ono jak obraz, ale przeglądarka nie udostępnia opcji „Zapisz obraz jako”, ponieważ nie jest to element obrazu. Aby włączyć funkcję „Zapisz obraz jako”, możesz dynamicznie utworzyć element Img i ustawić atrybut src na identyfikator URI danych elementu kanwy. Możesz też użyć narzędzia canvas2image.
bardziej zaawansowany edytor odbitek na płótnie,
Jeśli szukasz bardziej zaawansowanego edytora kanwy, warto wypróbować PaintWeb. Napisał go Mihai Sucan, rumuński uczeń, podczas Google Summer of Code 2009. Jest też autorem kilku samouczków na temat pisania własnych aplikacji do rysowania online.
Jeśli chcesz mieć bardziej profesjonalną bibliotekę, wypróbuj Pixati.
Więcej zabawy z Canvasem?
Paul Irish połączył Harmony i $1 Unistroke Recognizer, aby utworzyć w swojej witrynie małą niespodziankę wielkanocną.
Możesz też dowiedzieć się, jak sprawdzać płótno za pomocą Narzędzi deweloperskich w Chrome, korzystając z naszych najnowszych funkcji sprawdzania.
Poznaj dodatkowe samouczki dotyczące tworzenia planszy
- MDN: samouczek dotyczący Canvas
 - Zapoznaj się z HTML5: Canvas
 - Na stronie Dev.Opera znajdziesz artykuł HTML5 canvas – podstawy, który zawiera podstawowe informacje o prostych elementach rysunkowych.
 - Tworzenie klona Breakout w Canvas obejmuje podstawowe ruchy, fizykę i interakcje.