一行代碼搞定圖片縮放、旋轉、加水印

CharlotteNS 7年前發布 | 18K 次閱讀 Java Java開發

概述

Thumbnailator 是一個開源的 Java 項目,它提供了非常簡單的 API 來對圖片進行縮放、旋轉以及加水印的處理。

有多簡單呢?簡單到一行代碼就可以完成圖片處理。形式如下:

Thumbnails.of(new File("path/to/directory").listFiles())
    .size(640, 480)
    .outputFormat("jpg")
    .toFiles(Rename.PREFIX_DOT_THUMBNAIL);

當然,Thumbnailator 還有一些使用細節,下面我會一一道來。

核心 API

Thumbnails

Thumbnails 是使用 Thumbnailator 創建縮略圖的主入口。

它提供了一組初始化 Thumbnails.Builder 的接口。

先看下這組接口的聲明:

// 可變長度參數列表
public static Builder<File> of(String... files) {...}
public static Builder<File> of(File... files) {...}
public static Builder<URL> of(URL... urls) {...}
public static Builder<? extends InputStream> of(InputStream... inputStreams) {...}
public static Builder<BufferedImage> of(BufferedImage... images) {...}
// 迭代器(所有實現 Iterable 接口的 Java 對象都可以,當然也包括 List、Set)
public static Builder<File> fromFilenames(Iterable<String> files) {...}
public static Builder<File> fromFiles(Iterable<File> files) {...}
public static Builder<URL> fromURLs(Iterable<URL> urls) {...}
public static Builder<InputStream> fromInputStreams(Iterable<? extends InputStream> inputStreams) {...}
public static Builder<BufferedImage> fromImages(Iterable<BufferedImage> images) {...}

很顯然, Thumbnails 允許通過傳入文件名、文件、網絡圖的URL、圖片流、圖片緩存多種方式來初始化構造器 。

因此,你可以根據實際需求來靈活的選擇圖片的輸入方式。

需要注意一點: 如果輸入是多個對象(無論你是直接輸入容器對象或使用可變參數方式傳入多個對象),則輸出也必須選用輸出多個對象的方式,否則會報異常。

Thumbnails.Builder

Thumbnails.Builder 是 Thumbnails 的內部靜態類。它用于設置生成縮略圖任務的相關參數。

注: Thumbnails.Builder 的構造函數是私有函數。所以,它只允許通過 Thumbnails 的實例化函數來進行初始化。

設置參數的函數

Thumbnails.Builder 提供了一組函數鏈形式的接口來設置縮放圖參數。

以設置大小函數為例:

public Builder<T> size(int width, int height)
{
    updateStatus(Properties.SIZE, Status.ALREADY_SET);
    updateStatus(Properties.SCALE, Status.CANNOT_SET);

validateDimensions(width, height);
this.width = width;
this.height = height;

return this;

}</code></pre>

通過返回this指針,使得設置參數函數可以以鏈式調用的方式來使用,形式如下:

Thumbnails.of(new File("original.jpg"))
        .size(160, 160)
        .rotate(90)
        .watermark(Positions.BOTTOM_RIGHT, ImageIO.read(new File("watermark.png")), 0.5f)
        .outputQuality(0.8)
        .toFile(new File("image-with-watermark.jpg"));

好處,不言自明:那就是大大簡化了代碼。

輸出函數

Thumbnails.Builder 提供了一組重載函數來輸出生成的縮放圖。

函數聲明如下:

// 返回圖片緩存
public List<BufferedImage> asBufferedImages() throws IOException {...}
public BufferedImage asBufferedImage() throws IOException {...}
// 返回文件列表
public List<File> asFiles(Iterable<File> iterable) throws IOException {...}
public List<File> asFiles(Rename rename) throws IOException {...}
public List<File> asFiles(File destinationDir, Rename rename) throws IOException {...}
// 創建文件
public void toFile(File outFile) throws IOException {...}
public void toFile(String outFilepath) throws IOException {...}
public void toFiles(Iterable<File> iterable) throws IOException {...}
public void toFiles(Rename rename) throws IOException {...}
public void toFiles(File destinationDir, Rename rename) throws IOException {...}
// 創建輸出流
public void toOutputStream(OutputStream os) throws IOException {...}
public void toOutputStreams(Iterable<? extends OutputStream> iterable) throws IOException {...}

工作流

Thumbnailator 的工作步驟十分簡單,可分為三步:

  1. 輸入: Thumbnails 根據輸入初始化構造器—— Thumbnails.Builder 。

  2. 設置: Thumbnails.Builder 設置縮放圖片的參數。

  3. 輸出: Thumbnails.Builder 輸出圖片文件或圖片流。

實戰

前文介紹了 Thumbnailator 的核心 API,接下來我們就可以通過實戰來看看 Thumbnailator 究竟可以做些什么。

Thumbnailator 生成什么樣的圖片,是根據設置參數來決定的。

安裝

maven項目中引入依賴:

<dependency>
  <groupId>net.coobird</groupId>
  <artifactId>thumbnailator</artifactId>
  <version>[0.4, 0.5)</version>
</dependency>

圖片縮放

Thumbnails.Builder 的 size 函數可以設置新圖片精確的寬度和高度,也可以用 scale 函數設置縮放比例。

Thumbnails.of("oldFile.png")
        .size(16, 16)
        .toFile("newFile_16_16.png");

Thumbnails.of("oldFile.png") .scale(2.0) .toFile("newFile_scale_2.0.png");

Thumbnails.of("oldFile.png") .scale(1.0, 0.5) .toFile("newFile_scale_1.0_0.5.png");</code></pre>

oldFile.png

newFile_scale_1.0_0.5.png

圖片旋轉

Thumbnails.Builder 的 size 函數可以設置新圖片的旋轉角度。

Thumbnails.of("oldFile.png")
        .scale(0.8)
        .rotate(90)
        .toFile("newFile_rotate_90.png");

Thumbnails.of("oldFile.png") .scale(0.8) .rotate(180) .toFile("newFile_rotate_180.png");</code></pre>

newFile_rotate_90.png

加水印

Thumbnails.Builder 的 watermark 函數可以為圖片添加水印圖片。第一個參數是水印的位置;第二個參數是水印圖片的緩存數據;第三個參數是透明度。

BufferedImage watermarkImage = ImageIO.read(new File("wartermarkFile.png"));
Thumbnails.of("oldFile.png")
        .scale(0.8)
        .watermark(Positions.BOTTOM_LEFT, watermarkImage, 0.5f)
        .toFile("newFile_watermark.png");

wartermarkFile.png

newFile_watermark.png

批量處理圖片

下面以批量給圖片加水印來展示一下如何處理多個圖片文件。

BufferedImage watermarkImage = ImageIO.read(new File("wartermarkFile.png"));

File destinationDir = new File("D:\watermark\"); Thumbnails.of("oldFile.png", "oldFile2.png") .scale(0.8) .watermark(Positions.BOTTOM_LEFT, watermarkImage, 0.5f) .toFiles(destinationDir, Rename.PREFIX_DOT_THUMBNAIL);</code></pre>

 

參考

Thumbnailator 官方示例文檔

 

來自:http://www.cnblogs.com/jingmoxukong/p/6293877.html

 

 本文由用戶 CharlotteNS 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!