Thumbnailator 应用指南
简介
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 的接口。
先看下这组接口的声明:
很显然,Thumbnails 允许通过传入文件名、文件、网络图的 URL、图片流、图片缓存多种方式来初始化构造器。
因此,你可以根据实际需求来灵活的选择图片的输入方式。
需要注意一点:如果输入是多个对象(无论你是直接输入容器对象或使用可变参数方式传入多个对象),则输出也必须选用输出多个对象的方式,否则会报异常。
Thumbnails.Builder
Thumbnails.Builder 是 Thumbnails 的内部静态类。它用于设置生成缩略图任务的相关参数。
注:Thumbnails.Builder 的构造函数是私有函数。所以,它只允许通过 Thumbnails 的实例化函数来进行初始化。
设置参数的函数
Thumbnails.Builder 提供了一组函数链形式的接口来设置缩放图参数。
以设置大小函数为例:
通过返回 this 指针,使得设置参数函数可以以链式调用的方式来使用,形式如下:
好处,不言自明:那就是大大简化了代码。
输出函数
Thumbnails.Builder 提供了一组重载函数来输出生成的缩放图。
函数声明如下:
工作流
Thumbnailator 的工作步骤十分简单,可分为三步:
输入:
Thumbnails根据输入初始化构造器——Thumbnails.Builder。设置:
Thumbnails.Builder设置缩放图片的参数。输出:
Thumbnails.Builder输出图片文件或图片流。
更多详情可以参考: Thumbnailator 官网 javadoc
实战
前文介绍了 Thumbnailator 的核心 API,接下来我们就可以通过实战来看看 Thumbnailator 究竟可以做些什么。
Thumbnailator 生成什么样的图片,是根据设置参数来决定的。
安装
maven 项目中引入依赖:
图片缩放
Thumbnails.Builder 的 size 函数可以设置新图片精确的宽度和高度,也可以用 scale 函数设置缩放比例。
oldFile.png

newFile_scale_1.0_0.5.png

图片旋转
Thumbnails.Builder 的 size 函数可以设置新图片的旋转角度。
newFile_rotate_90.png

加水印
Thumbnails.Builder 的 watermark 函数可以为图片添加水印图片。第一个参数是水印的位置;第二个参数是水印图片的缓存数据;第三个参数是透明度。
wartermarkFile.png

newFile_watermark.png

批量处理图片
下面以批量给图片加水印来展示一下如何处理多个图片文件。
需要参考完整测试例代码请 点击这里
参考
Last updated
Was this helpful?