Integrazione di Canvas nell'app web

David Tong
David Tong

Introduzione

In questo articolo, parlerò di come utilizzare l'elemento canvas HTML5 per creare, modificare, aprire ed esportare immagini. Presenterò inoltre diversi strumenti open source pertinenti a questa tecnologia e fornirò alcuni suggerimenti su come queste tecniche possono essere applicate a un'applicazione web esistente.

Verificare il supporto delle canvas

La prima cosa da fare è verificare che il browser supporti completamente le canvas HTML5. Un modo semplice per farlo è utilizzare Modernizr per verificare la presenza di una determinata funzionalità:

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

Creazione di un elemento canvas e importazione di un'immagine come URI binario o dati

Innanzitutto, devi avere un elemento canvas nella pagina. Utilizzando JavaScript, potrai:

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 questo codice, il primo passaggio consiste nell'ottenere il contesto 2D, che ci permette di accedere all'API che definisce tutti i metodi e le proprietà di disegno. Successivamente, creiamo un oggetto image e impostiamo la proprietà src sulla posizione dell'immagine binaria. Una volta caricata l'immagine, utilizziamo il metodoDrawImage() per importarla nell'elemento canvas. Puoi anche utilizzare un URI dati anziché l'URL di un'immagine. Quindi, al posto dell'URL riportato sopra, puoi procedere come segue:

img.src=""

Potreste chiedere: "Perché dovremmo utilizzare l'URI di dati invece dell'immagine binaria?" Esistono molti vantaggi. Più avanti in questo articolo, scoprirai con quale facilità è possibile esportare un'immagine canvas come URI dati. Ecco uno strumento per convertire un file di immagine binaria in un URI di dati.

Manipolare l'immagine del canvas

Se ti è capitato di realizzare una qualsiasi tipo di programmazione dei loghi, per disegnare su una tela si intende lo stesso concetto. Mark Pilgrim ha un capitolo su tela nel suo libro, Dive Into HTML5. Sulla base di un esempio nel capitolo, possiamo aggiungere un diagramma di griglia all'immagine importata in alto utilizzando quanto segue:

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";

Puoi essere più creativo, ma lascio la parola alle altre esercitazioni elencate nell'appendice di questo articolo per ulteriori istruzioni sull'argomento. Non abbiamo ancora visto nulla di interessante, ma nella prossima sezione la situazione cambierà.

Esportazione dell'immagine canvas come URI dati

L'elemento canvas ha un metodo toDataURL(), che utilizza un tipo MIME come parametro. In questo modo, possiamo esportare la tela utilizzata in precedenza.

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

In questo modo, il canvas viene esportato come immagine PNG in una nuova finestra del browser. L'immagine, tuttavia, non è una normale immagine binaria, ma un URI di dati codificato in base64 di cui un browser può eseguire il rendering. Pertanto, dal punto di vista dell'utente, non c'è alcuna differenza tra questo e l'equivalente binario. Tieni presente che la riga di codice riportata sopra deve essere eseguita su un server web. L'esecuzione di toDataURL() su un file locale non riuscirà. Per conoscere lo stato del problema in Chrome, consulta questo ticket.

Integrazione nella tua app web

Canvas può essere un componente aggiuntivo molto potente per qualsiasi applicazione web che memorizza le immagini caricate dagli utenti.

Tela contenitore

Ad esempio, disponiamo di un'applicazione di archiviazione file online che archivia le immagini caricate dagli utenti. Possiamo aggiungere un pulsante di modifica per aprire il file immagine in un editor di immagini basato su canvas. Se non vuoi scrivere un editor di canvas personalizzato, Harmony è uno dei pochi editor di canvas pubblicamente disponibili. Include una semplice aggiunta di pennelli per soddisfare i tuoi gusti artistici. Quando scegli "Modifica immagine" nel menu illustrato sopra, dovrebbe aprirsi un editor canvas e verrà creata una chiamata a una funzione read_file() personalizzata nella funzione init() dell'editor, come indicato di seguito:

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')
   }
}
Harmony

Aggiunta di LocalStorage HTML5

Un piccolo ritocco che dovresti sempre prendere in considerazione, se ti interessa l'esperienza utente, è l'applicazione di LocalStorage. Ad esempio, se disponi di un'area di testo di grandi dimensioni che richiede all'utente di inserire molte informazioni. Quando l'utente sta per inviare il modulo, chiude per errore il browser (o il browser si arresta in modo anomalo). L'utente potrebbe essere demoralizzato e non si sarebbe preoccupato di riscrivere il messaggio. Nella demo di seguito, invece di salvare i dati sul server, salva l'immagine in LocalStorage come URI dati:

// 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');
        }
//...
}

Salvataggio del canvas come file binario sul server

Ti consigliamo di salvare l'immagine canvas come file binario. Ci sono molti modi per farlo. Ad esempio, puoi eseguire un'azione POST per passare l'URI dei dati al codice di backend. Utilizzando jQuery, il risultato sarà questo:

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');

Viene creata una chiamata XHR il cui contenuto è l'URI dei dati. Devi quindi decodificare l'URI dei dati base64 sul server. Ad esempio, in PHP puoi:

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
}

Nelle prime due righe, l'URI dei dati ($contents) è diviso in due parti. 'data:image/png;base64' e 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' utilizzeremo base64_decode() per decodificare la stringa URI dei dati. Il trucco è che esistono problemi di decodifica di stringhe superiori a 5K e questo approccio "dividi e conquista" sarà in grado di decodificare la stringa. Infine, utilizzando fwrite(), puoi salvare il file binario $contents sul tuo server.

Attivazione dell'opzione "Salva immagine" nel browser

Canvas è un elemento HTML. Assomiglia a un'immagine, ma il tuo browser non offre un'opzione "Salva immagine con nome" per questo elemento perché in realtà non è un elemento immagine. Per abilitare "Salva immagine con nome", puoi creare dinamicamente un elemento Img e impostare src sull'URI di dati dell'elemento canvas. Puoi anche utilizzare l'utilità canvas2image.

Un editor canvas più avanzato

Se stai cercando un editor canvas più avanzato, probabilmente vale la pena provare PaintWeb. È stato scritto da Mihai Sucan, uno studente rumeno, durante la Summer of Code 2009 di Google. Ha anche realizzato alcuni tutorial sulla creazione di una sua applicazione online per la pittura.

Verniciatura web

Per una raccolta più professionale, dai un'occhiata a Pixati.

Più divertimento con le canvas?

Paul irlandese ha unito Harmony e $1 Uniic Recognition per creare un piccolo uovo di Pasqua sul suo sito web.

Puoi anche scoprire come controllare la tela con Chrome DevTools usando le nostre recenti funzionalità di ispezione.

Approfondisci l'argomento con tutorial aggiuntivi sulle canvas