zoukankan      html  css  js  c++  java
  • 使用第三方工具Thumbnailator动态改变图片尺寸

    Thumbnailator项目git地址:https://github.com/coobird/thumbnailator

    使用步骤

    1.添加依赖

    <!-- Thumbnailator图片处理 -->
    <dependency>
    <groupId>net.coobird</groupId>
    <artifactId>thumbnailator</artifactId>
    <version>0.4.8</version>
    </dependency>
    2.源图片来源有2种方式:第一种从文件中读取图片,第二种从文件流中读取图片
    try {
                Thumbnails.of(new File("C:/Users/Pictures/Saved Pictures/logo1.png"))
                        .size(500, 500)
                        .toFile(new File("D:/data/images/thumbnai3.jpg"));
            } catch (IOException e) {
                e.printStackTrace();
            }
    View Code
    try {
                InputStream inputStream = new FileInputStream(new File("C:/Users/Pictures/Saved Pictures/logo1.png"));
                Thumbnails.of(inputStream)
                        .size(500, 500)
                        .toFile(new File("D:/data/images/thumbnai3.jpg"));
            } catch (IOException e) {
                e.printStackTrace();
            }
    View Code

    3.输出图片方式:输出图片文件或文件流

    Thumbnails.of(new File("C:/Users/Pictures/Saved Pictures/logo1.png"))
                        .size(500, 500)
                        .toFile(new File("D:/data/images/thumbnai3.jpg"));
    View Code

    或者

    InputStream inputStream = new ByteArrayInputStream(fileContent);
                    BufferedImage afterImage = Thumbnails.of(inputStream)
                            .size(afterSize, afterSize)            //按指定大小把图片进行缩和放(会遵循原图高宽比例)
    //                            .scale(1.00f)        //按照指定比例进行缩小和放大
    //                            .rotate(90)         //旋转图片,rotate(角度),正数则为顺时针,负数则为逆时针
    //                            .outputQuality(1)    //压缩图片文件大小,1为最高质量
    //                            .watermark(Positions.CENTER,ImageIO.read(waterPic),0.5f)    //给图片加水印,watermark(位置,水印图,透明度)Positions.CENTER表示加在中间
    //                            .sourceRegion(Positions.CENTER,300,300) //用sourceRegion()实现图片裁剪,图片中心300*300的区域,Positions.CENTER表示中心
    //                            .outputFormat("png")    //用outputFormat(图像格式)转换图片格式,保持原尺寸不变
                            .asBufferedImage();
    View Code
  • 相关阅读:
    HTML5 WebSocket 权威指南 学习一 (第二章 WebSocket API)
    VM虚拟机 Centos7 lnmp环境 配置域名问题 windows浏览器访问的问题
    https方式下 git push 每次都要输入密码的解决办法
    浏览器禁用Cookie
    使用Nginx反向代理进行负载均衡
    使用Ajax异步上传文件
    装配Bean
    关于Struts2配置文件名修改的问题
    NIO
    部署描述符
  • 原文地址:https://www.cnblogs.com/mora1988/p/9967566.html
Copyright © 2011-2022 走看看