简介
Thumbnailator是一个开源的Java项目,它提供了非常简单的API来对图片进行缩放、旋转以及加水印的处理。
有多简单呢?简单到一行代码就可以完成图片处理。形式如下:
1 2 3 4
| Thumbnails.of(new File("path/io/directory").listFiles()) .size(640,480) .outputFormat("jpg") .toFiles(Rename.PREFIX_DOT_THUMBNAIL);
|
核心API
Thumbnails
Thumbnails是使用 Thumbnailator 创建缩略图的主入口。
它提供了一组初始化Thumbnails.Builder的接口。
先看下这组接口的声明:
1 2 3 4 5 6 7 8 9 10 11 12
| 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) {...}
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 提供了一组函数链形式的接口来设置缩放图参数。
以设置大小函数为例:
1 2 3 4 5 6 7 8 9 10 11
| 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; }
|
通过返回 this 指针,使得设置参数函数可以以链式调用的方式来使用,形式如下:
1 2 3 4 5 6
| 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提供了一组重载函数来输出生成的缩放图
函数声明如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| 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 的工作步骤十分简单,可分为三步:
- 输入:
Thumbnails根据输入初始化构造器 – Thumbnails.Builder。
- 设置:
Thumbnails.Builder设置缩放图片的参数。
- 输出:
Thumbnails.Builder输出图片文件或图片流。
实战
前文介绍了 Thumbnailator 的核心 API,接下来我们就可以通过实战来看看 Thumbnailator 究竟可以做些什么。
Thumbnailator 生成什么样的图片,是根据设置参数来决定的。
引入
maven 项目中引入依赖:
1 2 3 4 5
| <dependency> <groupId>net.coobird</groupId> <artifactId>thumbnailator</artifactId> <version>0.4.8</version> </dependency>
|
图片缩放
Thumbnails.Builder的size函数可以设置图片精确的宽度和高度,也可以用scale函数设置缩放比例。
1 2 3 4 5 6 7 8 9 10 11
| 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");
|
图片旋转
Thumbnails.Builder的size函数可以设置新图片的旋转角度
1 2 3 4 5 6 7 8 9
| 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");
|
正数:顺时针 负数:逆时针
加水印
Thumbnails.Builder的watermark函数可以为图片添加水印图片。第一个参数是水印的位置;第二个参数是水印图片的缓存数据;第三个参数是透明度。
1 2 3 4 5
| 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");
|
批量处理图片
例如批量为图片加水印
1 2 3 4 5 6 7
| 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);
|
参考
Thumbnailator 官方示例文档