परिचय
इस लेख में, हम इमेज बनाने, उनमें बदलाव करने, उन्हें खोलने, और एक्सपोर्ट करने के लिए, HTML5 कैनवस एलिमेंट का इस्तेमाल करने का तरीका बताएंगे. इस दौरान, मैं इस टेक्नोलॉजी से जुड़े कई ओपन-सोर्स टूल भी पेश करूंगा. साथ ही, इन तकनीकों को किसी मौजूदा वेब ऐप्लिकेशन पर लागू करने के बारे में कुछ सलाह भी दूंगा.
कैनवस के साथ काम करने की सुविधा देखना
सबसे पहले, यह देखें कि आपका ब्राउज़र पूरी तरह से HTML5 कैनवस के साथ काम करता है या नहीं. किसी सुविधा की जांच करने के लिए, Modernizr का इस्तेमाल करना सबसे आसान तरीका है:
if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}
कैनवस एलिमेंट बनाना और किसी इमेज को बाइनरी या डेटा यूआरआई के तौर पर इंपोर्ट करना
सबसे पहले, आपको अपने पेज में कैनवस एलिमेंट जोड़ना होगा. JavaScript का इस्तेमाल करके, ये काम किए जा सकते हैं:
var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}
इस कोड में, पहला चरण 2D कॉन्टेक्स्ट पाना है. इससे हमें उस एपीआई का ऐक्सेस मिलता है जो ड्रॉइंग के सभी तरीकों और प्रॉपर्टी के बारे में बताता है. इसके बाद, हम एक इमेज ऑब्जेक्ट बनाते हैं और src प्रॉपर्टी को बाइनरी इमेज की जगह पर सेट करते हैं. इमेज लोड होने के बाद, हम इमेज को कैनवस एलिमेंट में इंपोर्ट करने के लिए, drawImage() तरीके का इस्तेमाल करते हैं. इमेज के यूआरएल के बजाय, डेटा यूआरआई का भी इस्तेमाल किया जा सकता है. इसलिए, ऊपर दिए गए यूआरएल के बजाय, ये काम किए जा सकते हैं:
img.src=""
आपके मन में यह सवाल आ सकता है कि "हम बाइनरी इमेज के बजाय, डेटा यूआरआई का इस्तेमाल क्यों करें?" इसके कई फ़ायदे हैं. इस लेख में आगे, आपको यह भी पता चलेगा कि कैनवस इमेज को डेटा यूआरआई के तौर पर आसानी से कैसे एक्सपोर्ट किया जा सकता है. यहां बाइनरी इमेज फ़ाइल को डेटा यूआरआई में बदलने वाला टूल दिया गया है.
कैनवस इमेज में बदलाव करना
अगर आपने कभी किसी तरह की लोगो प्रोग्रामिंग की है, तो कैनवस पर ड्रॉ करने के लिए भी यही कॉन्सेप्ट इस्तेमाल किया जाता है. मार्क पिलग्रिम की किताब, Dive Into HTML5 में कैनवस के बारे में एक चैप्टर है. चैप्टर में दिए गए उदाहरण के आधार पर, ऊपर इंपोर्ट की गई इमेज में ग्रिड डायग्राम जोड़ा जा सकता है. इसके लिए, इनका इस्तेमाल करें:.
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";
आपके पास इससे ज़्यादा क्रिएटिव होने का विकल्प है. हालांकि, इस विषय के बारे में ज़्यादा निर्देश पाने के लिए, इस लेख के ऐपेंडिक्स में दिए गए अन्य ट्यूटोरियल देखें. हमने अब तक कुछ खास नहीं देखा है, लेकिन अगले सेक्शन में आपको कुछ दिलचस्प जानकारी मिलेगी.
कैनवस इमेज को डेटा यूआरआई के तौर पर एक्सपोर्ट करना
कैनवस एलिमेंट में toDataURL() तरीका होता है, जो पैरामीटर के तौर पर MIME टाइप लेता है. इसकी मदद से, हम ऊपर इस्तेमाल किए गए कैनवस को एक्सपोर्ट कर सकते हैं. 
window.open(document.getElementById('ctx').toDataURL("image/png"));
इससे कैनवस, नई ब्राउज़र विंडो में PNG इमेज के तौर पर एक्सपोर्ट हो जाता है. हालांकि, यह इमेज कोई सामान्य बाइनरी इमेज नहीं है, बल्कि यह Base64-एन्कोड किया गया डेटा यूआरआई है. इसे ब्राउज़र से रेंडर किया जा सकता है. इसलिए, उपयोगकर्ता के हिसाब से, दोनों के बीच कोई अंतर नहीं है. 
ध्यान दें कि ऊपर दी गई कोड लाइन को वेब सर्वर पर चलाया जाना चाहिए. किसी लोकल फ़ाइल पर toDataURL() चलाने पर, गड़बड़ी का मैसेज दिखेगा. Chrome में इस समस्या की स्थिति जानने के लिए, यह टिकट देखें. 
अपने वेब ऐप्लिकेशन में इंटिग्रेट करना
कैनवस, उन सभी वेब ऐप्लिकेशन के लिए एक बेहतरीन ऐड-ऑन हो सकता है जो उपयोगकर्ताओं की अपलोड की गई इमेज को सेव करते हैं.
उदाहरण के लिए, हमारे पास एक ऑनलाइन फ़ाइल स्टोरेज ऐप्लिकेशन है, जो उपयोगकर्ताओं की अपलोड की गई इमेज को सेव करता है. हम इमेज फ़ाइल को कैनवस पर आधारित पिक्चर एडिटर में खोलने के लिए, 'बदलाव करें' बटन जोड़ सकते हैं. 
अगर आपको अपना कैनवस एडिटर नहीं लिखना है, तो Harmony उन कुछ कैनवस एडिटर में से एक है जो सार्वजनिक तौर पर उपलब्ध है. इसमें ब्रश आसानी से जोड़े जा सकते हैं, ताकि आप अपनी पसंद के मुताबिक आर्टवर्क बना सकें. 
ऊपर दिए गए मेन्यू में "इमेज में बदलाव करें" चुनने पर, कैनवस एडिटर खुल जाएगा. यह एडिटर के init() फ़ंक्शन में कस्टम read_file() फ़ंक्शन को कॉल करेगा. ऐसा करने का तरीका यहां बताया गया है: 
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 जोड़ना
अगर आपको उपयोगकर्ता अनुभव को बेहतर बनाना है, तो आपको LocalStorage का इस्तेमाल करना चाहिए. उदाहरण के लिए, अगर आपके पास एक बड़ा टेक्स्ट एरिया है, जिसमें उपयोगकर्ता को बहुत सारी जानकारी डालनी पड़ती है. जब उपयोगकर्ता फ़ॉर्म सबमिट करने वाला होता है, तब वह गलती से ब्राउज़र बंद कर देता है या ब्राउज़र क्रैश हो जाता है. ऐसा हो सकता है कि उपयोगकर्ता परेशान हो जाए और वह मैसेज फिर से न लिखे. नीचे दिए गए डेमो में, डेटा को सर्वर पर सेव करने के बजाय, इमेज को डेटा यूआरआई के तौर पर LocalStorage में सेव किया गया है:
// 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');
        }
//...
}
कैनवस को सर्वर पर बाइनरी फ़ाइल के तौर पर सेव करना
कैनवस इमेज को बाइनरी फ़ाइल के तौर पर सेव किया जा सकता है. ऐसा करने के कई तरीके हैं. उदाहरण के लिए, अपने बैकएंड कोड में डेटा यूआरआई पास करने के लिए, पोस्ट ऐक्शन किया जा सकता है. jQuery का इस्तेमाल करके, यह इस तरह दिखेगा:
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');
इससे, डेटा यूआरआई वाले कॉन्टेंट के साथ XHR कॉल बनता है. इसके बाद, आपको सर्वर पर base64 डेटा यूआरआई को डिकोड करना होगा. उदाहरण के लिए, PHP में ये काम किए जा सकते हैं:
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
}
पहली दो लाइनों में, डेटा यूआरआई ($contents) को दो हिस्सों में बांटा गया है. 'data:image/png;base64' और 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...'. इसके बाद, हम डेटा यूआरआई स्ट्रिंग को डिकोड करने के लिए base64_decode() का इस्तेमाल करेंगे. यहां ध्यान देने वाली बात यह है कि 5 हज़ार से ज़्यादा वर्णों वाली स्ट्रिंग को डिकोड करने में समस्याएं आती हैं. हालांकि, "अलग-अलग हिस्सों में बांटकर हल करना" वाला यह तरीका, स्ट्रिंग को डिकोड कर सकता है. 
आखिर में, fwrite() का इस्तेमाल करके, बाइनरी फ़ाइल, $contents को अपने सर्वर पर सेव किया जा सकता है. 
ब्राउज़र में "इमेज सेव करें" सुविधा चालू करना
कैनवस एक एचटीएमएल एलिमेंट है. यह इमेज की तरह दिखती है, लेकिन आपका ब्राउज़र इसके लिए "इमेज को इस नाम से सेव करें" विकल्प नहीं देता, क्योंकि यह असल में इमेज एलिमेंट नहीं है. "इमेज को इस नाम से सेव करें" सुविधा चालू करने के लिए, डाइनैमिक तौर पर कोई Img एलिमेंट बनाया जा सकता है. साथ ही, src को कैनवस एलिमेंट के डेटा यूआरआई पर सेट किया जा सकता है. canvas2image टूल का इस्तेमाल भी किया जा सकता है.
ज़्यादा बेहतर कैनवस एडिटर
अगर आपको कैनवस एडिटर की ज़्यादा बेहतर सुविधाएं चाहिए, तो PaintWeb आज़माएं. इसे रोमानिया के छात्र, माइकल सुकन ने Google Summer of Code 2009 के दौरान लिखा था. उन्होंने ऑनलाइन पेंट ऐप्लिकेशन लिखने के बारे में कुछ ट्यूटोरियल भी लिखे हैं.
ज़्यादा प्रोफ़ेशनल लाइब्रेरी के लिए, Pixati देखें.
क्या कैनवस की मदद से और भी मज़ेदार चीज़ें की जा सकती हैं?
पॉल आयरिश ने अपनी वेबसाइट पर एक छोटा सा ईस्टर एग बनाने के लिए, Harmony और $1 Unistroke Recognizer को जोड़ा.
जांच करने की हमारी नई सुविधाओं का इस्तेमाल करके, Chrome DevTools की मदद से कैनवस की जांच करने का तरीका भी सीखा जा सकता है.
कैनवस के बारे में ज़्यादा जानने के लिए, अन्य ट्यूटोरियल देखें
- MDN: कैनवस ट्यूटोरियल
 - HTML5: कैनवस के बारे में जानकारी
 - Dev.Opera पर HTML5 कैनवस - बुनियादी बातें में, ड्रॉइंग के बुनियादी प्राइमिटिव के बारे में बताया गया है
 - कैनवस में Breakout का क्लोन बनाना: इसमें बुनियादी मोशन, फ़िज़िक्स, और इंटरैक्टिविटी शामिल है