Sharp.js:简单而又实用的图像处理库。

前言

在现代Web开发中,图像处理是一个不可或缺的部分。

前端开发者经常需要处理图像,以确保它们在不同的设备和分辨率上都能保持良好的显示效果。

sharp.js是一个高性能的Node.js模块,它利用了libvips库,提供了快速且高效的图像处理能力。

本文将介绍sharp.js的基本使用和一些进阶技巧。

官网:sharp.pixelplumbing.com/

github:github.com/lovell/shar…

简介

sharp.js是一个基于 Node-API 的模块,它能够将大型图像转换为更小、更适合网络传输的格式,如JPEG、PNG、WebP、GIF和AVIF。

它支持所有支持 Node-API v9JavaScript 运行时环境,包括 Node.jsDenoBun

使用sharp.js进行图像缩放的速度比使用 ImageMagickGraphicsMagick 的最快设置快4到5倍。

基本使用

我们准备了一张原图

首先,确保你已经安装了Node.js版本18.17.0或更高版本。

然后,你可以通过npm或yarn安装sharp.js

 

bash

代码解读

复制代码

npm install sharp # 或者 yarn add sharp

接下来,你可以使用以下代码来加载一个图像并将其缩放到指定的尺寸:

 

javascript

代码解读

复制代码

const sharp = require('sharp'); sharp('input.png') .resize(300, 200) .toFile('output.jpg') .then(() => console.log('Image resized and saved!')) .catch(err => console.error('Error resizing image:', err));

这段代码将加载input.jpg文件,将其缩放到300x200像素,然后保存为output.jpg

进阶使用

sharp.js不仅支持缩放,还支持压缩、旋转、裁剪、合成等操作。

以下是一些进阶用法的示例:

  1. 压缩图像
 

javascript

代码解读

复制代码

sharp('input.png') .webp({ quality: 50 }) // 使用WebP格式并设置质量为50 .toFile('compressed.webp')

这行代码把一张2M的图片压缩到了32kb,对比效果如下:

  1. 旋转图像
 

javascript

代码解读

复制代码

sharp('input.png') .rotate(90) // 顺时针旋转90度 .toFile('rotated.jpg');

  1. 裁剪图像
 

javascript

代码解读

复制代码

sharp('input.png') .extract({ left: 100, top: 100, width: 200, height: 200 }) .toFile('cropped.jpg');

  1. 图像合成:水印等场景
 

javascript

代码解读

复制代码

// 合成图片 sharp('input.png') .composite([ { input: './logo.png', gravity: 'center' }, ]) .toFile('combined.png');

总结

以上的图片处理能力,按理说是可以在 electron 中使用的,这样的话不就可以依赖这个库做一个本地的图片处理工具么。

不过这种涉及文件流处理的库应该引用了一些系统级的库,估计在 electorn 中使用不会那么简单,如果只是简单的图片处理的话,纯前端的能力已经足够。

sharp.js是一个强大的图像处理库,它提供了快速且高效的图像处理功能,非常适合需要处理大量图像的Web应用。

它支持多种图像操作,并且易于使用。

原文链接:https://juejin.cn/post/7419209528263327796

在Node.js中,流式图像处理的选择主要取决于你的具体需求。有许多可以用于图像处理,例如使用Node.js内置的流和模块。但是,这些通常主要用于读取、转换和写入图像文件,而不太适合处理大规模图像数据。在这种情况下,使用流处理更为合适,因为这样可以更高效地处理大量数据。 以下是一些Node.js流式图像处理的介绍: 1. **sharp**:这是一个流行的Node.js图像处理,它支持流式处理。它提供了一种简单的方法来转换图像,包括缩放、旋转、裁剪、调整色彩和亮度等。它也支持许多不同的输入和输出格式,包括JPEG、PNG、TIFF等。 2. **gulp-image-pipeline**:这是一个用于处理图像的gulp插件,它支持流式处理。它可以帮助你转换图像格式、调整大小、裁剪、旋转等。 3. **node-canvas**:这是一个基于Canvas的图像处理,它支持在Node.js中创建和处理图像。它提供了许多用于图像处理的API,包括缩放、旋转、裁剪、调整色彩等。 4. **gm**:这是一个Node.js模块,它使用Google的图形处理(gm)进行图像处理。gm是一个强大的图形处理,支持许多不同的图像格式和操作。 这些中的每一个都有自己的优点和适用场景。在选择时,你应该考虑你的具体需求,例如需要处理多大的图像数据、需要执行哪些类型的图像处理操作等。另外,在使用这些时,要注意性能和资源消耗问题,以确保你的应用程序能够高效地处理大量图像数据。 以上是一些流行的Node.js流式图像处理,但可能还有其他或工具可供选择。你可以根据你的具体需求进行搜索和评估,以找到最适合你的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值