当前位置: 首页 > news >正文

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

前言

在现代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 v9JavaScript 运行时环境,包括 Node.jsDenoBun

使用sharp.js进行图像缩放的速度比使用 ImageMagickGraphicsMagick 的最快设置快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不仅支持缩放,还支持压缩、旋转、裁剪、合成等操作。

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

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

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

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

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

image

  1. 图像合成:水印等场景
// 合成图片
sharp('input.png').composite([{ input: './logo.png', gravity: 'center' },]).toFile('combined.png');

总结

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

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

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

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

– 欢迎点赞、关注、转发、收藏【我码玄黄】,各大平台同名。

http://www.lryc.cn/news/448167.html

相关文章:

  • Rust环境安装配置
  • 衡石分析平台系统管理手册-功能配置之全局 JS 设置
  • OpenHarmony(鸿蒙南向)——平台驱动开发【MIPI DSI】
  • C++_一篇文章让你弄懂各类(运算符)
  • 顺序表算法题 —— 移除元素、删除有序数组中的重复项、合并两个有序数组
  • 配置ssh后又报错git@github.com: Permission denied (publickey)
  • yolov10安装体验
  • 使用Docker-Compose部署SpringBoot项目的案例
  • 大话 RCU (read copy update)
  • vue项目npm run serve 报错,Error: read ECONNRESET at TCP.onStreamRead
  • 十二、MySQL数据类型精讲
  • 不同参数对分类精度的影响以及思考
  • 开源AI智能名片小程序源码:私域电商构建独特竞争力的新机遇
  • 从Web2到Web3:探索下一代互联网的无限可能性
  • POE供电支持画中画的摄像头解决方案
  • Python 3 字典
  • CFR( Java 反编译器)
  • 单片机的两种看门狗原理解析——IWDG和WWDG
  • SQL进阶技巧:如何获取状态一致的分组? | 最大、最小值法
  • windows10使用bat脚本安装前后端环境之msyql5.7安装配置并重置用户密码
  • 文件上传、amrkdown编辑器
  • Linux防火墙-4表5链
  • (最新已验证)stm32 + 新版 onenet +dht11+esp8266/01s + mqtt物联网上报温湿度和控制单片机(保姆级教程)
  • 无环SLAM系统集成后端回环检测模块(loop):SC-A-LOAM以及FAST_LIO_SLAM
  • 速盾:视频开cdn合适还是视频点播合适?
  • Mac电脑安装FFmpeg和卸载FFmpeg
  • 数据结构:栈 及其应用
  • 批量发送邮件:性能优化与错误处理深度解析
  • STM32原理知识查询表
  • 从 Kafka 到 WarpStream: 用 MinIO 简化数据流