java 实现图片裁剪指定宽度和高度

今天在工作中遇到了个问题:用户上传的人脸图片像素过大,硬件机无法识别,所以要对文件进行裁剪

public class ImageCropUtils {


    /**
     * @param fromFileStr 要裁剪的图片路径
     * @param saveToFileStr 保存的图片地址
     * @param suffix 图片后缀
     * @param width 裁剪后宽度
     * @param height 裁剪后高度
     *
     * @return 成功或失败
     * */
    public  static boolean createThumbnail( String fromFileStr, String saveToFileStr, String suffix, int width, int height ) throws Exception {
        // fileExtNmae是图片的格式 gif JPG 或png
        // String fileExtNmae="";

        File F = new File(fromFileStr);

        if (!F.isFile()){
            return false;
        }


        File ThF = new File(saveToFileStr);
        BufferedImage buffer = ImageIO.read(F);
        /*
         * 核心算法,计算图片的压缩比
         */
        int w= buffer.getWidth();
        int h=buffer.getHeight();
        double ratiox = 1.0d;
        double ratioy = 1.0d;

        ratiox= w * ratiox / width;
        ratioy= h * ratioy / height;

        if( ratiox >= 1){
            if(ratioy < 1){
                ratiox = height * 1.0 / h;
            }else{
                if(ratiox > ratioy){
                    ratiox = height * 1.0 / h;
                }else{
                    ratiox = width * 1.0 / w;
                }
            }
        }else{
            if(ratioy < 1){
                if(ratiox > ratioy){
                    ratiox = height * 1.0 / h;
                }else{
                    ratiox = width * 1.0 / w;
                }
            }else{
                ratiox = width * 1.0 / w;
            }
        }
        /*
         * 对于图片的放大或缩小倍数计算完成,ratiox大于1,则表示放大,否则表示缩小
         */
        AffineTransformOp op = new AffineTransformOp(AffineTransform
                .getScaleInstance(ratiox, ratiox), null);
        buffer = op.filter(buffer, null);
        //从放大的图像中心截图
        buffer = buffer.getSubimage((buffer.getWidth()-width)/2, (buffer.getHeight() - height) / 2, width, height);
        //写入文件
        ImageIO.write(buffer, suffix, ThF);

        return true;
    }

    /**
     * @param fromFileInputStream 要裁剪的图片
     * @param saveToFileStr 保存的图片地址
     * @param suffix 图片后缀
     * @param width 裁剪后宽度
     * @param height 裁剪后高度
     *
     * @return 成功或失败
     * */
    public  static boolean createThumbnail(InputStream fromFileInputStream, String saveToFileStr, String suffix, int width, int height ) throws Exception{
        // fileExtNmae是图片的格式 gif JPG 或png
        // String fileExtNmae="";



        File ThF = new File(saveToFileStr);

        BufferedImage buffer = ImageIO.read(fromFileInputStream);
        /*
         * 核心算法,计算图片的压缩比
         */
        int w= buffer.getWidth();
        int h=buffer.getHeight();
        double ratiox = 1.0d;
        double ratioy = 1.0d;

        ratiox= w * ratiox / width;
        ratioy= h * ratioy / height;

        if( ratiox >= 1){
            if(ratioy < 1){
                ratiox = height * 1.0 / h;
            }else{
                if(ratiox > ratioy){
                    ratiox = height * 1.0 / h;
                }else{
                    ratiox = width * 1.0 / w;
                }
            }
        }else{
            if(ratioy < 1){
                if(ratiox > ratioy){
                    ratiox = height * 1.0 / h;
                }else{
                    ratiox = width * 1.0 / w;
                }
            }else{
                ratiox = width * 1.0 / w;
            }
        }
        /*
         * 对于图片的放大或缩小倍数计算完成,ratiox大于1,则表示放大,否则表示缩小
         */
        AffineTransformOp op = new AffineTransformOp(AffineTransform
                .getScaleInstance(ratiox, ratiox), null);
        buffer = op.filter(buffer, null);
        //从放大的图像中心截图
        buffer = buffer.getSubimage((buffer.getWidth()-width)/2, (buffer.getHeight() - height) / 2, width, height);
        try {
            ImageIO.write(buffer, suffix, ThF);
        } catch (Exception ex) {
            ex.printStackTrace();
        }

        return true;
    }









    public static void main(String[] args) {

        try {
            ImageCropUtils.createThumbnail("G:\\face\\韦钰莹.JPG", "G:\\face\\韦钰莹3.JPG","png",280,280);
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值