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 {i>open-source<i} yang relevan dengan teknologi ini, dan memberikan beberapa tips tentang bagaimana teknik-teknik ini dapat diterapkan ke aplikasi web yang sudah 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 data atau biner

Pertama, Anda harus memiliki elemen kanvas di laman Anda. 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 bisa menggunakan URI data sebagai ganti URL gambar. Jadi, daripada menggunakan URL di atas, Anda dapat melakukan hal berikut:

img.src=""

Anda mungkin bertanya, "Mengapa kita menggunakan URI data alih-alih gambar biner?" Ada banyak kelebihan. Dan nanti dalam artikel ini, Anda akan melihat betapa mudahnya kami dapat mengekspor gambar kanvas sebagai URI data. Berikut adalah alat untuk mengonversi file gambar biner ke URI data.

Memanipulasi gambar kanvas

Jika Anda pernah melakukan pemrograman Logo, menggambar di kanvas menggunakan konsep yang sama. Mark Pilgrim memiliki bab di kanvas dalam bukunya, Dive Into HTML5. Berdasarkan contoh di bab ini, kita dapat menambahkan diagram grid ke gambar yang telah kita impor di atas dengan menggunakan hal 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 bisa lebih kreatif daripada ini, tetapi saya serahkan tutorial lain yang tercantum dalam lampiran artikel ini untuk petunjuk tambahan tentang subjek tersebut. Kami 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 kita gunakan di atas.

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

Tindakan ini akan mengekspor kanvas sebagai gambar PNG ke jendela browser baru. Namun, gambar bukan image biner biasa, melainkan URI data berenkode base64 yang dapat dirender oleh browser. Jadi, dari sudut pandang pengguna, tidak ada perbedaan antara hal tersebut dan padanan 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

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

Kanvas kotak

Misalnya, kami 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 beberapa editor kanvas yang tersedia secara terbuka. Fitur ini menampilkan penambahan kuas yang mudah, yang dapat memuaskan selera artistikmu. Jika Anda memilih "edit gambar" pada menu yang diilustrasikan di atas, editor kanvas akan terbuka, dan editor 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 perbaikan yang harus selalu Anda pertimbangkan--jika Anda peduli dengan pengalaman pengguna--adalah menerapkan LocalStorage. Misalnya, jika Anda memiliki area teks besar yang mengharuskan pengguna untuk memasukkan banyak informasi. Saat akan mengirimkan formulir, pengguna tidak sengaja menutup browser (atau browser tidak bekerja). Pengguna mungkin akan frustrasi dan tidak perlu repot-repot menulis ulang pesan. Dalam demo di bawah ini, sebagai ganti menyimpan data ke server, cukup simpan gambar ke LocalStorage sebagai URI data:

// 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

Anda mungkin ingin menyimpan gambar kanvas sebagai file biner. Ada banyak cara untuk melakukannya. Misalnya, Anda dapat melakukan tindakan POST untuk meneruskan URI data ke kode backend. Menggunakan jQuery, kodenya 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');

Ini akan membuat panggilan XHR dengan konten yang menjadi URI data. Anda kemudian perlu mendekode URI data base64 di server. Misalnya, di PHP, 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
}

Dalam dua baris pertama, URI data ($contents) dipecah menjadi dua bagian. 'data:image/png;base64', dan 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' Kita kemudian akan menggunakan base64_decode() untuk mendekode string URI data. Triknya di sini adalah ada masalah yang mendekode string yang lebih besar dari 5K, dan pendekatan "divide-and-conquer" ini akan dapat mendekode string. Terakhir, dengan menggunakan fwrite(), Anda dapat menyimpan file biner, $contents, ke server Anda.

Mengaktifkan "simpan gambar" di browser

{i>Canvas<i} adalah elemen HTML. Gambar ini sangat mirip dengan gambar, namun browser tidak menyediakan opsi "Save Image As" untuk gambar tersebut karena itu 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 kanvas2image.

Editor kanvas yang lebih canggih

Jika Anda mencari editor kanvas yang lebih canggih, PaintWeb mungkin patut dicoba. Buku ini ditulis oleh Mihai Sucan, seorang mahasiswa Rumania, selama Google Summer of Code 2009. Ia juga menulis beberapa tutorial untuk menulis aplikasi melukis secara online.

Menggambar Web

Untuk perpustakaan yang lebih profesional, pastikan untuk memeriksa Pixati.

Lebih menyenangkan dengan kanvas?

Paul Irlandia menggabungkan Harmony dan Recognizer Unistroke dengan harga $1 untuk membuat Telur Paskah kecil di situsnya.

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

Pelajari lebih dalam dengan tutorial tambahan di kanvas