http://www.hopesoft.org/blog/?p=1188
http://www.imagemagick.org/download/
2、用法
原始图片是input.jpg,尺寸:160×120
1)只缩小不放大
1 | gm convert input.jpg -resize "500x500>" output_1.jpg |
加了>,表示只有当图片的宽与高,大于给定的宽与高时,才进行“缩小”操作。
生成的图片大小是:160×120,未进行操作如果不加>,会导致图片被比等放大。2)等比缩图 (缺点:产生白边)
1 | gm convert input.jpg -thumbnail "100x100" output_1.jpg |
生成的图片大小是:100×75
3)非等比缩图,按给定的参数缩图(缺点:长宽比会变化)
1 | gm convert input.jpg -thumbnail "100x100!" output_2.jpg |
生成的图片大小是:100×100
4)裁剪后保证等比缩图 (缺点:裁剪了图片的一部分)
1 | gm convert input.jpg -thumbnail "100x100^" -gravity center -extent 100x100 output_3.jpg |
生成的图片大小是:100×100,还保证了比例。不过图片经过了裁剪,剪了图片左右两边才达到1:1
5)填充后保证等比缩图 (缺点:要填充颜色,和第一种方法基本一样)
1 | gm convert input.jpg -thumbnail "100x100" -background gray -gravity center -extent 100x100 output_4.jpg |
生成的图片大小是:100×100,还保证了比例,同时没有对图片进行任何裁剪,缺失的部分按指定颜色进行填充。
6)裁剪、填充相结合 (缺点:最差的方法)
1 | gm convert input.jpg -thumbnail "10000@ -background gray -gravity center -extent 100x100 output_5.jpg |
生成的图片大小是:100×100,这次保证了大小和比例,其中的10000就是100×100的乘积,同时在填充和裁剪之间做了一个平衡。
7)位深度32 转为24
IE6,7,8不支持显示“位深度32”的图片,但IE9、火狐、谷歌浏览器就可以显示。使用GM,把“位深度32”的图片转换为“位深度24”的图片输入图片zzz.jpg就是“位深度32”的图片,输出图片 zzz_out.jpg就是“位深度24”的图片 1 | gm convert -resize 100x100 -colorspace RGB zzz.jpg zzz_out.jpg |
转完后,图片的颜色会有轻微变化。
更多请参考: