thumbnailator图片处理:缩放、水印、剪切等

项目地址:https://github.com/coobird/thumbnailator 本篇介绍基本使用

加载图片源

File file = new File("xx/01.jpg");
Builder<File> builder = Thumbnails.of(file);

缩放

builder = builder.scale(0.9);   //参数是浮点数,大于1表示放大,小于1表示缩小

质量压缩

builder.outputQuality(0.9); //参数是浮点数,0-1之间

剪切

builder.sourceRegion(100, 100, 300, 300);    
builder.sourceRegion(Positions.CENTER, 200, 200);

根据宽度来缩放

builder.width(500);
根据高度来缩放

builder.height(500);

在调整尺寸时保持比例

builder.keepAspectRatio(true);  //默认为true,如果要剪裁到特定的比例,设为false即可

根据宽度和高度进行缩放

builder.size(600, 700);
//如果设置了keepAspectRatio(true),将按比例进行缩放,否则将强制按尺寸输出

缩放策略:
如果宽度缩放比>高度缩放比就以宽度来缩放,反之以高度缩放

将图片放入内存

File file2 = new File("/Users/qiangzi/data/img","logo.png");
BufferedImage bufferedImage = Thumbnails.of(file2).scale(1.0).outputQuality(1.0).asBufferedImage();
*必须要指定scale

加水印

builder.watermark(Positions.BOTTOM_RIGHT, bufferedImage, 1.0f);
//第一个参数是加水印的位置
//第二个参数是要加水印的图片
//第三个参数是水印图片的透明度
经过测试:gif图片的彩色会变成黑白,所以尽量使用jpg或png图片吧

输出图片,不管对图片进行什么操作,只有输出才能看到效果

builder.toFile(File file);

** *注意:scale、width|height、size三者不能同时共存,但必须要有一个 **

** 链式调用案例 **

//将原图缩放到宽度为500,压缩质量90%
Thumbnails.of(file).width(500).outputQuality(0.9).toFile(file);
//将原图按比例缩放,最宽300,最高400,不进行质量压缩
Thumbnails.of(file).size(300, 400).outputQuality(1.0).toFile(file);

个人小结

虽然Thumbnails给我们提供了大量的图像处理API,但要直接拿到开发中去使用,恐怕还得进行二次封装来满足项目的需求。基于Thumbnails的图像处理

更多API,请自己下载去尝试

**附录位置参数 ** Positions.TOP_LEFT Positions.TOP_CENTER Positions.TOP_RIGHT Positions.CENTER_LEFT Positions.CENTER Positions.CENTER_RIGHT Positions.BOTTOM_LEFT Positions.BOTTOM_CENTER Positions.BOTTOM_RIGHT

转载于:https://my.oschina.net/jrrx/blog/734868

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值