Java图片处理开源框架--Thumbnailator使用简介

图片处理是当今软件开发中非常重要的一环,然而处理图片的开源框架却并不多。现金网上流传的Java处理图片的代码,虽然可对图片进行简单处理,但效果并不理想。虽然也有些其他解决方案,但都摆脱不了繁琐,使用起来十分不方便。

为了解决这个问题,我也是在网上找了好久,看了很多资料,功夫不负有心人,最终找到了一个处理图片十分棒的开源框架。特此拿出来与大家分享。


Thumbnailator 是一个优秀的图片处理的Google开源Java类库。处理效果远比Java API的好。从API提供现有的图像文件和图像对象的类中简化了处理过程,两三行代码就能够从现有图片生成处理后的图片,且允许微调图片的生成方式,同时保持了需要写入的最低限度的代码量。还支持对一个目录的所有图片进行批量处理操作。

支持的处理操作:图片缩放,区域裁剪,水印,旋转,保持比例。

另外值得一提的是,Thumbnailator至今仍不断更新,怎么样,感觉很有保障吧!

Thumbnailator官网:http://code.google.com/p/thumbnailator/

下面我们介绍下如何使用Thumbnailator

原图:

1、指定大小进行缩放

  1. //size(宽度, 高度)  
  2.   
  3. /* 
  4.  * 若图片横比200小,高比300小,不变 
  5.  * 若图片横比200小,高比300大,高缩小到300,图片比例不变 
  6.  * 若图片横比200大,高比300小,横缩小到200,图片比例不变 
  7.  * 若图片横比200大,高比300大,图片按比例缩小,横为200或高为300 
  8.  */  
  9. Thumbnails.of("images/a380_1280x1024.jpg")  
  10.     .size(200300)  
  11.     .toFile("c:/a380_200x300.jpg");  
  12.   
  13. Thumbnails.of("images/a380_1280x1024.jpg")  
  14.     .size(25602048)  
  15.     .toFile("c:/a380_2560x2048.jpg");  


2、按照比例进行缩放

  1. //scale(比例)  
  2. Thumbnails.of("images/a380_1280x1024.jpg")  
  3.     .scale(0.25f)  
  4.     .toFile("c:/a380_25%.jpg");  
  5.   
  6. Thumbnails.of("images/a380_1280x1024.jpg")  
  7.     .scale(1.10f)  
  8.     .toFile("c:/a380_110%.jpg");  


3、不按照比例,指定大小进行缩放

  1. //keepAspectRatio(false)默认是按照比例缩放的  
  2. Thumbnails.of("images/a380_1280x1024.jpg")  
  3.     .size(200,200)  
  4.     .keepAspectRatio(false)  
  5.     .toFile("c:/a380_200x200.jpg");  


4、旋转

  1. //rotate(角度),正数:顺时针负数:逆时针  
  2. Thumbnails.of("images/a380_1280x1024.jpg")  
  3.     .size(1280,1024)  
  4.     .rotate(90)  
  5.     .toFile("c:/a380_rotate+90.jpg");  
  6.   
  7. Thumbnails.of("images/a380_1280x1024.jpg")  
  8.     .size(1280,1024)  
  9.     .rotate(-90)  
  10.     .toFile("c:/a380_rotate-90.jpg");  


5、水印

  1. //watermark(位置,水印图,透明度)  
  2. Thumbnails.of("images/a380_1280x1024.jpg")  
  3.     .size(1280,1024)  
  4.     .watermark(Positions.BOTTOM_RIGHT,ImageIO.read(newFile("images/watermark.png")),0.5f)  
  5.     .outputQuality(0.8f)  
  6.     .toFile("c:/a380_watermark_bottom_right.jpg");  
  7.   
  8. Thumbnails.of("images/a380_1280x1024.jpg")  
  9.     .size(1280,1024)  
  10.     .watermark(Positions.CENTER,ImageIO.read(newFile("images/watermark.png")),0.5f)  
  11.     .outputQuality(0.8f)  
  12.     .toFile("c:/a380_watermark_center.jpg");  




6、裁剪

  1. //sourceRegion()  
  2.   
  3. //图片中心400*400的区域  
  4. Thumbnails.of("images/a380_1280x1024.jpg")  
  5.     .sourceRegion(Positions.CENTER,400,400)  
  6.     .size(200,200)  
  7.     .keepAspectRatio(false)  
  8.     .toFile("c:/a380_region_center.jpg");  
  9.   
  10. //图片右下400*400的区域  
  11. Thumbnails.of("images/a380_1280x1024.jpg")  
  12.     .sourceRegion(Positions.BOTTOM_RIGHT,400,400)  
  13.     .size(200,200)  
  14.     .keepAspectRatio(false)  
  15.     .toFile("c:/a380_region_bootom_right.jpg");  
  16.   
  17. //指定坐标  
  18. Thumbnails.of("images/a380_1280x1024.jpg")  
  19.     .sourceRegion(600,500,400,400)  
  20.     .size(200,200)  
  21.     .keepAspectRatio(false)  
  22.     .toFile("c:/a380_region_coord.jpg");  



7、转化图像格式

  1. //outputFormat(图像格式)  
  2. Thumbnails.of("images/a380_1280x1024.jpg")  
  3.     .size(1280,1024)  
  4.     .outputFormat("png")  
  5.     .toFile("c:/a380_1280x1024.png");  
  6.   
  7. Thumbnails.of("images/a380_1280x1024.jpg")  
  8.     .size(1280,1024)  
  9.     .outputFormat("gif")  
  10.     .toFile("c:/a380_1280x1024.gif");  

 

8、输出到OutputStream

  1. //toOutputStream(流对象)  
  2. OutputStreamos=newFileOutputStream("c:/a380_1280x1024_OutputStream.png");  
  3. Thumbnails.of("images/a380_1280x1024.jpg")  
  4.     .size(1280,1024)  
  5.     .toOutputStream(os);  

 

 9、输出到BufferedImage

  1. //asBufferedImage()返回BufferedImage  
  2. BufferedImagethumbnail=Thumbnails.of("images/a380_1280x1024.jpg")  
  3.     .size(1280,1024)  
  4.     .asBufferedImage();  
  5. ImageIO.write(thumbnail,"jpg",newFile("c:/a380_1280x1024_BufferedImage.jpg"));  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值