Einführung
In diesem Artikel erfahren Sie, wie Sie mit dem HTML5-Element Canvas Bilder erstellen, bearbeiten, öffnen und exportieren. Außerdem stelle ich einige Open-Source-Tools vor, die für diese Technologie relevant sind, und gebe einige Tipps dazu, wie diese Techniken auf eine vorhandene Webanwendung angewendet werden können.
Unterstützung für Leinwand prüfen
Prüfen Sie zuerst, ob Ihr Browser HTML5-Canvas vollständig unterstützt. Eine einfache Möglichkeit dazu ist die Verwendung von Modernizr, um nach einer bestimmten Funktion zu suchen:
if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}
Canvas-Element erstellen und Bild als Binär- oder Daten-URI importieren
Zuerst müssen Sie ein Canvas-Element auf Ihrer Seite haben. Mit JavaScript können Sie Folgendes tun:
var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}
In diesem Code wird zuerst der 2D-Kontext abgerufen, der Zugriff auf die API gewährt, in der alle Zeichenmethoden und ‑eigenschaften definiert sind. Als Nächstes erstellen wir ein Bildobjekt und legen das Attribut „src“ auf den Speicherort des Binärbilds fest. Wenn das Bild geladen ist, importieren wir es mit der Methode „drawImage()“ in das Canvas-Element. Sie können auch einen Daten-URI anstelle der URL eines Bildes verwenden. Anstelle der obigen URL können Sie Folgendes tun:
img.src=""
Sie fragen sich vielleicht, warum wir die Daten-URI anstelle des Binärbilds verwenden. Es gibt viele Vorteile. Später in diesem Artikel sehen Sie, wie einfach wir ein Canvas-Bild als Daten-URI exportieren können. Hier finden Sie ein Tool, mit dem Sie eine binäre Bilddatei in einen Daten-URI konvertieren können.
Canvas-Bild bearbeiten
Wenn Sie schon einmal Logos programmiert haben, ist das Zeichnen auf einem Canvas dasselbe Prinzip. Mark Pilgrim hat in seinem Buch „Dive Into HTML5“ ein Kapitel zu Canvas. Basierend auf einem Beispiel in diesem Kapitel können wir dem Bild, das wir oben importiert haben, mit dem folgenden Befehl ein Rasterdiagramm hinzufügen:
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";
Sie können natürlich kreativer sein. Weitere Anleitungen zu diesem Thema finden Sie in den anderen Anleitungen im Anhang dieses Artikels. Bisher war es noch nicht sehr spannend, aber das ändert sich im nächsten Abschnitt.
Canvas-Bild als Daten-URI exportieren
Das Canvas-Element hat eine toDataURL()-Methode, die einen MIME-Typ als Parameter annimmt. So können wir den Canvas exportieren, den wir oben verwendet haben. 
window.open(document.getElementById('ctx').toDataURL("image/png"));
Dadurch wird der Canvas als PNG-Bild in einem neuen Browserfenster exportiert. Das Bild ist jedoch kein gewöhnliches Binärbild, sondern ein Base64-codierter Daten-URI, der von einem Browser gerendert werden kann. Aus Sicht des Nutzers gibt es also keinen Unterschied zwischen diesem und dem Binäräquivalent. 
Die Codezeile oben muss auf einem Webserver ausgeführt werden. Das Ausführen von toDataURL() auf einer lokalen Datei würde fehlschlagen. Den Status dieses Problems in Chrome findest du in diesem Ticket. 
In Ihre Webanwendung einbinden
Canvas kann ein sehr leistungsstarkes Add-on für alle Webanwendungen sein, in denen von Nutzern hochgeladene Bilder gespeichert werden.
Angenommen, wir haben eine Online-Dateispeicheranwendung, in der von Nutzern hochgeladene Bilder gespeichert werden. Wir können eine Schaltfläche zum Bearbeiten hinzufügen, um die Bilddatei in einem Canvas-basierten Bildeditor zu öffnen. 
Wenn Sie keinen eigenen Canvas-Editor schreiben möchten, ist Harmony einer der wenigen frei verfügbaren Canvas-Editoren. Es bietet eine einfache Möglichkeit, Pinsel hinzuzufügen, die Ihren künstlerischen Geschmack treffen. 
Wenn Sie im Menü oben „Bild bearbeiten“ auswählen, sollte sich ein Canvas-Editor öffnen, der in der init()-Funktion des Editors eine benutzerdefinierte read_file()-Funktion aufruft. Das würde so aussehen: 
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 hinzufügen
Wenn Sie Wert auf die Nutzerfreundlichkeit legen, sollten Sie immer LocalStorage verwenden. Das ist beispielsweise der Fall, wenn Sie ein großes Textfeld haben, in das der Nutzer viele Informationen eingeben muss. Der Nutzer möchte das Formular absenden, schließt aber versehentlich den Browser oder der Browser stürzt ab. Der Nutzer ist möglicherweise frustriert und schreibt die Nachricht nicht noch einmal. In der Demo unten wird das Bild nicht auf dem Server, sondern im LocalStorage als Daten-URI gespeichert:
// 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');
        }
//...
}
Canvas als Binärdatei auf dem Server speichern
Sie können das Canvas-Bild als Binärdatei speichern. Es gibt viele Möglichkeiten, dies zu tun. Sie können beispielsweise eine POST-Aktion ausführen, um den Daten-URI an Ihren Back-End-Code weiterzuleiten. Mit jQuery würde das so aussehen:
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');
Dadurch wird ein XHR-Aufruf mit dem Daten-URI als Inhalt erstellt. Sie müssen dann die Base64-Daten-URI auf dem Server decodieren. In PHP haben Sie beispielsweise folgende Möglichkeiten:
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
}
In den ersten beiden Zeilen wird der Daten-URI ($contents) in zwei Teile aufgeteilt. 'data:image/png;base64' und 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...'. Mit base64_decode() decodieren wir dann den Daten-URI-String. Das Problem dabei ist, dass es Probleme beim Decodieren von Strings mit mehr als 5.000 Byte gibt. Mit diesem Ansatz „Teile und Herrsche“ lässt sich der String jedoch decodieren. 
Mit fwrite() können Sie die Binärdatei „$contents“ auf Ihrem Server speichern. 
„Bild speichern“ im Browser aktivieren
Canvas ist ein HTML-Element. Es sieht fast wie ein Bild aus, aber Ihr Browser bietet keine Option „Bild als… speichern“ an, da es sich nicht wirklich um ein Bildelement handelt. Wenn Sie „Bild speichern als“ aktivieren möchten, können Sie ein Img-Element dynamisch erstellen und das Attribut „src“ auf die Daten-URI des Canvas-Elements festlegen. Sie können auch das Dienstprogramm „canvas2image“ verwenden.
Ein erweiterter Canvas-Editor
Wenn Sie nach einem erweiterten Canvas-Editor suchen, ist PaintWeb wahrscheinlich einen Versuch wert. Es wurde von Mihai Sucan, einem rumänischen Studenten, während des Google Summer of Code 2009 geschrieben. Er hat auch einige Anleitungen zum Erstellen einer eigenen Online-Malanwendung verfasst.
Eine professionellere Bibliothek ist Pixati.
Mehr Spaß mit Canvas?
Paul Irish hat Harmony mit dem Unistroke-Erkennungstool für 1 $kombiniert, um auf seiner Website ein kleines Osterei zu erstellen.
Mit unseren neuen Prüffunktionen können Sie auch lernen, wie Sie Canvas mit den Chrome-Entwicklertools prüfen.
Zusätzliche Anleitungen auf Canvas
- MDN: Canvas-Anleitung
 - Einführung in HTML5: Canvas
 - HTML5 canvas – the basics (HTML5-Canvas – die Grundlagen) auf Dev.Opera behandelt die grundlegenden Zeichenprimitiven.
 - Erstellen eines Breakout-Klons in Canvas: grundlegende Bewegung, Physik und Interaktivität