一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - Java教程 - java實現圖片角度旋轉并獲得圖片信息

java實現圖片角度旋轉并獲得圖片信息

2021-07-14 16:13fackyou200 Java教程

這篇文章主要為大家詳細介紹了java實現圖片角度旋轉并獲得圖片信息,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java實現圖片角度旋轉并獲得圖片信息的具體代碼,供大家參考,具體內容如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
public class demo {
 
 /**
 * 調整圖片角度
 * make by dongxh 2017年11月1日下午3:51:08
 * @param src
 * @param angel
 * @return
 */
 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;
 }
 
 /**
 * 計算旋轉參數
 * make by dongxh 2017年11月1日下午3:51:29
 * @param src
 * @param angel
 * @return
 */
 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 rectangle(new dimension(des_width, des_height));
 }
 
 /**
 * 獲得圖片調整角度
 * make by dongxh 2017年11月1日下午3:40:20
 * @param imgfile
 * @return
 */
 public static integer getimgrotateangle(string imgfile){
 integer angel = 0;
 metadata metadata = null;
 try{
 if(stringutils.isblank(imgfile))return angel;
 file _img_file_ = new file(imgfile);
 if(!_img_file_.exists())return angel;
 metadata = jpegmetadatareader.readmetadata(_img_file_);
 directory directory = metadata.getdirectory(exifdirectory.class);
 if(directory != null && directory.containstag(exifdirectory.tag_orientation)){
 int orientation = directory.getint(exifdirectory.tag_orientation);
 // 原圖片的方向信息
    if(6 == orientation ){
     //6旋轉90
     angel = 90;
    }else if( 3 == orientation){
    //3旋轉180
     angel = 180;
    }else if( 8 == orientation){
    //8旋轉90
     angel = 270;
    }
 }
 }catch(exception e){
 e.printstacktrace();
 }
 return angel;
 }
 
 /**
 * 調整圖片角度
 * make by dongxh 2017年11月1日下午4:31:20
 * @param imgfile
 */
 public static void rotateimage(string imgfile){
 try {
 if(stringutils.isblank(imgfile)){
 file _img_file_ = new file(imgfile);
 if(_img_file_.exists()){
  integer angel = getimgrotateangle(imgfile);
  if(angel==0)return;
  bufferedimage src = imageio.read(_img_file_);
  bufferedimage des = rotate(src, angel);
  imageio.write(des,"jpg", _img_file_);
 }
 }
 } catch (ioexception e) {
 e.printstacktrace();
 }
 }
 
 public static void main(string[] args)throws exception{
 string frompic = "d://88888//img_20171004_122718.jpg";
 //rotateimage(file);
 
 integer angel = getimgrotateangle(frompic);
 system.out.println(angel);
 thumbnails.of(frompic)
  .rotate(angel)
  .scale(0.2f)
  .outputformat("jpg")
  .outputquality(0.2f)
  .tofile(frompic);
 
 system.out.println("==end==");
 }
 
}

獲得圖片使用metadata-extractor

?
1
2
3
4
5
<dependency>
 <groupid>com.drewnoakes</groupid>
 <artifactid>metadata-extractor</artifactid>
 <version>2.4.0-beta-1</version>
</dependency>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/fackyou200/article/details/78435709

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日产中文乱码卡一卡二 | www.精品视频 | bdsm中国精品调教 | 色婷婷在线视频 | 亚洲国产无线码在线观看 | 白丝尤物的下面被疯狂蹂躏 | 青草影院在线观看 | 奇米成人 | 国产精品资源在线观看 | 无码天堂亚洲国产AV久久 | 韩国免费特一级毛片 | 无限资源在线观看完整版免费下载 | 国产亚洲精品第一综合linode | 韩国三级日本三级香港三级黄 | juliaann大战两个黑人 | 色悠久久久久综合欧美99 | vod国产成人精品视频 | 国产精品久久久久久久免费大片 | 波多野结衣女教师在线观看 | 成人免费观看一区二区 | 草久久网 | 99午夜| 亚洲日韩中文字幕一区 | ass韩国美女人体pics | 亚洲精品中文字幕第一区 | 99热99re | 欧洲老妇人70 | 精品福利一区二区免费视频 | 羞羞漫画免费漫画页面在线看漫画秋蝉 | 99久久综合给久久精品 | 国产高清露脸学生在线观看 | 久久精品黄AA片一区二区三区 | 欧美色图日韩 | 男男gaygays黑人| 国产精品久久久久影院色老大 | 青青草国产一区二区三区 | 武侠艳妇屈辱的张开双腿 | 天天色天天综合网 | 丁香成人社 | 扒开双腿羞辱调教play视频 | 欧美视频黑鬼大战白妞 |