网站首页 > 开源技术 正文
前言
在现代Web开发中,图像处理是一个不可或缺的部分。
前端开发者经常需要处理图像,以确保它们在不同的设备和分辨率上都能保持良好的显示效果。
sharp.js是一个高性能的Node.js模块,它利用了libvips库,提供了快速且高效的图像处理能力。
本文将介绍sharp.js的基本使用和一些进阶技巧。
官网:https://sharp.pixelplumbing.com/
github:https://github.com/lovell/sharp
简介
sharp.js是一个基于 Node-API 的模块,它能够将大型图像转换为更小、更适合网络传输的格式,如JPEG、PNG、WebP、GIF和AVIF。
它支持所有支持 Node-API v9的 JavaScript 运行时环境,包括 Node.js 、Deno 和 Bun 。
使用sharp.js进行图像缩放的速度比使用 ImageMagick 和 GraphicsMagick 的最快设置快4到5倍。
基本使用
我们准备了一张原图
首先,确保你已经安装了Node.js版本18.17.0或更高版本。
然后,你可以通过npm或yarn安装sharp.js:
npm install sharp
# 或者
yarn add sharp
接下来,你可以使用以下代码来加载一个图像并将其缩放到指定的尺寸:
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不仅支持缩放,还支持压缩、旋转、裁剪、合成等操作。
以下是一些进阶用法的示例:
- 压缩图像:
sharp('input.png')
.webp({ quality: 50 }) // 使用WebP格式并设置质量为50
.toFile('compressed.webp')
这行代码把一张2M的图片压缩到了32kb,对比效果如下:
- 旋转图像:
sharp('input.png')
.rotate(90) // 顺时针旋转90度
.toFile('rotated.jpg');
- 裁剪图像:
sharp('input.png')
.extract({ left: 100, top: 100, width: 200, height: 200 })
.toFile('cropped.jpg');
image
- 图像合成:水印等场景
// 合成图片
sharp('input.png')
.composite([
{ input: './logo.png', gravity: 'center' },
])
.toFile('combined.png');
总结
以上的图片处理能力,按理说是可以在 electron 中使用的,这样的话不就可以依赖这个库做一个本地的图片处理工具么。
不过这种涉及文件流处理的库应该引用了一些系统级的库,估计在 electorn 中使用不会那么简单,如果只是简单的图片处理的话,纯前端的能力已经足够。
sharp.js是一个强大的图像处理库,它提供了快速且高效的图像处理功能,非常适合需要处理大量图像的Web应用。
它支持多种图像操作,并且易于使用。
– 欢迎点赞、关注、转发、收藏【我码玄黄】,各大平台同名。
猜你喜欢
- 2024-10-26 QQ竞争对手-开源IM平台Rocket.chat 来了
- 2024-10-26 Android App 自动化测试:OPEN-STF环境搭建
- 2024-10-26 一个LAMP环境一键安装搭建(一键安装lamp脚本)
- 2024-10-26 部署企业内部聊天工具Rocket.Chat开源IM系统
- 2024-10-26 CentOS 8 和 RHEL 8 服务器上启用 EPEL 仓库方法
- 2024-10-26 以后做GIF图用它就可以了 PChome(做出gif)
- 2024-10-26 X-CMD 发布 v0.4.9: 新增 pandoc 和 gm 模块 | tldr 和 install 新增 --fzf
- 2024-10-26 nodejs 图片处理库简介(node canvas处理图片)
- 2024-10-26 使用ImageMagick操作gif图(imagemagick使用教程)
- 2024-07-19 常春藤CMS:顾方软件打造安全稳定的企业级CMS系统
你 发表评论:
欢迎- 05-28AIMP播放器这样设置,显示歌词更加完美
- 05-28回放增益可存储:音频播放器AIMP 3.60.1483下载
- 05-28【推荐】俄罗斯顶级音乐播放软件AIMP
- 05-28找到一款汉EV的本地音乐播放神器,叫AIMP(不是广告)
- 05-28文档没有保存电脑就关机了怎么办?
- 05-28微软office加入OpenAI
- 05-28吉林大学“开放交流时间”(Open Office Hour)来了!
- 05-28全新 Office 2024 正式发布
- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)