zoukankan      html  css  js  c++  java
  • java通过使用Thumbnails实现图片压缩放大

    最近项目中需要照相功能,用java写了一个客户端照相工具后发现保存的图片比较大,于是使用了Thumbnails进行图片压缩,在这里简单记录一下Thumbnails的使用:
    1.引入maven依赖:

    		<dependency>
    			<groupId>net.coobird</groupId>
    			<artifactId>thumbnailator</artifactId>
    			<version>0.4.8</version>
    		</dependency>
    

    2.使用Thumbnails进行图片压缩:
    在这里插入图片描述
    Thumbnails的of方法是用于输入资源的,可以看到可以传入BufferedImage对象、File对象、文件路径字符串等。

    Thumbnails缩放图片可以分为两种类型:
    a.大小固定:

    	try {
    			Thumbnails.of("d:/1.png").size(200, 300).allowOverwrite(true).toFile(new File("d:/2.png"));
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    

    在size方法里写固定大小,然后使用to方法写出。

    b.按比例缩放:

    	try {
    			// Thumbnails.of("d:/1.png").scale(1).outputQuality(0.5f).allowOverwrite(true).toFile(new File("d:/2.png"));
    			Thumbnails.of("d:/1.png").scale(1, 1.2).outputQuality(0.5f).allowOverwrite(true).toFile(new File("d:/2.png"));
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    

    scale方法是指按照长宽大小缩放,1个参数的时候是整体缩放,它有一个重载方法,两个参数,可以分别指定长和宽的缩放率;outputQuality方法是指输出质量,越低图片占用内存越小,清晰度相应的也就越低。

    这里使用Thumbnails压缩一下图片的BASE64编码,当然不能直接压缩BASE64字符串了,可以先压缩一下图片再转为BASE64编码:
    引入一下Apache的编码工具:

    		<dependency>
    			<groupId>commons-codec</groupId>
    			<artifactId>commons-codec</artifactId>
    			<version>1.13</version>
    		</dependency>
    

    核心代码如下:

    BufferedImage asBufferedImage = Thumbnails.of("D:\0.png").size(100, 120).allowOverwrite(true)
    				.asBufferedImage();
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    ImageIO.write(asBufferedImage, "png", bos);
    System.out.println(Base64.encodeBase64String(bos.toByteArray()));
    
    一颗安安静静的小韭菜。文中如果有什么错误,欢迎指出。
  • 相关阅读:
    Shell变量、函数
    Shell
    springMVC基础讲解
    Spring(二)--IoC&AOP
    Spring(一)--简介
    Mybatis(二)--SqlMapConfig.xml配置文件
    Mybatis(一)--简介
    框架的介绍
    博文推荐 | 下一代消息平台 Pulsar 到底是什么
    Pulsar 2.7.0 新增特性概览:事务支持、Topic 级别策略配置等
  • 原文地址:https://www.cnblogs.com/c-Ajing/p/13448379.html
Copyright © 2011-2022 走看看