Skip to content

মৌলিক উদাহরণ

এখানে 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');

সম্পর্কিত লিঙ্ক

Apache 2.0 লাইসেন্সের অধীনে রিলিজ করা হয়েছে।