Node.js API رایگان برای ایجاد و تبدیل تصاویر

کتابخانه Node.js منبع باز به طور کامل از تبدیل خودکار Imagec، تغییر اندازه، ویرایش چرخش و موارد دیگر در داخل برنامه های Node.js پشتیبانی می کند.

پردازش تصویر جنبه اساسی بسیاری از برنامه های کاربردی مدرن است، از توسعه وب گرفته تا برنامه های تلفن همراه. وقتی صحبت از پردازش تصویر کارآمد و با کارایی بالا در Node.js می شود، شارپ API به عنوان یک کتابخانه منبع باز پیشرو برجسته می شود. شارپ یک کتابخانه پردازش تصویر منبع باز و با کارایی بالا است که بر روی کتابخانه libvips ساخته شده است. شارپ که به دلیل سرعت و استفاده کم حافظه اش شناخته شده است، برای انجام وظایف پردازش تصویر در مقیاس بزرگ به طور موثر طراحی شده است. به دلیل سهولت استفاده، پشتیبانی گسترده از فرمت و ویژگی های قدرتمند، در بین توسعه دهندگان محبوبیت خاصی دارد. من از چندین ویژگی مهم مانند تولید پویا تصاویر شخصی‌شده، تغییر اندازه تصویر، تبدیل خودکار تصویر، برش یا چرخاندن تصویر و بسیاری موارد دیگر پشتیبانی می‌کنم.

Sharp API یک ابزار قدرتمند برای توسعه دهندگان نرم افزاری است که به دنبال ترکیب پردازش تصویر با کارایی بالا در برنامه های Node.js خود هستند. از طیف وسیعی از فرمت‌های فایل تصویری از جمله JPEG، PNG، WebP، TIFF، GIF، AVIF و حتی داده‌های پیکسل خام پشتیبانی می‌کند. این تطبیق پذیری توسعه دهندگان نرم افزار را قادر می سازد تا بدون نگرانی در مورد مشکلات سازگاری، با تصاویر از منابع مختلف کار کنند. API کاملاً ناهمزمان است، به این معنی که می تواند چندین کار پردازش تصویر را به طور همزمان انجام دهد. این معماری غیر مسدود کننده برای برنامه هایی که نیاز به توان عملیاتی و مقیاس پذیری بالایی دارند ایده آل است. ترکیبی از سرعت، کارایی و طیف وسیعی از ویژگی‌ها، آن را به گزینه‌ای ایده‌آل برای پروژه‌هایی تبدیل می‌کند که نیاز به دستکاری تصویر در زمان واقعی، تبدیل فرمت یا کارهای پیچیده پردازش تصویر دارند.

Previous Next

شروع به کار با شارپ

روش توصیه شده برای نصب شارپ از طریق NPM. لطفا از دستور زیر برای نصب آن استفاده کنید.

Install Sharp via NPM

npm install sharp
const sharp = require('sharp');

پردازش خودکار تصویر در برنامه‌های Node.js

توسعه‌دهندگان می‌توانند از کتابخانه Sharp برای خودکارسازی کارهای پردازش تصویر، مانند تولید تصاویر کوچک، تبدیل فرمت‌های تصویر، یا اعمال واترمارک استفاده کنند. این به ویژه برای سیستم‌های مدیریت محتوا (CMS)، پلتفرم‌های تجارت الکترونیک و برنامه‌های رسانه‌های اجتماعی که حجم زیادی از تصاویر نیاز به پردازش مداوم دارند، مفید است. قابلیت های گسترده تبدیل آن، آن را به پایه ای مناسب برای ساخت ویرایشگرهای تصویر سفارشی تبدیل می کند. چه ایجاد یک ویرایشگر عکس مبتنی بر وب یا یک برنامه تلفن همراه برای ویرایش تصاویر، شارپ ابزارهای لازم را برای پیاده سازی ویژگی های پیشرفته دستکاری تصویر فراهم می کند. در اینجا مثالی وجود دارد که نحوه تنظیم روشنایی و کنتراست یک تصویر را در محیط Node.js نشان می دهد.

چگونه روشنایی و کنتراست تصویر را در برنامه های Node.js تنظیم کنیم؟

sharp('input.jpg')
  .modulate({
    brightness: 1.2, // Increase brightness by 20%
    contrast: 1.5    // Increase contrast by 50%
  })
  .toFile('output.jpg')
  .then(() => console.log('Image brightness and contrast adjusted'))
  .catch(err => console.error('Error:', err));

تغییر اندازه و بهینه سازی تصویر در Node.js

برای برنامه‌های وب که تصاویر را ارائه می‌کنند، عملکرد کلیدی است. با کتابخانه شارپ منبع باز، توسعه دهندگان نرم افزار می توانند سرویسی ایجاد کنند که به طور خودکار اندازه تصاویر را برای دستگاه ها و اندازه های مختلف صفحه نمایش تغییر داده و بهینه می کند. به عنوان مثال، یک پلت فرم تجارت الکترونیکی می تواند از شارپ برای تولید چندین نسخه از تصاویر محصول (تصاویر کوچک، تصاویر با اندازه متوسط ​​و تصاویر با وضوح بالا) در پرواز استفاده کند. این تضمین می کند که کاربران بدون توجه به دستگاه خود بهترین کیفیت تصویر و سرعت بارگذاری را دریافت می کنند. در اینجا یک مثال ساده است که نشان می دهد، چگونه توسعه دهندگان نرم افزار می توانند یک Image را در برنامه های Node.js بارگذاری و تغییر اندازه دهند.

چگونه تصویر JPG را در برنامه های Node.js بارگیری و تغییر اندازه دهیم؟

const sharp = require('sharp');

sharp('input.jpg')
  .resize({ width: 300 })
  .toFile('output.jpg')
  .then(() => {
    console.log('Image resized successfully');
  })
  .catch(err => {
    console.error('Error processing image:', err);
  });

تبدیل خودکار تصویر در سیستم‌های مدیریت محتوا

در پلتفرم‌های پر محتوا مانند وبلاگ‌ها یا وب‌سایت‌های خبری، تصاویر اغلب در قالب‌های مختلف ارائه می‌شوند. کتابخانه منبع باز شارپ می تواند تبدیل این تصاویر را به فرمت استانداردی که برای استفاده در وب بهینه شده است، خودکار کند. به عنوان مثال، تبدیل تمام تصاویر به فرمت WebP می تواند اندازه فایل را به میزان قابل توجهی کاهش دهد و زمان بارگذاری را بدون افت کیفیت بهبود بخشد. در اینجا یک نمونه کد بسیار قدرتمند وجود دارد که نشان می دهد چگونه توسعه دهندگان نرم افزار می توانند تصاویر شخصی سازی شده در برنامه های Node.js ایجاد کنند.

چگونه تصاویر شخصی سازی شده را در برنامه های Node.js ایجاد کنیم؟

sharp({
  create: {
    width: 300,
    height: 200,
    channels: 4,
    background: { r: 255, g: 255, b: 255, alpha: 0.5 }
  }
})
  .composite([{ input: 'overlay.png', gravity: 'center' }])
  .toFile('output.png')
  .then(() => {
    console.log('Personalized image created');
  })
  .catch(err => {
    console.error('Error generating image:', err);
  });

پشتیبانی از فرمت های تصویری چندگانه

کتابخانه منبع باز Sharp از طیف گسترده ای از فرمت های فایل تصویری مانند JPEG PNG، TIFF، GIF و حتی فرمت های مدرن مانند WebP و AVIF پشتیبانی می کند. این تطبیق پذیری به توسعه دهندگان نرم افزار این قدرت را می دهد که با انواع مختلف تصاویر کار کنند و از سازگاری در پلتفرم ها و دستگاه های مختلف اطمینان حاصل کنند.

 فارسی