আপনার ওয়েব অ্যাপে ক্যানভাস একীভূত করা

ভূমিকা

এই নিবন্ধে, আমি কীভাবে ছবি তৈরি, সম্পাদনা, খুলতে এবং রপ্তানি করতে 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.
}

একটি ক্যানভাস উপাদান তৈরি করা এবং বাইনারি বা ডেটা URI হিসাবে একটি চিত্র আমদানি করা

প্রথমত, আপনার পৃষ্ঠায় একটি ক্যানভাস উপাদান থাকতে হবে। জাভাস্ক্রিপ্ট ব্যবহার করে, আপনি নিম্নলিখিতগুলি করেন:

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() পদ্ধতি ব্যবহার করি। আপনি একটি ছবির URL এর পরিবর্তে একটি ডেটা URI ব্যবহার করতে পারেন। সুতরাং উপরের URL এর পরিবর্তে, আপনি নিম্নলিখিতগুলি করতে পারেন:

img.src=""

আপনি জিজ্ঞাসা করতে পারেন, "কেন আমরা বাইনারি চিত্রের পরিবর্তে ডেটা URI ব্যবহার করব?" অনেক সুবিধা আছে। এবং পরে এই নিবন্ধে, আপনি দেখতে পাবেন যে আমরা কত সহজে একটি ক্যানভাস ইমেজ ডেটা URI হিসাবে রপ্তানি করতে পারি। একটি বাইনারি ইমেজ ফাইলকে ডেটা URI-তে রূপান্তর করার জন্য এখানে একটি টুল রয়েছে।

ক্যানভাস ইমেজ হেরফের

আপনি যদি কখনো কোনো ধরনের লোগো প্রোগ্রামিং করে থাকেন, তাহলে ক্যানভাসে আঁকা একই ধারণা ব্যবহার করে। মার্ক পিলগ্রিম তার বই, ডাইভ ইনটু 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";

আপনি এটির চেয়ে আরও বেশি সৃজনশীল হতে পারেন, তবে আমি এই বিষয়ে অতিরিক্ত নির্দেশাবলীর জন্য এই নিবন্ধের পরিশিষ্টে তালিকাভুক্ত অন্যান্য টিউটোরিয়ালগুলিতে এটি ছেড়ে দিচ্ছি। আমরা এখনও খুব উত্তেজনাপূর্ণ কিছু দেখিনি, তবে পরবর্তী বিভাগটি এটি পরিবর্তন করবে।

ডেটা URI হিসাবে ক্যানভাস ছবি রপ্তানি করা হচ্ছে

ক্যানভাস উপাদানটিতে একটি toDataURL() পদ্ধতি রয়েছে, যা একটি MIME প্রকারকে প্যারামিটার হিসাবে নেয়৷ এটির মাধ্যমে, আমরা উপরে যে ক্যানভাস ব্যবহার করেছি তা রপ্তানি করতে পারি।

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

এটি একটি নতুন ব্রাউজার উইন্ডোতে একটি PNG চিত্র হিসাবে ক্যানভাস রপ্তানি করে৷ চিত্রটি, যাইহোক, একটি সাধারণ বাইনারি চিত্র নয়, বরং এটি একটি বেস64-এনকোডেড ডেটা URI যা একটি ব্রাউজার দ্বারা রেন্ডার করা যেতে পারে। সুতরাং, ব্যবহারকারীর দৃষ্টিকোণ থেকে, এটি এবং বাইনারি সমতুল্যের মধ্যে কোন পার্থক্য নেই। মনে রাখবেন যে উপরের কোডের লাইনটি একটি ওয়েব সার্ভারে চালানো দরকার। একটি স্থানীয় ফাইলে toDataURL() চালানো ব্যর্থ হবে। Chrome-এ এই সমস্যার স্থিতির জন্য এই টিকিটটি দেখুন।

আপনার ওয়েব অ্যাপে একীভূত হচ্ছে

ব্যবহারকারীর আপলোড করা ছবি সঞ্চয় করে এমন যেকোনো ওয়েব অ্যাপ্লিকেশনের জন্য ক্যানভাস একটি অত্যন্ত শক্তিশালী অ্যাড-অন হতে পারে।

বক্স ক্যানভাস

উদাহরণস্বরূপ, আমাদের কাছে একটি অনলাইন ফাইল স্টোরেজ অ্যাপ্লিকেশন রয়েছে যা ব্যবহারকারীর আপলোড করা ছবি সংরক্ষণ করে। ক্যানভাস-ভিত্তিক ছবি এডিটরে ইমেজ ফাইল খুলতে আমরা একটি সম্পাদনা বোতাম যোগ করতে পারি। আপনি যদি নিজের ক্যানভাস সম্পাদক লিখতে না চান, হারমনি হল প্রকাশ্যে উপলব্ধ কয়েকটি ক্যানভাস সম্পাদকের মধ্যে একটি। এটিতে ব্রাশের সহজ সংযোজন বৈশিষ্ট্য রয়েছে, যা আপনার শৈল্পিক স্বাদকে সন্তুষ্ট করতে পারে। আপনি যখন উপরে চিত্রিত মেনুতে "চিত্র সম্পাদনা করুন" চয়ন করেন, তখন একটি ক্যানভাস সম্পাদক খুলতে হবে এবং এটি সম্পাদকের 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-এ ডেটা URI হিসাবে সংরক্ষণ করুন:

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

সার্ভারে একটি বাইনারি ফাইল হিসাবে ক্যানভাস সংরক্ষণ করা হচ্ছে

আপনি একটি বাইনারি ফাইল হিসাবে ক্যানভাস ইমেজ সংরক্ষণ করতে চাইতে পারেন. এটা করার অনেক উপায় আছে। উদাহরণস্বরূপ, আপনি আপনার ব্যাকএন্ড কোডে ডেটা URI পাস করার জন্য একটি POST অ্যাকশন সঞ্চালন করতে পারেন। 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 কল তৈরি করে যার বিষয়বস্তু হল ডেটা URI। তারপর আপনাকে সার্ভারে base64 ডেটা URI ডিকোড করতে হবে। পিএইচপি- তে, উদাহরণস্বরূপ, আপনি নিম্নলিখিতগুলি করতে পারেন:

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
}

প্রথম দুটি লাইনে, ডেটা URI ($contents) দুটি অংশে বিভক্ত। 'data:image/png;base64' , এবং 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' তারপর আমরা ডেটা URI স্ট্রিং ডিকোড করতে base64_decode() ব্যবহার করব। এখানে কৌশলটি হল যে 5K এর চেয়ে বেশি স্ট্রিং ডিকোডিং সমস্যা রয়েছে এবং এই "বিভাজন-এন্ড-জয়" পদ্ধতিটি স্ট্রিংটিকে ডিকোড করতে সক্ষম হবে৷ অবশেষে, fwrite() ব্যবহার করে, আপনি বাইনারি ফাইল, $contents, আপনার সার্ভারে সংরক্ষণ করতে পারেন।

ব্রাউজারে "ছবি সংরক্ষণ করুন" সক্ষম করা হচ্ছে

ক্যানভাস একটি HTML উপাদান। এটি দেখতে অনেকটা একটি ছবির মতো, কিন্তু আপনার ব্রাউজার এটির জন্য "ছবি সংরক্ষণ করুন" বিকল্প প্রদান করে না কারণ এটি সত্যিই একটি চিত্র উপাদান নয়। "ছবি সংরক্ষণ করুন" সক্ষম করতে আপনি গতিশীলভাবে একটি Img উপাদান তৈরি করতে পারেন এবং ক্যানভাস উপাদানের ডেটা URI-তে src সেট করতে পারেন৷ আপনি canvas2image ইউটিলিটিও ব্যবহার করতে পারেন।

আরও উন্নত ক্যানভাস সম্পাদক

আপনি যদি আরও উন্নত ক্যানভাস সম্পাদক খুঁজছেন, PaintWeb সম্ভবত চেষ্টা করার মতো। এটি লিখেছিলেন মিহাই সুকান, একজন রোমানিয়ান ছাত্র, গুগল সামার অফ কোড 2009 এর সময়। তিনি আপনার নিজের অনলাইন পেইন্ট অ্যাপ্লিকেশন লেখার জন্য কয়েকটি টিউটোরিয়ালও লিখেছেন।

পেইন্ট ওয়েব

আরও পেশাদার লাইব্রেরির জন্য, Pixati চেক আউট করতে ভুলবেন না।

ক্যানভাসের সাথে আরও মজা?

পল আইরিশ তার ওয়েবসাইটে একটি ছোট্ট ইস্টার ডিম তৈরি করতে হারমনি এবং $1 ইউনিস্ট্রোক রিকগনিজারকে একত্রিত করেছেন।

এছাড়াও আপনি আমাদের সাম্প্রতিক পরিদর্শন বৈশিষ্ট্যগুলি ব্যবহার করে Chrome DevTools দিয়ে কীভাবে ক্যানভাস পরিদর্শন করবেন তা শিখতে পারেন৷

ক্যানভাসে অতিরিক্ত টিউটোরিয়াল সহ আরও গভীরে যান