মৌলিক উদাহরণ
এখানে Sharp-এর কিছু মৌলিক ব্যবহারের উদাহরণ দেওয়া হয়েছে, যা আপনাকে দ্রুত শুরু করতে সাহায্য করবে।
ইমেজের আকার পরিবর্তন
সহজ রিসাইজ
javascript
import sharp from 'sharp';
// নির্দিষ্ট আকারে রিসাইজ করুন
await sharp('input.jpg')
.resize(300, 200)
.toFile('output.jpg');অ্যাসপেক্ট রেশিও রাখুন
javascript
// শুধুমাত্র প্রস্থ নির্দিষ্ট করুন, উচ্চতা স্বয়ংক্রিয়ভাবে গণনা হবে
await sharp('input.jpg')
.resize(300)
.toFile('output.jpg');
// শুধুমাত্র উচ্চতা নির্দিষ্ট করুন, প্রস্থ স্বয়ংক্রিয়ভাবে গণনা হবে
await sharp('input.jpg')
.resize(null, 200)
.toFile('output.jpg');ফিট মোড
javascript
// cover: অ্যাসপেক্ট রেশিও রাখুন, অতিরিক্ত অংশ ক্রপ করুন
await sharp('input.jpg')
.resize(300, 200, { fit: 'cover' })
.toFile('output.jpg');
// contain: অ্যাসপেক্ট রেশিও রাখুন, ব্যাকগ্রাউন্ড যোগ করুন
await sharp('input.jpg')
.resize(300, 200, { fit: 'contain', background: { r: 255, g: 255, b: 255 } })
.toFile('output.jpg');ফরম্যাট কনভার্শন
JPEG থেকে PNG
javascript
await sharp('input.jpg')
.png()
.toFile('output.png');PNG থেকে JPEG
javascript
await sharp('input.png')
.jpeg({ quality: 80 })
.toFile('output.jpg');WebP-এ রূপান্তর
javascript
await sharp('input.jpg')
.webp({ quality: 80 })
.toFile('output.webp');AVIF-এ রূপান্তর
javascript
await sharp('input.jpg')
.avif({ quality: 80 })
.toFile('output.avif');ইমেজ রোটেশন
90 ডিগ্রি রোটেশন
javascript
await sharp('input.jpg')
.rotate(90)
.toFile('output.jpg');স্বয়ংক্রিয় রোটেশন (EXIF অনুযায়ী)
javascript
await sharp('input.jpg')
.rotate() // স্বয়ংক্রিয় রোটেশন
.toFile('output.jpg');ইমেজ ফ্লিপ
উল্লম্ব ফ্লিপ
javascript
await sharp('input.jpg')
.flip()
.toFile('output.jpg');অনুভূমিক ফ্লিপ
javascript
await sharp('input.jpg')
.flop()
.toFile('output.jpg');ইমেজ ক্রপ
নির্দিষ্ট এলাকা ক্রপ
javascript
await sharp('input.jpg')
.extract({ left: 100, top: 100, width: 300, height: 200 })
.toFile('output.jpg');ক্রপ করুন এবং রিসাইজ করুন
javascript
await sharp('input.jpg')
.extract({ left: 100, top: 100, width: 300, height: 200 })
.resize(150, 100)
.toFile('output.jpg');ফিল্টার ইফেক্ট
গ্রেস্কেল কনভার্শন
javascript
await sharp('input.jpg')
.grayscale()
.toFile('output.jpg');ব্লার ইফেক্ট
javascript
await sharp('input.jpg')
.blur(5)
.toFile('output.jpg');শার্পেনিং ইফেক্ট
javascript
await sharp('input.jpg')
.sharpen()
.toFile('output.jpg');রঙ উল্টানো
javascript
await sharp('input.jpg')
.negate()
.toFile('output.jpg');রঙ অ্যাডজাস্টমেন্ট
ব্রাইটনেস অ্যাডজাস্টমেন্ট
javascript
await sharp('input.jpg')
.modulate({ brightness: 1.2 })
.toFile('output.jpg');স্যাচুরেশন অ্যাডজাস্টমেন্ট
javascript
await sharp('input.jpg')
.modulate({ saturation: 0.8 })
.toFile('output.jpg');হিউ অ্যাডজাস্টমেন্ট
javascript
await sharp('input.jpg')
.modulate({ hue: 180 })
.toFile('output.jpg');ট্রান্সপারেন্সি হ্যান্ডলিং
ট্রান্সপারেন্সি যোগ করুন
javascript
await sharp('input.jpg')
.ensureAlpha()
.png()
.toFile('output.png');ট্রান্সপারেন্সি অপসারণ করুন
javascript
await sharp('input.png')
.flatten({ background: { r: 255, g: 255, b: 255 } })
.jpeg()
.toFile('output.jpg');কোয়ালিটি সেটিং
JPEG কোয়ালিটি
javascript
// উচ্চ কোয়ালিটি
await sharp('input.png')
.jpeg({ quality: 95 })
.toFile('output.jpg');
// মাঝারি কোয়ালিটি
await sharp('input.png')
.jpeg({ quality: 80 })
.toFile('output.jpg');
// নিম্ন কোয়ালিটি (ছোট ফাইল)
await sharp('input.png')
.jpeg({ quality: 50 })
.toFile('output.jpg');WebP কোয়ালিটি
javascript
await sharp('input.jpg')
.webp({ quality: 80, lossless: false })
.toFile('output.webp');চেইন অপারেশন
একাধিক অপারেশন কম্বাইন
javascript
await sharp('input.jpg')
.resize(800, 600)
.rotate(90)
.blur(2)
.sharpen()
.jpeg({ quality: 80 })
.toFile('output.jpg');শর্তাধীন প্রসেসিং
javascript
const image = sharp('input.jpg').resize(300, 200);
if (needsBlur) {
image.blur(3);
}
if (needsSharpen) {
image.sharpen();
}
await image.jpeg({ quality: 80 }).toFile('output.jpg');এরর হ্যান্ডলিং
মৌলিক এরর হ্যান্ডলিং
javascript
try {
await sharp('input.jpg')
.resize(300, 200)
.toFile('output.jpg');
} catch (error) {
console.error('ইমেজ প্রসেসিং ব্যর্থ:', error.message);
}ফাইল অস্তিত্ব চেক করুন
javascript
const fs = require('fs');
if (fs.existsSync('input.jpg')) {
await sharp('input.jpg')
.resize(300, 200)
.toFile('output.jpg');
} else {
console.error('ইনপুট ফাইল নেই');
}স্ট্রিম প্রসেসিং
স্ট্রিম থেকে পড়ুন
javascript
const fs = require('fs');
fs.createReadStream('input.jpg')
.pipe(sharp().resize(300, 200))
.pipe(fs.createWriteStream('output.jpg'));স্ট্রিমে আউটপুট করুন
javascript
const fs = require('fs');
sharp('input.jpg')
.resize(300, 200)
.jpeg({ quality: 80 })
.pipe(fs.createWriteStream('output.jpg'));Buffer প্রসেসিং
Buffer থেকে তৈরি করুন
javascript
const fs = require('fs');
const inputBuffer = fs.readFileSync('input.jpg');
const outputBuffer = await sharp(inputBuffer)
.resize(300, 200)
.jpeg({ quality: 80 })
.toBuffer();
fs.writeFileSync('output.jpg', outputBuffer);Buffer-এ আউটপুট করুন
javascript
const buffer = await sharp('input.jpg')
.resize(300, 200)
.jpeg({ quality: 80 })
.toBuffer();
// সরাসরি buffer ব্যবহার করতে পারেন
console.log('ইমেজ সাইজ:', buffer.length);ব্যাচ প্রসেসিং
ডিরেক্টরির সব ইমেজ প্রসেস করুন
javascript
const fs = require('fs').promises;
const path = require('path');
async function processImages(inputDir, outputDir) {
const files = await fs.readdir(inputDir);
for (const file of files) {
if (file.match(/\.(jpg|jpeg|png|webp)$/i)) {
try {
await sharp(path.join(inputDir, file))
.resize(300, 200)
.jpeg({ quality: 80 })
.toFile(path.join(outputDir, file));
console.log(`প্রসেসিং সম্পন্ন: ${file}`);
} catch (error) {
console.error(`${file} প্রসেসিং ব্যর্থ:`, error.message);
}
}
}
}
processImages('./input', './output');