nodejs处理图片的中间件node-images详解
cross-platform image decoder(png/jpeg/gif) and encoder(png/jpeg) for node.js
node.js轻量级跨平台图像编解码库
var images = require("images"); images("input.jpg") //load image from file //加载图像文件 .size(400) //geometric scaling the image to 400 pixels width //等比缩放图像到400像素宽 .draw(images("logo.png"), 10, 10) //drawn logo at coordinates (10,10) //在(10,10)处绘制logo .save("output.jpg", { //save the image to a file,whih quality 50 quality : 50 //保存图片到文件,图片质量为50 });
features 功能特性
- lightweight:no need to install any image processing library.
- 轻量级:无需安装任何图像处理库。
- cross-platform: released a compiled .node file on windows, just download and start.
- 跨平台:windows下发布了编译好的.node文件,下载就能用。
- easy-to-use: provide jquery-like chaining api.simple and reliable!
- 方便用:jquery风格的api,简单可依赖。
installation 安装
$ npm install images
api 接口
node-images provide jquery-like chaining api,you can start the chain like this:
node-images 提供了类似jquery的链式调用api,您可以这样开始:
/* load and decode image from file */ /* 从指定文件加载并解码图像 */ images(file) /* create a new transparent image */ /* 创建一个指定宽高的透明图像 */ images(width, height) /* load and decode image from a buffer */ /* 从buffer数据中解码图像 */ images(buffer[, start[, end]]) /* copy from another image */ /* 从另一个图像中复制区域来创建图像 */ images(image[, x, y, width, height])
images(file)
load and decode image from file从指定文件加载并解码图像
images(width, height)
create a new transparent image创建一个指定宽高的透明图像
images(buffer[, start[, end]])
load and decode image from a buffer从buffer数据中解码图像
images(image[, x, y, width, height])
copy from another image从另一个图像中复制区域来创建图像
.fill(red, green, blue[, alpha])
eg:images(200, 100).fill(0xff, 0x00, 0x00, 0.5) fill image with color以指定颜色填充图像
.draw(image, x, y)
draw image on the current image position( x , y )在当前图像( x , y )上绘制 image 图像
.encode(type[, config])
eg:images("input.png").encode("jpg", {operation:50}) encode image to buffer, config is image setting.
以指定格式编码当前图像到buffer,config为图片设置,目前支持设置jpg图像质量
return buffer
返回填充好的buffer
note:the operation will cut off the chain
注意:该操作将会切断调用链
see:.save(file[, type[, config]]) 参考:.save(file[, type[, config]])
.save(file[, type[, config]])
eg:images("input.png").encode("output.jpg", {operation:50}) encoding and save the current image to a file, if the type is not specified, type well be automatically determined according to the file, config is image setting. eg: { operation:50 }
编码并保存当前图像到 file ,如果type未指定,则根据 file 自动判断文件类型,config为图片设置,目前支持设置jpg图像质量
.size([width[, height]])
get size of the image or set the size of the image,if the height is not specified, then scaling based on the current width and height获取或者设置图像宽高,如果height未指定,则根据当前宽高等比缩放
.resize(width[, height])
set the size of the image,if the height is not specified, then scaling based on the current width and height
设置图像宽高,如果height未指定,则根据当前宽高等比缩放, 默认采用 bicubic 算法。
.width([width])
get width for the image or set width of the image获取或设置图像宽度
.height([height])
get height for the image or set height of the image获取或设置图像高度
images.setlimit(width, height)
set the limit size of each image 设置库处理图片的大小限制,设置后对所有新的操作生效(如果超限则抛出异常)
images.setgcthreshold(value)
set the garbage collection threshold 设置图像处理库自动gc的阈值(当新增内存使用超过该阈值时,执行垃圾回收)
images.getusedmemory()
get used memory (in bytes)得到图像处理库占用的内存大小(单位为字节)
images.gc()
forced call garbage collection 强制调用v8的垃圾回收机制
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。