一行代碼搞定圖片縮放、旋轉(zhuǎn)、加水印

概述

Thumbnailator 是一個(gè)開(kāi)源的 Java 項(xiàng)目,它提供了非常簡(jiǎn)單的 API 來(lái)對(duì)圖片進(jìn)行縮放、旋轉(zhuǎn)以及加水印的處理。

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

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

當(dāng)然,Thumbnailator 還有一些使用細(xì)節(jié),下面我會(huì)一一道來(lái)。

核心 API

Thumbnails

Thumbnails 是使用 Thumbnailator 創(chuàng)建縮略圖的主入口。

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

先看下這組接口的聲明:

// 可變長(zhǎng)度參數(shù)列表
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) {...}
// 迭代器(所有實(shí)現(xiàn) Iterable 接口的 Java 對(duì)象都可以,當(dāng)然也包括 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 允許通過(guò)傳入文件名、文件、網(wǎng)絡(luò)圖的URL、圖片流、圖片緩存多種方式來(lái)初始化構(gòu)造器

因此,你可以根據(jù)實(shí)際需求來(lái)靈活的選擇圖片的輸入方式。

需要注意一點(diǎn):如果輸入是多個(gè)對(duì)象(無(wú)論你是直接輸入容器對(duì)象或使用可變參數(shù)方式傳入多個(gè)對(duì)象),則輸出也必須選用輸出多個(gè)對(duì)象的方式,否則會(huì)報(bào)異常。

Thumbnails.Builder

Thumbnails.BuilderThumbnails 的內(nèi)部靜態(tài)類。它用于設(shè)置生成縮略圖任務(wù)的相關(guān)參數(shù)。

注:Thumbnails.Builder 的構(gòu)造函數(shù)是私有函數(shù)。所以,它只允許通過(guò) Thumbnails 的實(shí)例化函數(shù)來(lái)進(jìn)行初始化。

設(shè)置參數(shù)的函數(shù)

Thumbnails.Builder 提供了一組函數(shù)鏈形式的接口來(lái)設(shè)置縮放圖參數(shù)。

以設(shè)置大小函數(shù)為例:

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;
}

通過(guò)返回this指針,使得設(shè)置參數(shù)函數(shù)可以以鏈?zhǔn)秸{(diào)用的方式來(lái)使用,形式如下:

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"));

好處,不言自明:那就是大大簡(jiǎn)化了代碼。

輸出函數(shù)

Thumbnails.Builder 提供了一組重載函數(shù)來(lái)輸出生成的縮放圖。

函數(shù)聲明如下:

// 返回圖片緩存
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 {...}
// 創(chuàng)建文件
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 {...}
// 創(chuàng)建輸出流
public void toOutputStream(OutputStream os) throws IOException {...}
public void toOutputStreams(Iterable<? extends OutputStream> iterable) throws IOException {...}

工作流

Thumbnailator 的工作步驟十分簡(jiǎn)單,可分為三步:

  1. 輸入Thumbnails 根據(jù)輸入初始化構(gòu)造器—— Thumbnails.Builder

  2. 設(shè)置Thumbnails.Builder 設(shè)置縮放圖片的參數(shù)。

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

更多詳情可以參考: <u>Thumbnailator 官網(wǎng)javadoc</u>

實(shí)戰(zhàn)

前文介紹了 Thumbnailator 的核心 API,接下來(lái)我們就可以通過(guò)實(shí)戰(zhàn)來(lái)看看 Thumbnailator 究竟可以做些什么。

Thumbnailator 生成什么樣的圖片,是根據(jù)設(shè)置參數(shù)來(lái)決定的。

安裝

maven項(xiàng)目中引入依賴:

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

圖片縮放

Thumbnails.Buildersize 函數(shù)可以設(shè)置新圖片精確的寬度和高度,也可以用 scale 函數(shù)設(shè)置縮放比例。

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");

oldFile.png

lion_scale_1.0.png

newFile_scale_1.0_0.5.png

lion_scale_1.0_0.5.png

圖片旋轉(zhuǎn)

Thumbnails.Buildersize 函數(shù)可以設(shè)置新圖片的旋轉(zhuǎn)角度。

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");

newFile_rotate_90.png

lion2_rotate_90.png

加水印

Thumbnails.Builderwatermark 函數(shù)可以為圖片添加水印圖片。第一個(gè)參數(shù)是水印的位置;第二個(gè)參數(shù)是水印圖片的緩存數(shù)據(jù);第三個(gè)參數(shù)是透明度。

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

wartermark.png

newFile_watermark.png

lion2_watermark.png

批量處理圖片

下面以批量給圖片加水印來(lái)展示一下如何處理多個(gè)圖片文件。

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);

需要參考完整測(cè)試?yán)a請(qǐng) <u>點(diǎn)擊這里</u>

參考

Thumbnailator 官方示例文檔

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • ¥開(kāi)啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開(kāi)一個(gè)線程,因...
    小菜c閱讀 6,554評(píng)論 0 17
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,993評(píng)論 19 139
  • 毒膽:4** 雙膽:46* 三膽:469 五碼:14679 復(fù)試:47/69/1289 和差:6 7 跨:4 5 ...
    單挑果凍閱讀 210評(píng)論 1 2
  • 夢(mèng)斷往事 卻生情絲 淚撒衣衫 卻見(jiàn)雨落 手揮金戈 卻消戰(zhàn)意 眼見(jiàn)花開(kāi) 卻看無(wú)果 耳聽(tīng)琴音 卻說(shuō)弦斷 魂入奈何 卻聞...
    淺夏微涼閱讀 406評(píng)論 0 2
  • 最近天氣總是陰雨連綿許久不見(jiàn)陽(yáng)光,曬在陽(yáng)臺(tái)外的衣服總是好些天干不了,這些往往都是造成我心情不好的主要因素之一。...
    八荒阿閱讀 272評(píng)論 0 0