Introduction
Dans cet article, je vais vous expliquer comment utiliser l'élément canvas HTML5 pour créer, modifier, ouvrir et exporter des images. Je présenterai également plusieurs outils Open Source pertinents pour cette technologie et vous donnerai des conseils sur la façon dont ces techniques peuvent être appliquées à une application Web existante.
Vérifier la compatibilité avec le canevas
La première chose à faire est de vérifier que votre navigateur est entièrement compatible avec le canevas HTML5. Pour ce faire, il vous suffit d'utiliser Modernizr pour vérifier la présence d'une certaine fonctionnalité:
if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}
Créer un élément de canevas et importer une image en tant qu'URI binaire ou de données
Tout d'abord, vous devez ajouter un élément de canevas à votre page. Avec JavaScript, vous pouvez:
var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}
Dans ce code, la première étape consiste à obtenir le contexte 2D, qui nous permet d'accéder à l'API qui définit toutes les méthodes et propriétés de dessin. Nous créons ensuite un objet image et définissons la propriété src sur l'emplacement de l'image binaire. Une fois l'image chargée, nous utilisons la méthode drawImage() pour l'importer dans l'élément canvas. Vous pouvez également utiliser un URI de données au lieu de l'URL d'une image. Vous pouvez donc remplacer l'URL ci-dessus par la suivante:
img.src=""
Vous vous demandez peut-être pourquoi utiliser un URI de données au lieu de l'image binaire. Elle présente de nombreux avantages. Plus loin dans cet article, vous verrez à quel point il est facile d'exporter une image de canevas en tant qu'URI de données. Voici un outil permettant de convertir un fichier image binaire en URI de données.
Manipuler l'image du canevas
Si vous avez déjà fait de la programmation Logo, le dessin sur un canevas repose sur le même concept. Mark Pilgrim consacre un chapitre au canevas dans son livre "Dive Into HTML5". En nous basant sur un exemple du chapitre, nous pouvons ajouter un diagramme de grille à l'image que nous avons importée ci-dessus en utilisant ce qui suit :
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";
Vous pouvez être plus créatif, mais je vous laisse consulter les autres tutoriels listés dans l'annexe de cet article pour obtenir des instructions supplémentaires à ce sujet. Nous n'avons encore rien vu de très intéressant, mais la section suivante va changer cela.
Exporter l'image du canevas en tant qu'URI de données
L'élément canvas comporte une méthode toDataURL(), qui utilise un type MIME comme paramètre. Nous pouvons ainsi exporter le canevas que nous avons utilisé ci-dessus. 
window.open(document.getElementById('ctx').toDataURL("image/png"));
Le canevas est alors exporté en tant qu'image PNG dans une nouvelle fenêtre de navigateur. L'image n'est toutefois pas une image binaire ordinaire, mais un URI de données encodé en base64 pouvant être affiché par un navigateur. Par conséquent, du point de vue de l'utilisateur, il n'y a aucune différence entre cela et l'équivalent binaire. 
Notez que la ligne de code ci-dessus doit être exécutée sur un serveur Web. L'exécution de toDataURL() sur un fichier local échouerait. Pour connaître l'état de ce problème dans Chrome, consultez cette demande. 
Intégrer à votre application Web
Canvas peut être un module complémentaire très puissant pour toutes les applications Web qui stockent des images importées par les utilisateurs.
Par exemple, nous avons une application de stockage de fichiers en ligne qui stocke les images importées par les utilisateurs. Nous pouvons ajouter un bouton de modification pour ouvrir le fichier image dans un éditeur d'images basé sur un canevas. 
Si vous ne souhaitez pas écrire votre propre éditeur de canevas, Harmony est l'un des rares éditeurs de canevas disponibles. Il permet d'ajouter facilement des pinceaux pour répondre à vos goûts artistiques. 
Lorsque vous choisissez "Modifier l'image" dans le menu illustré ci-dessus, un éditeur de canevas devrait s'ouvrir et appeler une fonction read_file() personnalisée dans la fonction init() de l'éditeur comme suit: 
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')
   }
}
Ajouter LocalStorage HTML5
Si vous vous souciez de l'expérience utilisateur, vous devez toujours envisager d'appliquer LocalStorage. Par exemple, si vous avez une grande zone de texte qui nécessite que l'utilisateur saisisse de nombreuses informations. Lorsque l'utilisateur est sur le point d'envoyer le formulaire, il ferme accidentellement le navigateur (ou le navigateur plante). L'utilisateur peut être frustré et ne pas se donner la peine de réécrire le message. Dans la démonstration ci-dessous, au lieu d'enregistrer les données sur le serveur, enregistrez simplement l'image dans LocalStorage en tant qu'URI de données:
// 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');
        }
//...
}
Enregistrer le canevas en tant que fichier binaire sur le serveur
Vous pouvez enregistrer l'image du canevas en tant que fichier binaire. Vous pouvez le faire de plusieurs façons. Par exemple, vous pouvez effectuer une action POST pour transmettre l'URI de données à votre code backend. Avec jQuery, cela se présente comme suit:
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');
Cela crée un appel XHR dont le contenu est l'URI des données. Vous devez ensuite décoder l'URI de données base64 sur le serveur. En PHP, par exemple, vous pouvez effectuer les opérations suivantes:
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
}
Dans les deux premières lignes, l'URI de données ($contents) est divisé en deux parties. 'data:image/png;base64' et 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...'. Nous utiliserons ensuite base64_decode() pour décoder la chaîne d'URI de données. L'astuce ici est qu'il existe des problèmes de décodage des chaînes de plus de 5 ko, et cette approche "diviser pour régner" permettra de les décoder. 
Enfin, à l'aide de fwrite(), vous pouvez enregistrer le fichier binaire, $contents, sur votre serveur. 
Activer l'option "Enregistrer l'image" dans le navigateur
Le canevas est un élément HTML. Il ressemble à une image, mais votre navigateur ne propose pas d'option "Enregistrer l'image sous", car il ne s'agit pas vraiment d'un élément image. Pour activer "Enregistrer l'image sous", vous pouvez créer dynamiquement un élément Img et définir la valeur de src sur l'URI de données de l'élément canvas. Vous pouvez également utiliser l'utilitaire canvas2image.
Un éditeur de canevas plus avancé
Si vous recherchez un éditeur de canevas plus avancé, PaintWeb est probablement une bonne option. Il a été écrit par Mihai Sucan, un étudiant roumain, lors du Google Summer of Code 2009. Il a également rédigé quelques tutoriels sur la création de votre propre application de peinture en ligne.
Pour une bibliothèque plus professionnelle, consultez Pixati.
Amusez-vous encore plus avec l'application Dessin ?
Paul Irish a combiné Harmony et le reconnaissance Unistroke à 1 $pour créer un petit œuf de Pâques sur son site Web.
Découvrez également comment inspecter le canevas avec les outils pour les développeurs Chrome à l'aide de nos dernières fonctionnalités d'inspection.
Approfondissez vos connaissances avec des tutoriels supplémentaires sur Canvas
- MDN: Tutoriel Canvas
 - Découvrir HTML5: Canvas
 - HTML5 canvas - the basics (Canevas HTML5 : principes de base) sur Dev.Opera présente les primitives de dessin de base.
 - Créer un clone de Breakout dans un canevas inclut des principes de base de mouvement, de physique et d'interactivité.