图片压缩成指定大小

不用截取图片,按指定大小截取。

 

package com.boco.vnms.common.util;

import java.awt.Color;  
import java.awt.Graphics2D;  
import java.awt.Image;  
import java.awt.image.BufferedImage;  
import java.awt.image.ConvolveOp;  
import java.awt.image.Kernel;  
import java.io.File;  
import java.io.FileOutputStream;  
import java.io.InputStream;  
import org.apache.commons.fileupload.FileItem;  
import org.apache.log4j.Logger;      
import com.sun.image.codec.jpeg.JPEGCodec;  
import com.sun.image.codec.jpeg.JPEGImageEncoder; 

public class ImageUtil {  
    /**  
     * Logger for this class  
     */ 
    private static final Logger logger = Logger.getLogger(ImageUtil.class);      
    public static void imageScale(String srcFilePath, String targetFilePath,  
            int width, int height) {  
         imageScale(new File(srcFilePath), new File(targetFilePath), width,  
                height);  
    }  
    public static void imageScale(File srcFile, File targetFile, int width, int height) {  
        try {  
            Image image = javax.imageio.ImageIO.read(srcFile);  
            image = image.getScaledInstance(width, height,  
                    Image.SCALE_AREA_AVERAGING);  
            // Make a BufferedImage from the Image.  
            BufferedImage mBufferedImage = new BufferedImage(width, height,  
                    BufferedImage.TYPE_INT_RGB);  
            Graphics2D g2 = mBufferedImage.createGraphics();              
            g2.drawImage(image, 0, 0, width, height, Color.white, null);  
            g2.dispose();  
            float[] kernelData2 = { -0.125f, -0.125f, -0.125f, -0.125f, 2,  
                    -0.125f, -0.125f, -0.125f, -0.125f };  
            Kernel kernel = new Kernel(3, 3, kernelData2);  
           ConvolveOp cOp = new ConvolveOp(kernel, ConvolveOp.EDGE_NO_OP, null);  
            mBufferedImage = cOp.filter(mBufferedImage, null);  
   
           File targetDir = targetFile.getParentFile();  
            if (!targetDir.exists())  
                targetDir.mkdirs();  
  
            FileOutputStream out = new FileOutputStream(targetFile);  
            JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);  
            encoder.encode(mBufferedImage);  
            out.close();  
        } catch (Exception e) {  
           logger.error(  
                    "imageScale(String, String, int, int) - 图片压缩出错 - srcFilePath=" 
                            + srcFile.getPath() + ", targeFilePath=" 
                           + targetFile.getPath() + ", width=" + width  
                           + ", height=" + height, e);  
        }  
    }  
   
   public void imageScale(FileItem fileItem, String targetFilePath, int width,  
            int height) {  
        try {  
            InputStream input = fileItem.getInputStream();  
            Image image = javax.imageio.ImageIO.read(input);  
   
            image = image.getScaledInstance(width, height,  
                    Image.SCALE_AREA_AVERAGING);  
            BufferedImage mBufferedImage = new BufferedImage(width, height,  
                    BufferedImage.TYPE_INT_RGB);  
            Graphics2D g2 = mBufferedImage.createGraphics();  
   
            g2.drawImage(image, 0, 0, width, height, Color.white, null);  
            g2.dispose();  
   
            float[] kernelData2 = { -0.125f, -0.125f, -0.125f, -0.125f, 2,  
                    -0.125f, -0.125f, -0.125f, -0.125f };  
            Kernel kernel = new Kernel(3, 3, kernelData2);  
            ConvolveOp cOp = new ConvolveOp(kernel, ConvolveOp.EDGE_NO_OP, null);  
            mBufferedImage = cOp.filter(mBufferedImage, null);  
   
            File target = new File(targetFilePath);  
            File targetDir = target.getParentFile();  
            if (!targetDir.exists())  
                targetDir.mkdirs();  
   
            FileOutputStream out = new FileOutputStream(targetFilePath);  
            JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);  
            encoder.encode(mBufferedImage);  
            out.close();  
            input.close();  
        } catch (Exception e) {  
            logger.error(  
                    "imageScale(String, String, int, int) - 图片压缩出错 - fileItem=" 
                           + fileItem.getName() + ", targetFilePath=" 
                      + targetFilePath + ", width=" + width + ", height=" 
                     + height, e);  
   }  
  } 

public static void main(String[] args) {
   imageScale("D:/xx.jpg", "D:/xx.jpg",200, 100);
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值