Mengintegrasikan Kanvas ke Aplikasi Web Anda

Pengantar

Dalam artikel ini, saya akan membahas cara menggunakan elemen kanvas HTML5 untuk membuat, mengedit, membuka, dan mengekspor gambar. Saya juga akan memperkenalkan beberapa alat open source yang relevan dengan teknologi ini, dan memberikan beberapa tips tentang cara menerapkan teknik ini ke aplikasi web yang ada.

Memeriksa dukungan kanvas

Hal pertama yang harus dilakukan adalah memeriksa apakah browser Anda sepenuhnya mendukung kanvas HTML5. Cara mudah untuk melakukannya adalah dengan menggunakan Modernizr untuk memeriksa fitur tertentu:

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

Membuat elemen kanvas dan mengimpor gambar sebagai URI biner atau data

Pertama, Anda harus memiliki elemen kanvas di halaman. Dengan JavaScript, Anda melakukan hal berikut:

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

Dalam kode ini, langkah pertama adalah mendapatkan konteks 2D, yang memberi kita akses ke API yang menentukan semua metode dan properti gambar. Selanjutnya, kita membuat objek gambar dan menetapkan properti src ke lokasi gambar biner. Saat gambar dimuat, kita kemudian menggunakan metode drawImage() untuk mengimpor gambar ke elemen kanvas. Anda juga dapat menggunakan URI data, bukan URL gambar. Jadi, sebagai ganti URL di atas, Anda dapat melakukan hal berikut:

img.src=""

Anda mungkin bertanya, "Mengapa kita menggunakan URI data, bukan gambar biner?" Ada banyak keuntungan. Kemudian dalam artikel ini, Anda akan melihat betapa mudahnya kita mengekspor gambar kanvas sebagai URI data. Berikut adalah alat untuk mengonversi file gambar biner menjadi URI data.

Melakukan manipulasi pada gambar kanvas

Jika Anda pernah melakukan Pemrograman logo, menggambar di kanvas menggunakan konsep yang sama. Mark Pilgrim memiliki bab tentang kanvas dalam bukunya, Dive Into HTML5. Berdasarkan contoh dalam bab ini, kita dapat menambahkan diagram petak ke gambar yang diimpor di atas menggunakan kode berikut:.

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

Anda dapat lebih kreatif dari ini, tetapi saya menyerahkannya kepada tutorial lain yang tercantum dalam lampiran artikel ini untuk mendapatkan petunjuk tambahan tentang subjek tersebut. Kita belum melihat sesuatu yang sangat menarik, tetapi bagian berikutnya akan mengubahnya.

Mengekspor gambar kanvas sebagai URI data

Elemen kanvas memiliki metode toDataURL(), yang menggunakan jenis MIME sebagai parameter. Dengan ini, kita dapat mengekspor kanvas yang digunakan di atas.

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

Tindakan ini akan mengekspor kanvas sebagai gambar PNG ke jendela browser baru. Namun, gambar tersebut bukan gambar biner biasa, melainkan URI data berenkode base64 yang dapat dirender oleh browser. Jadi, dari sudut pandang pengguna, tidak ada perbedaan antara keduanya dan yang setara biner. Perhatikan bahwa baris kode di atas perlu dijalankan di server web. Menjalankan toDataURL() pada file lokal akan gagal. Lihat tiket ini untuk mengetahui status masalah ini di Chrome.

Mengintegrasikan ke dalam aplikasi web Anda

Kanvas dapat menjadi add-on yang sangat efektif untuk aplikasi web apa pun yang menyimpan gambar yang diupload pengguna.

Kanvas kotak

Misalnya, kita memiliki aplikasi penyimpanan file online yang menyimpan gambar yang diupload pengguna. Kita dapat menambahkan tombol edit untuk membuka file gambar di editor gambar berbasis kanvas. Jika Anda tidak ingin menulis editor kanvas sendiri, Harmony adalah salah satu dari sedikit editor kanvas yang tersedia secara terbuka. Aplikasi ini dilengkapi dengan penambahan kuas yang mudah, yang dapat memuaskan selera artistik Anda. Saat Anda memilih "edit image" di menu yang diilustrasikan di atas, editor kanvas akan terbuka, dan akan melakukan panggilan ke fungsi read_file() kustom dalam fungsi init() editor sebagai berikut:

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

Menambahkan LocalStorage HTML5

Sedikit sentuhan yang harus selalu Anda pertimbangkan--jika Anda peduli dengan pengalaman pengguna--adalah menerapkan LocalStorage. Misalnya, jika Anda memiliki area teks besar yang mengharuskan pengguna memasukkan banyak informasi. Saat pengguna akan mengirimkan formulir, ia tidak sengaja menutup browser (atau browser mengalami error). Pengguna mungkin merasa frustrasi dan tidak repot menulis ulang pesan lagi. Dalam demo di bawah, simpan gambar ke LocalStorage sebagai URI data, bukan menyimpan data ke server:

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

Menyimpan kanvas sebagai file biner ke server

Sebaiknya simpan gambar kanvas sebagai file biner. Ada banyak cara untuk melakukannya. Misalnya, Anda dapat melakukan tindakan POST untuk meneruskan URI data ke kode backend. Dengan jQuery, tampilannya akan terlihat seperti ini:

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

Tindakan ini akan membuat panggilan XHR dengan konten berupa URI data. Kemudian, Anda perlu mendekode URI data base64 di server. Di PHP, misalnya, Anda dapat melakukan hal berikut:

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
}

Pada dua baris pertama, URI data ($contents) dibagi menjadi dua bagian. 'data:image/png;base64', dan 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' Kemudian, kita akan menggunakan base64_decode() untuk mendekode string URI data. Triknya di sini adalah ada masalah dalam mendekode string yang lebih besar dari 5K, dan pendekatan "bagi dan taklukkan" ini akan dapat mendekode string. Terakhir, menggunakan fwrite(), Anda dapat menyimpan file biner, $contents, ke server.

Mengaktifkan "simpan gambar" di browser

Kanvas adalah elemen HTML. Tampilannya hampir seperti gambar, tetapi browser Anda tidak menyediakan opsi "Simpan Gambar Sebagai" untuknya karena sebenarnya bukan elemen gambar. Untuk mengaktifkan "Save Image As", Anda dapat membuat elemen Img secara dinamis, dan menetapkan src ke URI data elemen kanvas. Anda juga dapat menggunakan utilitas canvas2image.

Editor kanvas yang lebih canggih

Jika Anda mencari editor kanvas yang lebih canggih, PaintWeb mungkin patut dicoba. Aplikasi ini ditulis oleh Mihai Sucan, seorang mahasiswa Rumania, selama Google Summer of Code 2009. Ia juga menulis beberapa tutorial tentang cara menulis aplikasi gambar online Anda sendiri.

Paint Web

Untuk library yang lebih profesional, pastikan untuk melihat Pixati.

Lebih menyenangkan dengan kanvas?

Paul Irish menggabungkan Harmony dan Pengenal Unistroke $1 untuk membuat sedikit Telur Paskah di situsnya.

Anda juga dapat mempelajari cara memeriksa kanvas dengan Chrome DevTools menggunakan fitur inspeksi terbaru kami.

Pelajari lebih dalam dengan tutorial tambahan di kanvas