आपके वेब ऐप्लिकेशन में कैनवस को इंटिग्रेट करना

डेविड टॉन्ग
डेविड टॉन्ग

शुरुआती जानकारी

इस लेख में, इमेज बनाने, उनमें बदलाव करने, उन्हें खोलने, और एक्सपोर्ट करने के लिए, 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 कॉन्टेक्स्ट पाएं. इससे हमें उस API का ऐक्सेस मिलता है जो ड्रॉइंग के सभी तरीकों और प्रॉपर्टी के बारे में बताता है. इसके बाद, हम एक इमेज ऑब्जेक्ट बनाते हैं और 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() का इस्तेमाल करेंगे. सबसे अहम बात यह है कि 5K से बड़ी स्ट्रिंग को डिकोड करने में समस्याएं आ रही हैं. ऐसे में, "बातें-और-जीतना" वाले तरीके से स्ट्रिंग को डिकोड किया जा सकता है. आखिर में, fwrite() का इस्तेमाल करके, आप बाइनरी फ़ाइल, $contents को अपने सर्वर पर सेव कर सकते हैं.

ब्राउज़र में "इमेज सेव करें" सुविधा चालू करना

कैनवस एक एचटीएमएल एलिमेंट है. यह काफ़ी हद तक किसी इमेज की तरह दिखता है, लेकिन आपका ब्राउज़र इसके लिए "इस रूप में इमेज सेव करें" विकल्प उपलब्ध नहीं कराता. ऐसा इसलिए, क्योंकि यह असल में कोई इमेज एलिमेंट नहीं है. "इमेज को इस रूप में सेव करें" को चालू करने के लिए, डाइनैमिक तौर पर एक इमेज एलिमेंट बनाया जा सकता है और src को कैनवस एलिमेंट के डेटा यूआरआई पर सेट किया जा सकता है. canvas2image यूटिलिटी का भी इस्तेमाल किया जा सकता है.

ज़्यादा बेहतर कैनवस एडिटर

अगर आपको ज़्यादा बेहतर कैनवस एडिटर चाहिए, तो PaintWeb को आज़माना सही है. इसे रोमानिया के छात्र मिहाई सुकान ने Google समर ऑफ़ कोड 2009 के दौरान लिखा था. उन्होंने खुद का ऑनलाइन पेंट ऐप्लिकेशन लिखने के लिए कुछ ट्यूटोरियल भी तैयार किए हैं.

वेब पेंट करें

ज़्यादा पेशेवर लाइब्रेरी के लिए, Pixati पर जाएं.

क्या कैनवस का इस्तेमाल और भी मज़ेदार हो गया है?

पॉल आयरिश ने अपनी वेबसाइट पर एक छोटा ईस्टर एग बनाने के लिए, Harmony और $1 Uni सेवाएं रिकग्नर को जोड़ा है.

Chrome DevTools की मदद से कैनवस की जांच करने का तरीका जानने के लिए, हाल ही में उपलब्ध जांच से जुड़ी सुविधाओं का इस्तेमाल करें.

कैनवस पर अतिरिक्त ट्यूटोरियल की मदद से ज़्यादा जानकारी पाएं