欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

使用java怎么對圖片的角度進(jìn)行旋轉(zhuǎn)

這篇文章給大家介紹使用java怎么對圖片的角度進(jìn)行旋轉(zhuǎn),內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:主機域名、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、獨山子網(wǎng)站維護(hù)、網(wǎng)站推廣。

Java可以用來干什么

Java主要應(yīng)用于:1. web開發(fā);2. Android開發(fā);3. 客戶端開發(fā);4. 網(wǎng)頁開發(fā);5. 企業(yè)級應(yīng)用開發(fā);6. Java大數(shù)據(jù)開發(fā);7.游戲開發(fā)等。

方法一:普通方法實現(xiàn)圖片旋轉(zhuǎn)

/**
   * 圖像旋轉(zhuǎn)
   * @param src
   * @param angel
   * @return
*/
  public static BufferedImage Rotate(Image src, double 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_3BYTE_BGR);
    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, double 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));
    len_dalta_width=len_dalta_width>0?len_dalta_width:-len_dalta_width;
 
    int len_dalta_height = (int) (len * Math.cos(Math.PI - angel_alpha
        - angel_dalta_height));
    len_dalta_height=len_dalta_height>0?len_dalta_height:-len_dalta_height;
 
    int des_width = src.width + len_dalta_width * 2;
    int des_height = src.height + len_dalta_height * 2;
    des_width=des_width>0?des_width:-des_width;
    des_height=des_height>0?des_height:-des_height;
    return new java.awt.Rectangle(new Dimension(des_width, des_height));
}

方法二:opencv實現(xiàn)圖片旋轉(zhuǎn)

 /**
   * opencv實現(xiàn)圖片旋轉(zhuǎn)
   * @param splitImage
   * @param angle
   * @return
*/
  public static Mat rotate3(Mat splitImage, double angle)
  {
    double thera = angle * Math.PI / 180;
    double a = Math.sin(thera);
    double b = Math.cos(thera);
 
    int wsrc = splitImage.width();
    int hsrc = splitImage.height();
 
    int wdst = (int) (hsrc * Math.abs(a) + wsrc * Math.abs(b));
    int hdst = (int) (wsrc * Math.abs(a) + hsrc * Math.abs(b));
    Mat imgDst = new Mat(hdst, wdst, splitImage.type());
 
    Point pt = new Point(splitImage.cols() / 2, splitImage.rows() / 2);
    // 獲取仿射變換矩陣
    Mat affineTrans = Imgproc.getRotationMatrix2D(pt, angle, 1.0);
 
    System.out.println(affineTrans.dump());
    // 改變變換矩陣第三列的值
    affineTrans.put(0, 2, affineTrans.get(0, 2)[0] + (wdst - wsrc) / 2);
    affineTrans.put(1, 2, affineTrans.get(1, 2)[0] + (hdst - hsrc) / 2);
 
    Imgproc.warpAffine(splitImage, imgDst, affineTrans, imgDst.size(),
        Imgproc.INTER_CUBIC | Imgproc.WARP_FILL_OUTLIERS);
    return imgDst;
}

關(guān)于使用java怎么對圖片的角度進(jìn)行旋轉(zhuǎn)就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

網(wǎng)頁標(biāo)題:使用java怎么對圖片的角度進(jìn)行旋轉(zhuǎn)
網(wǎng)站URL:http://aaarwkj.com/article46/pdideg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、網(wǎng)站收錄、商城網(wǎng)站、Google靜態(tài)網(wǎng)站建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司
九九热在线免费观看精品视频| 日韩欧美国产成人在线观看| 国产亚洲欧美日韩看国产| 久久成人a毛片免费观看网站| 日韩午夜免费一区二区蜜桃| 丰满熟女人妻中文字幕免费| 亚洲精品国产精品成人 | 国产传媒在线播放一区| 久久日韩一区二区三区| 日韩一区二区三区不卡| 日韩av高清免费播放| 人人妻人人澡人人妻| 欧美 日韩亚洲一区| 欧美日韩中文国产天堂| 日韩综合欧美激情另类| 91亚洲蜜桃内射后入在线观看| 国产一区国产二区中文字幕| 国产精品成久久久久三级| 久久国产精品一区二区三区| 蜜桃臀内射一区二区三区| 少妇午夜福利一区二区| 欧美大片在线观看高清| 亚洲黄色av乱码在线观看| 国产亚洲精品热视频在线观看| 天天操夜夜夜夜夜操| 午夜福利视频在线观看| 欧美伊香蕉久久综合网99| 亚洲成人免费在线播放| 夫妻在线观看高清视频| 欧洲一区二区三区黄色| 四虎免费在线高清观看| 亚洲熟妇av乱码在线| 国产精品久久久久久爽| 欧美成人一区二区三区八| 亚洲av十八禁在线播放| 国产熟女一区二区精品视频| 久久亚洲中文字幕精品熟女一区| 97免费人妻在线视频| 亚洲精品一区国产精品av| 99人妻精品一区二区| 免费在线观看污污污网站|