Java圖片處理開源框架

圖片處理是當今軟件開發中非常重要的一環,然而處理圖片的開源框架卻並不多。現金網上流傳的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"));  

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章