NodeJs + gm图片缩略图

我的另一篇文章: Nginx/Apache图片缩略图技术

gm官网

1, 软件环境

nodejs
npm
GraphicsMagick or ImageMagick

貌似ImageMagick在处理大图片时比GraphicsMagick要快很多。

2, gm的一些关键函数

//1, 使用方式
var gm = require('gm');
gm("图片源路径")
    .resize(200,0)     //设置压缩后的w/h
    .setFormat('JPEG')
    .quality(70)       //设置压缩质量: 0-100
    .strip()
    .autoOrient()
    .write("压缩后保存路径" , 
    function(err){console.log("err: " + err);})
//2, 获取图片尺寸
gm("图片路径").size(function(err,value){});
//3, 获取图片大小
gm("图片路径").filesize(function(err,value){});```

resize函数, 详细参数
resize {w}x{h} {%} {@} {!} {<} {>}
这里需要注意第3个参数

%
表示按照width/height的百分比, resize(70, 0, '%')表示宽度为原先的70%

@
(×_×)表示不明白,貌似可以限制压缩文件的filesize, gm文档上是这样描述的:
Use @ to specify the maximum area in pixels of an image.

!
表示强制width/height, resize(70, 70, '%')表示输出图片尺寸70x70,图片可能变形

^
表示最小width/height, resize(70,70,'^')表示width/height最小不能小于70px

>
表示只有源图片的width or height超过指定的width/height时,图片尺寸才会变。
如:源图片大小:640x640, resize(1000, 1000)最终图片尺寸不变。

<
>正好相反,表示只有源图片的width or height小于指定的width/height时,图片尺寸才会变

gm默认使用GraphicsMagick处理图片,如果你想使用ImageMagick,则:

var gm = require('gm');
var imageMagick = gm.subClass({ imageMagick: true })
//使用方式同上,把上面的gm(..)函数替换成imageMagick(..)函数即可

转载于:https://www.cnblogs.com/java-koma/p/4278707.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值