【Java實例】使用Thumbnailator生成縮略圖(縮放、旋轉、裁剪、水印)

1 需求

表哥須要給兒子報名考試,系統要求上傳不超過30KB的圖片,而如今的手機隨手一拍就是幾MB的,怎麼弄一個才30KB的圖片呢?git

一個簡單的辦法是在電腦上把圖片縮小,而後截屏小圖片,但如今的電腦屏幕分辨率很高,並且截屏大小很差控制;一樣分辨率在不一樣圖片格式下,大小也相差很大。試了一下微信截圖工具,輸出的圖片比較大。因而放棄了該辦法。github

另外一個辦法是經過其它工具來處理。找了圖片在線壓縮網站和一款手機軟件,發如今圖片小於必定大小時壓縮無效。若是再繼續找其它工具,簡直就是折騰且浪費時間,因此也放棄了該辦法。微信

最後,仍是本身寫個代碼把圖片按原比例壓縮成了29KB,使用Thumbnailator庫,兩三行代碼搞定。網絡

2 縮略圖能夠作什麼?

縮略圖是應用極其普遍的,像頭像、圖片消息、商品圖片等,都會用到縮略圖。maven

好比,當你有了一個新的微信好友,你就能看到他的頭像,一開始這個頭像是一個比原圖更小的縮略圖。而你點擊查看原圖時,微信客戶端纔會給你下載原圖。由於你並不會對每一個人的頭像都感興趣,都會去查看清晰的原圖,一個小小的縮略圖已經能知足了。這樣能夠減輕網絡傳輸的負擔,加快響應速度。工具

微信傳圖片和視頻也是一樣的道理,先給你傳一個比較小的預覽,你點擊查看原圖或視頻播放纔給你傳更大的文件。學習

3 縮略圖的開源庫

縮略圖的開源庫不少:網站

(1)Thumbnailatorspa

GitHub:https://github.com/coobird/thumbnailator3d

不依賴外部庫,輕便高效,任何平臺適用,支持縮放、旋轉、截取,支持水印。

(2)Imgscalr

GitHub:https://github.com/rkalla/imgscalr

所有基於 Java 2D,不依賴外部庫,輕便高效,任何平臺適用,支持縮放、旋轉、截取,不支持水印。

本文主要講解Thumbnailator的使用,最新版本爲0.4.8,maven引入以下:

<dependency>
  <groupId>net.coobird</groupId>
  <artifactId>thumbnailator</artifactId>
  <version>0.4.8</version>
</dependency>複製代碼

4 經常使用操做

4.1 指定大小縮放

原圖爲4:3比例的圖片,爲4032x3024(圖片太大,網站沒法上傳原圖),以下:

file

當使用指定大小方式進行縮放時,默認是保持原比例的。

//參數小且比例與原比例同樣
//則按參數輸出結果
Thumbnails.of(originalPic)
  .size(400, 300)
  .toFile(picturePath + "climb-up.size.400X300.jpeg");
//參數大且比例不等
//則按比例放大,取最小的值
Thumbnails.of(originalPic)
  .size(4400, 3400)
  .toFile(picturePath + "climb-up.size.4400X3300.jpeg");
//參數小且比例不等
//則按比例縮小,取最小的值
Thumbnails.of(originalPic)
  .size(200, 300)
  .toFile(picturePath + "climb-up.size.200X150.jpeg");
//不保持比例
//則按參數輸出結果
Thumbnails.of(originalPic)
  .size(200, 300)
  .keepAspectRatio(false)
  .toFile(picturePath + "climb-up.size.notKeepRatio.200X300.jpeg");
//強制設置大小
//則按參數輸出結果,與上個例子同樣
Thumbnails.of(originalPic)
  .forceSize(200, 300)
  .toFile(picturePath + "climb-up.forceSize.200X300.jpeg");複製代碼

展現其中兩種結果:

(1)size(200, 300),結果爲200X150的圖片,比例仍是4:3。

file

(2)forceSize(200, 300),結果爲200X300的圖片,如原比例不一樣,會有變形。

file

4.2 按比例進行縮放

按比例進行縮放是指按寬和高的比例同時縮放,看下面代碼:

//比例小於1,縮小
//寬和高同時縮小爲原來的0.1倍
Thumbnails.of(originalPic)
  .scale(0.1f)
  .toFile(picturePath + "climb-up.scale.403X302.jpeg");
//比例大於1,放大
//寬和高同時放大爲原來的1.1倍
Thumbnails.of(originalPic)
  .scale(1.1f)
  .toFile(picturePath + "climb-up.scale.4435X3326.jpeg");複製代碼

4.3 按角度旋轉

按角度旋轉時,角度爲正數時,順時針;角度爲負數時,逆時針。代碼以下:

Thumbnails.of(originalPic)
  .size(400,300)
  .rotate(45)
  .toFile(picturePath + "climb-up.rotate.45.jpeg");複製代碼

壓縮並旋轉後的結果圖片以下所示:

file

4.4 添加水印

添加水印也是十分方便,咱們示例將水印放在右上角,代碼以下:

Thumbnails.of(originalPic)
  .size(2000,1500)
  .watermark(Positions.TOP_RIGHT, ImageIO.read(
    new File(picturePath + "pkslow.size.400X300.jpeg")), 0.5f)
  .toFile(picturePath + "climb-up.watermark.jpeg");複製代碼

加上水印後的圖片以下:

file

4.5 裁剪

代碼以下:

Thumbnails.of(originalPic)
  .sourceRegion(Positions.TOP_RIGHT, 1800, 1800)
  .size(400, 400)
  .toFile(picturePath + "climb-up.crop.jpeg");複製代碼

結果以下:

file

4.6 目錄下的文件批量操做

這個功能仍是很是有用,能夠操做目錄下的全部圖片,並指定文件名輸出,如指定前綴,代碼以下:

Thumbnails.of(new File("/pictures/201912/").listFiles())
  .size(400, 400)
  .toFiles(Rename.PREFIX_DOT_THUMBNAIL);複製代碼

操做後的生成的結果以下:

file

5 總結

Thumbnailator庫操做方便,支持縮放、旋轉、裁剪、水印等功能,並且沒有其它依賴,值得了解學習。

歡迎關注公衆號<南瓜慢說>,將持續爲你更新...

file

多讀書,多分享;多寫做,多整理。

相關文章
相關標籤/搜索