Giriş
Bu makalede, resim oluşturmak, düzenlemek, açmak ve dışa aktarmak için HTML5 tuval öğesinin nasıl kullanılacağı ele alınacaktır. Ayrıca bu teknolojiyle alakalı çeşitli açık kaynak araçları tanıtacak ve bu tekniklerin mevcut bir web uygulamasına nasıl uygulanabileceğiyle ilgili bazı ipuçları vereceğim.
Kanvas desteği olup olmadığını kontrol etme
İlk olarak, tarayıcınızın HTML5 kanvası'nı tam olarak destekleyip desteklemediğini kontrol edin. Bunu yapmanın kolay bir yolu, belirli bir özelliği kontrol etmek için Modernizr'i kullanmaktır:
if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}
Bir kanvas öğesi oluşturma ve bir resmi ikili veya veri URI'si olarak içe aktarma
Öncelikle sayfanızda bir kanvas öğenizin olması gerekir. JavaScript'i kullanarak şunları yapabilirsiniz:
var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}
Bu kodda ilk adım, tüm çizim yöntemlerini ve özelliklerini tanımlayan API'ye erişim sağlayan 2D bağlamı elde etmektir. Ardından, bir resim nesnesi oluşturup src mülkünü ikili resmin konumuna ayarlarız. Resim yüklendiğinde, drawImage() yöntemini kullanarak resmi kanvas öğesine aktarırız. Bir resmin URL'si yerine veri URI'si de kullanabilirsiniz. Bu nedenle, yukarıdaki URL yerine aşağıdakileri yapabilirsiniz:
img.src=""
"İkilik resim yerine neden veri URI'sini kullanalım?" diye sorabilirsiniz. Bunun birçok avantajı vardır. Bu makalenin ilerleyen bölümlerinde, kanvas resmini veri URI'si olarak nasıl kolayca dışa aktarabileceğimizi göreceksiniz. İkili resim dosyasını veri URI'sine dönüştüren bir araç aşağıda verilmiştir.
Kanvas resmini değiştirme
Daha önce herhangi bir tür Logo programlama yaptıysanız kanvas üzerinde çizim yapmak için de aynı kavramı kullanırsınız. Mark Pilgrim'in Dive Into HTML5 adlı kitabında tuval hakkında bir bölüm vardır. Bölümdeki bir örneğe dayanarak, yukarıda içe aktardığımız resme aşağıdakileri kullanarak bir ızgara şeması ekleyebiliriz:
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";
Bundan daha yaratıcı olabilirsiniz ancak bu konuyla ilgili ek talimatlar için bu makalenin ekinde listelenen diğer eğitici içeriklere göz atabilirsiniz. Henüz çok heyecan verici bir şey görmedik ancak bunu bir sonraki bölümde değiştireceğiz.
Kanvas resmini veri URI'si olarak dışa aktarma
Tuval öğesinde, parametre olarak MIME türü alan bir toDataURL() yöntemi vardır. Böylece, yukarıda kullandığımız kanvası dışa aktarabiliriz. 
window.open(document.getElementById('ctx').toDataURL("image/png"));
Bu işlem, kanvası yeni bir tarayıcı penceresine PNG resmi olarak aktarır. Ancak bu resim, sıradan bir ikili resim değil, tarayıcı tarafından oluşturulabilen base64 kodlu bir veri URI'sidir. Bu nedenle, kullanıcı açısından bu yöntemle ikili eşdeğeri arasında fark yoktur. 
Yukarıdaki kod satırının bir web sunucusunda çalıştırılması gerektiğini unutmayın. toDataURL(), yerel bir dosyada çalıştırıldığında başarısız olur. Chrome'daki bu sorunun durumu için bu kaydı inceleyin. 
Web uygulamanıza entegre etme
Tuval, kullanıcı tarafından yüklenen resimleri depolayan tüm web uygulamaları için çok güçlü bir eklenti olabilir.
Örneğin, kullanıcıların yüklediği resimleri depolayan bir online dosya depolama uygulamamız var. Resim dosyasını kanvas tabanlı bir resim düzenleyicisinde açmak için bir düzenleme düğmesi ekleyebiliriz. 
Kendi kanvas düzenleyicinizi yazmak istemiyorsanız Harmony, herkese açık olarak kullanılabilen birkaç kanvas düzenleyicisinden biridir. Sanatsal zevkinize hitap edecek fırçaları kolayca ekleyebilirsiniz. 
Yukarıda gösterilen menüde "Resmi düzenle"yi seçtiğinizde bir kanvas düzenleyici açılır ve düzenleyicinin init() işlevinde aşağıdaki gibi özel bir read_file() işlevi çağrılır: 
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 ekleme
Kullanıcı deneyimine önem veriyorsanız her zaman göz önünde bulundurmanız gereken küçük bir dokunuş, LocalStorage'u uygulamaktır. Örneğin, kullanıcının çok fazla bilgi girmesini gerektiren büyük bir metin alanınız varsa. Kullanıcı formu göndermek üzereyken yanlışlıkla tarayıcıyı kapatır (veya tarayıcı kilitlenir). Kullanıcı, bu durumdan rahatsız olabilir ve mesajı yeniden yazmak istemeyebilir. Aşağıdaki demoda, verileri sunucuya kaydetmek yerine resmi LocalStorage'a veri URI'si olarak kaydedebilirsiniz:
// 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');
        }
//...
}
Kanvası sunucuya ikili dosya olarak kaydetme
Kanvas resmini ikili dosya olarak kaydedebilirsiniz. Bunu yapmanın birçok yolu vardır. Örneğin, veri URI'sini arka uç kodunuza iletmek için bir POST işlemi gerçekleştirebilirsiniz. jQuery kullanıldığında bu kod şöyle görünür:
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');
Bu işlem, içeriğin veri URI'si olduğu bir XHR çağrısı oluşturur. Ardından, sunucudaki base64 veri URI'sinin kodunu çözmeniz gerekir. Örneğin, PHP'de aşağıdakileri yapabilirsiniz:
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
}
İlk iki satırda veri URI'si ("contents") iki bölüme ayrılmıştır. 'data:image/png;base64' ve 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...'. Ardından, veri URI dizeninin kodunu çözmek için base64_decode()'yi kullanırız. Buradaki püf nokta, 5.000'den uzun dizelerin kodunu çözmeyle ilgili sorunlar olmasıdır. Bu "böl ve yönet" yaklaşımı, dizenin kodunu çözebilir. 
Son olarak, fwrite() işlevini kullanarak $contents adlı ikili dosyayı sunucunuza kaydedebilirsiniz. 
Tarayıcıda "Resmi kaydet" seçeneğini etkinleştirme
Tuval bir HTML öğesidir. Resme çok benziyor ancak gerçek bir resim öğesi olmadığı için tarayıcınız bunun için "Resmi Şu Adla Kaydet" seçeneği sunmuyor. "Resmi Şu Adla Kaydet"i etkinleştirmek için dinamik olarak bir Img öğesi oluşturabilir ve src özelliğini kanvas öğesinin veri URI'sine ayarlayabilirsiniz. canvas2image yardımcı programını da kullanabilirsiniz.
Daha gelişmiş bir kanvas düzenleyici
Daha gelişmiş bir kanvas düzenleyici arıyorsanız PaintWeb'i deneyebilirsiniz. Bu makale, Romanya'lı bir öğrenci olan Mihai Sucan tarafından Google Summer of Code 2009 sırasında yazılmıştır. Ayrıca, kendi online boyama uygulamanızı yazmayla ilgili birkaç eğitici içerik de hazırladı.
Daha profesyonel bir kitaplık için Pixati'ye göz atın.
Kanvasla daha eğlenceli mi?
Paul Irish, web sitesinde küçük bir Paskalya yumurtası oluşturmak için Harmony'u ve 1 ABD doları değerindeki Unistroke Tanımlayıcı'yı birleştirdi.
Ayrıca, yeni inceleme özelliklerimizi kullanarak Chrome Geliştirici Araçları ile kanvası nasıl inceleyeceğinizi de öğrenebilirsiniz.
Kanvasla ilgili ek eğitimlerle daha fazla bilgi edinin
- MDN: Canvas Eğitimi
 - HTML5'e dalın: Tuval
 - Dev.Opera'daki HTML5 kanvası - temel bilgiler, temel çizim primitiflerini kapsar.
 - Tuvalde Breakout klonu oluşturma temel hareket, fizik ve etkileşimi içerir