java后端实现图片旋转功能

                    java后端实现图片旋转功能
                    
    原因:
        最近在项目中,需要图片旋转之后重新替换ftp上的图片文件,vue可以实现图片旋转完后转成base64提交后端,转换之后,<img>标签不能显示,由此走了
        捷径,直接在后端进行旋转,初学分享,勿喷
        
        
    前端vue代码
      updateDirection (degImage){
        axios({
          url: this.$http.adornUrl('invoices/reversal'),
          method: 'get',
          data: {
            'imgUrl': this.imgUrl,        // 图片地址
            'deg': degImage.imgDeg        //旋转角度, 90 ,180 ,270
          }
        }).then(({data}) => {
          
        })
      },
      
      
    java代码:
        if(deg.equals("-90")) deg="270";
        if(deg.equals("-180")) deg="180";
        if((deg.equals("-270"))) deg="90";
        try {
            BufferedImage src = ImageIO.read(new File(imgUrl));
            BufferedImage des = RotateImage.Rotate(src, Integer.valueOf(deg));
            ImageIO.write(des, "jpg", new File(imgUrl));
        }catch (Exception e){
           e.printStackTrace();
        }
        
        
        // 百度
        package com.qingtengtech.web.modules.sys.controller;

        import java.awt.*;
        import java.awt.image.BufferedImage;

        
        public class RotateImage {
            public static BufferedImage Rotate(Image src, int angel) {
                int src_width = src.getWidth(null);
                int src_height = src.getHeight(null);
        // calculate the new image size
                Rectangle rect_des = CalcRotatedSize(new Rectangle(new Dimension(
                        src_width, src_height)), angel);


                BufferedImage res = null;
                res = new BufferedImage(rect_des.width, rect_des.height,
                        BufferedImage.TYPE_INT_RGB);
                Graphics2D g2 = res.createGraphics();
        // transform
                g2.translate((rect_des.width - src_width) / 2,
                        (rect_des.height - src_height) / 2);
                g2.rotate(Math.toRadians(angel), src_width / 2, src_height / 2);


                g2.drawImage(src, null, null);
                return res;
            }


            public static Rectangle CalcRotatedSize(Rectangle src, int angel) {
        // if angel is greater than 90 degree, we need to do some conversion
                if (angel >= 90) {
                    if(angel / 90 % 2 == 1){
                        int temp = src.height;
                        src.height = src.width;
                        src.width = temp;
                    }
                    angel = angel % 90;
                }


                double r = Math.sqrt(src.height * src.height + src.width * src.width) / 2;
                double len = 2 * Math.sin(Math.toRadians(angel) / 2) * r;
                double angel_alpha = (Math.PI - Math.toRadians(angel)) / 2;
                double angel_dalta_width = Math.atan((double) src.height / src.width);
                double angel_dalta_height = Math.atan((double) src.width / src.height);


                int len_dalta_width = (int) (len * Math.cos(Math.PI - angel_alpha
                        - angel_dalta_width));
                int len_dalta_height = (int) (len * Math.cos(Math.PI - angel_alpha
                        - angel_dalta_height));
                int des_width = src.width + len_dalta_width * 2;
                int des_height = src.height + len_dalta_height * 2;
                return new java.awt.Rectangle(new Dimension(des_width, des_height));
            }
        }
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值