nodejs使用jimp实现图片处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nodejs使用jimp实现图片处理相关的知识,希望对你有一定的参考价值。

参考技术A 在开发中,图片处理是逃不开的一个问题。 jimp 插件可以非常方便的实现图片的一些常见操作。

jimp插件支持常见的图片格式:

使用read方法把图片资源进行读取。读取之后可以使用jimp提供的API对图片做更多的操作。

原图

缩放之后

crop( x, y, w, h)
参数分别表示开始位置的x,y以及裁剪的宽和高

裁剪的结果

rotate把图片旋转指定的角度。

旋转结果

透明效果

效果

Node 裁切图片的方法

        1、安装 jimp

  $ npm install --save jimp

        2、读取本地图片切图

jimp.read('本地图片地址', function (err, img) {
    if (err) throw err
    img
  	  .crop(x坐标起点, y坐标起点, width最终图片宽度, height最终图片高度)
      .write(result)
})

        3、读取http图片,转成buffer,切成buffer数据

const options = {
	headers: {
		'User-Agent': 'Mozilla/5.0',
	}
}
http.get(imgUrl, options ,(response) => {
	let imgData = ''
	response.setEncoding('binary')
	response.on('data', (chunk) => {
		imgData += chunk
	})
	response.on('end', () => {
		const imgBuffer = new Buffer.from(imgData, 'binary')
		jimp.read(imgBuffer)
			.then((img) => {
				const topLeftImage = img.clone() // copy jimp对象进行操作
				const topRightImage = img.clone()
				const bottomLeftImage = img.clone()
				const bottomRightImage = img.clone()
				const topLeft = topLeftImage.crop(64, 64, 256, 256)
				topLeft.getBuffer('image/jpeg', (_, buf) => {
					consoel.log(buf)
				})
				const topRight = topRightImage.crop(320, 64, 256, 256)
				topRight.getBuffer('image/jpeg', (_, buf) => {
					consoel.log(buf)
				})
				const bottomLeft = bottomLeftImage.crop(64, 320, 256, 256)
				bottomLeft.getBuffer('image/jpeg', (_, buf) => {
					consoel.log(buf)
				})
				const bottomRight = bottomRightImage.crop(320, 320, 256, 256)
				bottomRight.getBuffer('image/jpeg', (_, buf) => {
					consoel.log(buf)
				})
			})
			.catch(err => {
				console.error(err)
			})
	})
}).on('error', function (err) {
	console.log('出错!', err)
})

        4、graphicsMagick、imageMagick GM

        需要下载工具graphicsMagick | imageMagick并配置环境变量

  $ npm i gm
/**
 * 裁剪图片
 * @param srcImg    待裁剪的图片路径
 * @param destImg   裁剪后的图片路径
 * @param width     宽度
 * @param height    高度
 * @param x         x坐标
 * @param y         y坐标
 */
function cropImgHandle(srcImg, destImg, width, height, x, y) {
  gm(srcImg).crop(width, height, x, y).write(destImg, function (err) {
    if (err) {
      return console.log(err)
    } else {
    	console.log('success')
    }
  })
}

        到此 Node 裁切图片的方法介绍完成。

以上是关于nodejs使用jimp实现图片处理的主要内容,如果未能解决你的问题,请参考以下文章

Nodejs前端服务器压缩图片

nodejs去掉图片64编码前面部分

nodejs--express的中间件multer实现图片文件上传--XUEBIG

在 Jimp 处理图像后下载图像文件

nodejs处理图片工具sharp

nodejs处理图片工具sharp