溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-30 22:14:33 來源:腳本之家 閱讀:206 作者:fackyou200 欄目:編程語言

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

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

<dependency>
 <groupId>com.drewnoakes</groupId>
 <artifactId>metadata-extractor</artifactId>
 <version>2.4.0-beta-1</version>
</dependency>

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女