SVGcode হল একটি প্রগতিশীল ওয়েব অ্যাপ যা আপনাকে JPG, PNG, GIF, WebP, AVIF ইত্যাদি রাস্টার ছবিগুলিকে SVG ফর্ম্যাটে ভেক্টর গ্রাফিক্সে রূপান্তর করতে দেয়৷ এটি ফাইল সিস্টেম অ্যাক্সেস API, Async ক্লিপবোর্ড API, ফাইল হ্যান্ডলিং API, এবং উইন্ডো নিয়ন্ত্রণ ওভারলে কাস্টমাইজেশন ব্যবহার করে।
রাস্টার থেকে ভেক্টর পর্যন্ত
আপনি কি কখনও একটি ইমেজ স্কেল করেছেন এবং ফলাফলটি পিক্সেলেটেড এবং অসন্তোষজনক ছিল? যদি তাই হয়, আপনি সম্ভবত WebP, PNG, বা JPG এর মতো রাস্টার ইমেজ ফরম্যাট নিয়ে কাজ করেছেন।
বিপরীতে, ভেক্টর গ্রাফিক্স হল এমন চিত্র যা একটি স্থানাঙ্ক সিস্টেমের বিন্দু দ্বারা সংজ্ঞায়িত করা হয়। এই বিন্দুগুলি রেখা এবং বক্ররেখা দ্বারা সংযুক্ত হয়ে বহুভুজ এবং অন্যান্য আকার তৈরি করে। রাস্টার গ্রাফিক্সের তুলনায় ভেক্টর গ্রাফিক্সের একটি সুবিধা রয়েছে যেগুলি পিক্সেলেশন ছাড়াই যেকোন রেজোলিউশনে উপরে বা নিচের দিকে স্কেল করা যেতে পারে।
SVGcode প্রবর্তন করা হচ্ছে
আমি SVGcode নামে একটি PWA তৈরি করেছি যা আপনাকে রাস্টার চিত্রগুলিকে ভেক্টরে রূপান্তর করতে সহায়তা করতে পারে। ক্রেডিট যেখানে ক্রেডিট বকেয়া: আমি এটি উদ্ভাবন করিনি। SVGcode-এর সাহায্যে, আমি শুধু পিটার সেলিংগারের পোট্রেস নামক একটি কমান্ড লাইন টুলের কাঁধে দাঁড়িয়ে আছি যেটিকে আমি ওয়েব অ্যাসেম্বলিতে রূপান্তর করেছি , তাই এটি একটি ওয়েব অ্যাপে ব্যবহার করা যেতে পারে।
SVGcode ব্যবহার করে
প্রথমে, আমি আপনাকে দেখাতে চাই কিভাবে অ্যাপটি ব্যবহার করতে হয়। আমি ক্রোম ডেভ সামিটের টিজার ইমেজ দিয়ে শুরু করছি যা আমি ChromiumDev Twitter চ্যানেল থেকে ডাউনলোড করেছি। এটি একটি PNG রাস্টার চিত্র যা আমি তারপর SVGcode অ্যাপে টেনে আনব। যখন আমি ফাইলটি ড্রপ করি, ইনপুটের একটি ভেক্টরাইজড সংস্করণ উপস্থিত না হওয়া পর্যন্ত অ্যাপটি রঙের দ্বারা চিত্রের রঙকে ট্রেস করে। আমি এখন চিত্রটি জুম করতে পারি, এবং আপনি দেখতে পাচ্ছেন, প্রান্তগুলি তীক্ষ্ণ থাকে। কিন্তু ক্রোম লোগোতে জুম ইন করে, আপনি দেখতে পারেন যে ট্রেসিংটি নিখুঁত ছিল না এবং বিশেষ করে লোগোটির রূপরেখা কিছুটা দাগযুক্ত দেখায়। আমি পাঁচ পিক্সেল পর্যন্ত দাগ দমন করে ট্রেসিং ডি-স্পেকলিং করে ফলাফল উন্নত করতে পারি।
এসভিজিকোডে পোস্টারাইজেশন
ভেক্টরাইজেশনের জন্য একটি গুরুত্বপূর্ণ পদক্ষেপ, বিশেষ করে ফটোগ্রাফিক ছবির জন্য, রঙের সংখ্যা কমাতে ইনপুট ইমেজ পোস্টারাইজ করা। SVGcode আমাকে প্রতি রঙের চ্যানেলে এটি করতে দেয় এবং আমি পরিবর্তন করার সাথে সাথে ফলাফল SVG দেখতে পারি। যখন আমি ফলাফলে খুশি হই, আমি আমার হার্ড ডিস্কে SVG সংরক্ষণ করতে পারি এবং যেখানে খুশি ব্যবহার করতে পারি।
এসভিজিকোডে ব্যবহৃত API
এখন আপনি দেখেছেন যে অ্যাপটি কী সক্ষম, আমি আপনাকে এমন কিছু API দেখাই যা যাদুটি ঘটতে সহায়তা করে।
প্রগতিশীল ওয়েব অ্যাপ
SVGcode একটি ইনস্টলযোগ্য প্রগতিশীল ওয়েব অ্যাপ এবং তাই সম্পূর্ণ অফলাইন সক্ষম৷ অ্যাপটি Vite.js- এর জন্য ভ্যানিলা JS টেমপ্লেটের উপর ভিত্তি করে তৈরি এবং জনপ্রিয় Vite প্লাগইন PWA ব্যবহার করে, যা একটি পরিষেবা কর্মী তৈরি করে যা হুডের নিচে Workbox.js ব্যবহার করে। ওয়ার্কবক্স হল লাইব্রেরির একটি সেট যা প্রোগ্রেসিভ ওয়েব অ্যাপসের জন্য প্রোডাকশন-প্রস্তুত পরিষেবা কর্মীকে শক্তি দিতে পারে, এই প্যাটার্নটি অগত্যা সমস্ত অ্যাপের জন্য কাজ নাও করতে পারে, কিন্তু SVGcode-এর ব্যবহারের ক্ষেত্রে এটি দুর্দান্ত।
উইন্ডো নিয়ন্ত্রণ ওভারলে
উপলব্ধ স্ক্রীন রিয়েল এস্টেটকে সর্বাধিক করার জন্য, SVGcode এর প্রধান মেনুটিকে শিরোনামবার এলাকায় নিয়ে গিয়ে উইন্ডো কন্ট্রোল ওভারলে কাস্টমাইজেশন ব্যবহার করে। আপনি এটি ইনস্টল ফ্লো শেষে সক্রিয় হতে দেখতে পারেন।
ফাইল সিস্টেম অ্যাক্সেস API
ইনপুট ইমেজ ফাইল খুলতে এবং ফলস্বরূপ এসভিজি সংরক্ষণ করতে, আমি ফাইল সিস্টেম অ্যাক্সেস API ব্যবহার করি। এটি আমাকে পূর্বে খোলা ফাইলগুলির একটি রেফারেন্স রাখতে এবং একটি অ্যাপ পুনরায় লোড করার পরেও আমি যেখানে ছেড়েছি সেখানে চালিয়ে যেতে দেয়। যখনই একটি ছবি সংরক্ষণ করা হয়, এটি svgo লাইব্রেরির মাধ্যমে অপ্টিমাইজ করা হয়, যা SVG-এর জটিলতার উপর নির্ভর করে একটি মুহূর্ত সময় নিতে পারে। ফাইল সংরক্ষণ ডায়ালগ দেখানোর জন্য একটি ব্যবহারকারীর অঙ্গভঙ্গি প্রয়োজন। তাই এসভিজি অপ্টিমাইজেশান হওয়ার আগে ফাইল হ্যান্ডেলটি প্রাপ্ত করা গুরুত্বপূর্ণ, তাই অপ্টিমাইজ করা এসভিজি প্রস্তুত হওয়ার সময় ব্যবহারকারীর অঙ্গভঙ্গিটি অবৈধ হয়ে যায় না।
try {
let svg = svgOutput.innerHTML;
let handle = null;
// To not consume the user gesture obtain the handle before preparing the
// blob, which may take longer.
if (supported) {
handle = await showSaveFilePicker({
types: [{description: 'SVG file', accept: {'image/svg+xml': ['.svg']}}],
});
}
showToast(i18n.t('optimizingSVG'), Infinity);
svg = await optimizeSVG(svg);
showToast(i18n.t('savedSVG'));
const blob = new Blob([svg], {type: 'image/svg+xml'});
await fileSave(blob, {description: 'SVG file'}, handle);
} catch (err) {
console.error(err.name, err.message);
showToast(err.message);
}
টেনে আনুন
একটি ইনপুট ইমেজ খোলার জন্য, আমি হয় ফাইল ওপেন বৈশিষ্ট্যটি ব্যবহার করতে পারি, অথবা, যেমন আপনি উপরে দেখেছেন, শুধুমাত্র একটি ইমেজ ফাইল অ্যাপে টেনে আনুন এবং ড্রপ করুন। ফাইল খোলার বৈশিষ্ট্যটি বেশ সহজবোধ্য, আরও আকর্ষণীয় হল ড্র্যাগ এবং ড্রপ কেস। এটি সম্পর্কে বিশেষত চমৎকার যা হল যে আপনি getAsFileSystemHandle()
পদ্ধতির মাধ্যমে ডেটা স্থানান্তর আইটেম থেকে একটি ফাইল সিস্টেম হ্যান্ডেল পেতে পারেন। যেমন আগে উল্লেখ করা হয়েছে, আমি এই হ্যান্ডেলটি ধরে রাখতে পারি, তাই অ্যাপটি পুনরায় লোড হলে এটি প্রস্তুত।
document.addEventListener('drop', async (event) => {
event.preventDefault();
dropContainer.classList.remove('dropenter');
const item = event.dataTransfer.items[0];
if (item.kind === 'file') {
inputImage.addEventListener(
'load',
() => {
URL.revokeObjectURL(blobURL);
},
{once: true},
);
const handle = await item.getAsFileSystemHandle();
if (handle.kind !== 'file') {
return;
}
const file = await handle.getFile();
const blobURL = URL.createObjectURL(file);
inputImage.src = blobURL;
await set(FILE_HANDLE, handle);
}
});
আরও বিশদ বিবরণের জন্য, ফাইল সিস্টেম অ্যাক্সেস API- এর নিবন্ধটি দেখুন এবং, যদি আপনি আগ্রহী হন, src/js/filesystem.js
এ SVGcode সোর্স কোডটি অধ্যয়ন করুন।
Async ক্লিপবোর্ড API
Async ক্লিপবোর্ড API এর মাধ্যমে SVGcode অপারেটিং সিস্টেমের ক্লিপবোর্ডের সাথে সম্পূর্ণরূপে একত্রিত। আপনি অপারেটিং সিস্টেমের ফাইল এক্সপ্লোরার থেকে পেস্ট ইমেজ বোতামে ক্লিক করে বা আপনার কীবোর্ডে কমান্ড বা কন্ট্রোল প্লাস ভি টিপে অ্যাপে ছবি পেস্ট করতে পারেন।
Async ক্লিপবোর্ড API সম্প্রতি SVG চিত্রগুলির সাথেও মোকাবিলা করার ক্ষমতা অর্জন করেছে, তাই আপনি একটি SVG চিত্র অনুলিপি করতে এবং আরও প্রক্রিয়াকরণের জন্য এটিকে অন্য অ্যাপ্লিকেশনে পেস্ট করতে পারেন৷
copyButton.addEventListener('click', async () => {
let svg = svgOutput.innerHTML;
showToast(i18n.t('optimizingSVG'), Infinity);
svg = await optimizeSVG(svg);
const textBlob = new Blob([svg], {type: 'text/plain'});
const svgBlob = new Blob([svg], {type: 'image/svg+xml'});
navigator.clipboard.write([
new ClipboardItem({
[svgBlob.type]: svgBlob,
[textBlob.type]: textBlob,
}),
]);
showToast(i18n.t('copiedSVG'));
});
আরও জানতে, Async ক্লিপবোর্ড নিবন্ধটি পড়ুন, অথবা src/js/clipboard.js
ফাইলটি দেখুন।
ফাইল হ্যান্ডলিং
SVGcode এর আমার প্রিয় বৈশিষ্ট্যগুলির মধ্যে একটি হল এটি অপারেটিং সিস্টেমের সাথে কতটা ভালভাবে মিশে যায়। একটি ইনস্টল করা PWA হিসাবে, এটি ইমেজ ফাইলগুলির জন্য একটি ফাইল হ্যান্ডলার বা এমনকি ডিফল্ট ফাইল হ্যান্ডলার হতে পারে। এর মানে হল যে যখন আমি আমার macOS মেশিনে ফাইন্ডারে থাকি, তখন আমি একটি ছবিতে রাইট-ক্লিক করতে পারি এবং SVGcode দিয়ে খুলতে পারি। এই বৈশিষ্ট্যটিকে ফাইল হ্যান্ডলিং বলা হয় এবং এটি ওয়েব অ্যাপ ম্যানিফেস্ট এবং লঞ্চ সারিতে ফাইল_হ্যান্ডলার সম্পত্তির উপর ভিত্তি করে কাজ করে, যা অ্যাপটিকে পাস করা ফাইলটি ব্যবহার করতে দেয়।
window.launchQueue.setConsumer(async (launchParams) => {
if (!launchParams.files.length) {
return;
}
for (const handle of launchParams.files) {
const file = await handle.getFile();
if (file.type.startsWith('image/')) {
const blobURL = URL.createObjectURL(file);
inputImage.addEventListener(
'load',
() => {
URL.revokeObjectURL(blobURL);
},
{once: true},
);
inputImage.src = blobURL;
await set(FILE_HANDLE, handle);
return;
}
}
});
আরও তথ্যের জন্য, ইনস্টল করা ওয়েব অ্যাপ্লিকেশনগুলিকে ফাইল হ্যান্ডলার হতে দিন এবং src/js/filehandling.js
এ সোর্স কোড দেখুন।
ওয়েব শেয়ার (ফাইল)
অপারেটিং সিস্টেমের সাথে মিশে যাওয়ার আরেকটি উদাহরণ হল অ্যাপের শেয়ার বৈশিষ্ট্য। ধরে নিচ্ছি যে আমি এসভিজি কোড দিয়ে তৈরি একটি এসভিজিতে সম্পাদনা করতে চাই, এটির সাথে মোকাবিলা করার একটি উপায় হ'ল ফাইলটি সংরক্ষণ করা, এসভিজি সম্পাদনা অ্যাপ চালু করা এবং তারপরে সেখান থেকে এসভিজি ফাইলটি খুলুন। একটি মসৃণ প্রবাহ, যদিও, ওয়েব শেয়ার API ব্যবহার করা, যা ফাইলগুলিকে সরাসরি শেয়ার করার অনুমতি দেয়। তাই যদি SVG সম্পাদনা অ্যাপটি একটি শেয়ার টার্গেট হয়, তবে এটি বিচ্যুতি ছাড়াই সরাসরি ফাইলটি গ্রহণ করতে পারে।
shareSVGButton.addEventListener('click', async () => {
let svg = svgOutput.innerHTML;
svg = await optimizeSVG(svg);
const suggestedFileName =
getSuggestedFileName(await get(FILE_HANDLE)) || 'Untitled.svg';
const file = new File([svg], suggestedFileName, { type: 'image/svg+xml' });
const data = {
files: [file],
};
if (navigator.canShare(data)) {
try {
await navigator.share(data);
} catch (err) {
if (err.name !== 'AbortError') {
console.error(err.name, err.message);
}
}
}
});
ওয়েব শেয়ার টার্গেট (ফাইল)
অন্যভাবে, SVGcode শেয়ার টার্গেট হিসাবেও কাজ করতে পারে এবং অন্যান্য অ্যাপ থেকে ফাইল গ্রহণ করতে পারে। এই কাজটি করার জন্য, অ্যাপটিকে ওয়েব শেয়ার টার্গেট API-এর মাধ্যমে অপারেটিং সিস্টেমকে জানাতে হবে যে এটি কী ধরনের ডেটা গ্রহণ করতে পারে। এটি ওয়েব অ্যাপ ম্যানিফেস্টের একটি ডেডিকেটেড ফিল্ডের মাধ্যমে ঘটে।
{
"share_target": {
"action": "https://svgco.de/share-target/",
"method": "POST",
"enctype": "multipart/form-data",
"params": {
"files": [
{
"name": "image",
"accept": ["image/jpeg", "image/png", "image/webp", "image/gif"]
}
]
}
}
}
action
রুটটি প্রকৃতপক্ষে বিদ্যমান নেই, তবে পরিষেবা কর্মীর fetch
হ্যান্ডলারে বিশুদ্ধভাবে পরিচালনা করা হয়, যা অ্যাপে প্রকৃত প্রক্রিয়াকরণের জন্য প্রাপ্ত ফাইলগুলিকে পাস করে।
self.addEventListener('fetch', (fetchEvent) => {
if (
fetchEvent.request.url.endsWith('/share-target/') &&
fetchEvent.request.method === 'POST'
) {
return fetchEvent.respondWith(
(async () => {
const formData = await fetchEvent.request.formData();
const image = formData.get('image');
const keys = await caches.keys();
const mediaCache = await caches.open(
keys.filter((key) => key.startsWith('media'))[0],
);
await mediaCache.put('shared-image', new Response(image));
return Response.redirect('./?share-target', 303);
})(),
);
}
});
উপসংহার
ঠিক আছে, এটি SVGcode-এর কিছু উন্নত অ্যাপ বৈশিষ্ট্যের মাধ্যমে একটি দ্রুত সফর। আমি আশা করি এই অ্যাপটি Squosh বা SVGOMG- এর মতো অন্যান্য আশ্চর্যজনক অ্যাপের পাশাপাশি আপনার ইমেজ প্রসেসিং প্রয়োজনের জন্য একটি অপরিহার্য টুল হয়ে উঠতে পারে।
SVGcode svgco.de এ উপলব্ধ। দেখুন আমি সেখানে কি করেছি? আপনি GitHub এ এর সোর্স কোড পর্যালোচনা করতে পারেন। মনে রাখবেন যেহেতু পোট্রেস জিপিএল-লাইসেন্সযুক্ত, তাই এসভিজিকোডও। এবং যে সঙ্গে, খুশি vectorizing! আমি আশা করি SVGcode দরকারী হবে, এবং এর কিছু বৈশিষ্ট্য আপনার পরবর্তী অ্যাপটিকে অনুপ্রাণিত করতে পারে।
স্বীকৃতি
এই নিবন্ধটি জো মেডলি দ্বারা পর্যালোচনা করা হয়েছে।