자바 는 어떻게 그림 의 중첩 과 조합 작업 을 실현 합 니까?

자바 가 이미지 의 중첩 과 연결 을 실현 하 는 글 은 인터넷 에 확실히 많다.공교롭게도 소 편 개발 작업 에서 도 이런 문제 에 부 딪 혀 간략하게 정리 하여 불시에 필요 할 때 에 대비 했다.
자바 의 그림 처 리 는 주로 BufferedImage 류 를 사용 합 니 다.

BufferedImage 하위 클래스 는 이미지 데이터 버퍼 에 접근 할 수 있 는 Image 를 설명 합 니 다.BufferedImage 는 이미지 데이터 의 ColorModel 과 Raster 로 구성 되 어 있 습 니 다.Raster 의 SampleModel 에서 band 의 수량 과 유형 은 ColorModel 이 요구 하 는 수량 과 유형 과 일치 하여 색상 과 알파 의 분량 을 표시 해 야 합 니 다.모든 버 프 레 드 이미지 대상 의 왼쪽 상단 좌 표 는(0,0)입 니 다.따라서 BufferedImage 를 구성 하 는 모든 Raster 는 minX=0 과 minY=0 을 만족 시 켜 야 합 니 다.Raster 의 데이터 획득 방법,데이터 설정 방법,ColorModel 의 색상 특징 화 방법 에 의존 합 니 다.
이상 은 주로 공식 문서 에서 기원 되 었 으 니 우리 가 올 때 실천 코드 를 직접 쓰 자.
먼저 파일 을 BufferedImage 대상 으로 바 꾸 고,파일 을 읽 고 BufferedImage 대상 으로 바 꾸 는 두 가지 방법 을 알려 줍 니 다.

/**
   * @param fileUrl            
   * @return         
   * @throws IOException                IO  
   */
  public static BufferedImage getBufferedImage(String fileUrl)
      throws IOException {
    File f = new File(fileUrl);
    return ImageIO.read(f);
  }  
  
  /**
   *      BufferedImage
   * @param destUrl        
   * @return
   */
  public static BufferedImage getBufferedImageDestUrl(String destUrl) {
    HttpURLConnection conn = null;
    BufferedImage image = null;
    try {
      URL url = new URL(destUrl);
      conn = (HttpURLConnection) url.openConnection();
      if (conn.getResponseCode() == 200) {
        image = ImageIO.read(conn.getInputStream());
        return image;
      }
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      conn.disconnect();
    }
    return image;
  }
다음은 BufferedImage 대상 을 로 컬 에 저장 합 니 다.구체 적 인 방법 은 다음 과 같 습 니 다.

/**
   *     
   * @param buffImg          BufferedImage  
   * @param savePath              
   */
  public static void generateSaveFile(BufferedImage buffImg, String savePath) {
    int temp = savePath.lastIndexOf(".") + 1;
    try {
      File outFile = new File(savePath);
      if(!outFile.exists()){
        outFile.createNewFile();
      }
      ImageIO.write(buffImg, savePath.substring(temp), outFile);
      System.out.println("ImageIO write...");
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
이상 은 준비 부분 으로 지금부터 그림 중첩 의 실현 방법:

/**
   * 
   * @Title:     
   * @Description:        java.awt.image.BufferedImage
   * @param buffImg    (BufferedImage)
   * @param waterFile     (BufferedImage)
   * @param x       X   
   * @param y       Y   
   * @param alpha    ,     0.0~1.0:     ~     
   * @return BufferedImage
   * @throws IOException
   */
  public static BufferedImage overlyingImage(BufferedImage buffImg, BufferedImage waterImg, int x, int y, float alpha) throws IOException {

    //   Graphics2D  ,         
    Graphics2D g2d = buffImg.createGraphics();
    int waterImgWidth = waterImg.getWidth();//        
    int waterImgHeight = waterImg.getHeight();//        
    //                 
    g2d.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP, alpha));
    //   
    g2d.drawImage(waterImg, x, y, waterImgWidth, waterImgHeight, null);
    g2d.dispose();//               
    return buffImg;
  }
그림 맞 춤 법:

/**
   *                 ,        ,       ;         ,      。
   * mergeImage      ,    。 
   * @param img1         
   * @param img2         
   * @param isHorizontal  true         , false         
   * @return       BufferedImage  
   * @throws IOException
   */
  public static BufferedImage mergeImage(BufferedImage img1,
      BufferedImage img2, boolean isHorizontal) throws IOException {
    int w1 = img1.getWidth();
    int h1 = img1.getHeight();
    int w2 = img2.getWidth();
    int h2 = img2.getHeight();

    //       RGB
    int[] ImageArrayOne = new int[w1 * h1];
    ImageArrayOne = img1.getRGB(0, 0, w1, h1, ImageArrayOne, 0, w1); //             RGB    
    int[] ImageArrayTwo = new int[w2 * h2];
    ImageArrayTwo = img2.getRGB(0, 0, w2, h2, ImageArrayTwo, 0, w2);

    //      
    BufferedImage DestImage = null;
    if (isHorizontal) { //       
      DestImage = new BufferedImage(w1+w2, h1, BufferedImage.TYPE_INT_RGB);
      DestImage.setRGB(0, 0, w1, h1, ImageArrayOne, 0, w1); //             RGB
      DestImage.setRGB(w1, 0, w2, h2, ImageArrayTwo, 0, w2);
    } else { //       
      DestImage = new BufferedImage(w1, h1 + h2, BufferedImage.TYPE_INT_RGB);
      DestImage.setRGB(0, 0, w1, h1, ImageArrayOne, 0, w1); //             RGB
      DestImage.setRGB(0, h1, w2, h2, ImageArrayTwo, 0, w2); //        RGB
    }

    return DestImage;
  }
테스트 방법 은 다음 과 같다.

/**
   * Java         
   */
  public static void overlyingImageTest() {

    String sourceFilePath = "D://test//test1.jpg";
    String waterFilePath = "D://test//test2.jpg";
    String saveFilePath = "D://test//overlyingImageNew.jpg";
    try {
      BufferedImage bufferImage1 = getBufferedImage(sourceFilePath);
      BufferedImage bufferImage2 = getBufferedImage(waterFilePath);

      //      
      BufferedImage buffImg = overlyingImage(bufferImage1, bufferImage2, 0, 0, 1.0f);
      //       
      generateSaveFile(buffImg, saveFilePath);
    } catch (IOException e) {
      e.printStackTrace();
    }

  }
  
  
  /**
   * Java         
   */
  public static void imageMargeTest() {
    //         
    BufferedImage bi1 = null;
    BufferedImage bi2 = null;
    //   mergeImage          
    BufferedImage destImg = null;
    System.out.println("          :");
    String saveFilePath = "D://test//new1.jpg";
    String divingPath = "D://test//new2.jpg";
    String margeImagePath = "D://test//margeNew.jpg";
    try {
      bi1 = getBufferedImage(saveFilePath);
      bi2 = getBufferedImage(divingPath);
      //   mergeImage          
      destImg = mergeImage(bi1, bi2, false);
    } catch (IOException e) {
      e.printStackTrace();
    }
    //     
    generateSaveFile(destImg, margeImagePath);
    System.out.println("      !");
  }

  public static void main(String[] args) {
    //        
    overlyingImageTest();
    //          
    imageMargeTest();
  }
전체 코드 는 다음 과 같 습 니 다.

package ImagePackage;

import java.awt.AlphaComposite;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URL;

import javax.imageio.ImageIO;

/**

 *             ,              。
 *                ,             ,          BufferedImage
 * mergeImage(BufferedImage[] imgs, boolean isHorizontal)  ;
 *              ,          ,             
 */

public class ImageMerge {

  /**
   * @param fileUrl
   *                 
   * @return         
   * @throws IOException
   *                      IO  
   */
  public static BufferedImage getBufferedImage(String fileUrl)
      throws IOException {
    File f = new File(fileUrl);
    return ImageIO.read(f);
  }
  
  
  /**
   *      BufferedImage
   * @param destUrl        
   * @return
   */
  public static BufferedImage getBufferedImageDestUrl(String destUrl) {
    HttpURLConnection conn = null;
    BufferedImage image = null;
    try {
      URL url = new URL(destUrl);
      conn = (HttpURLConnection) url.openConnection();
      if (conn.getResponseCode() == 200) {
        image = ImageIO.read(conn.getInputStream());
        return image;
      }
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      conn.disconnect();
    }
    return image;
  }
  
  /**
   *     
   * 
   * @param buffImg
   *               BufferedImage  
   * @param savePath
   *                   
   */
  public static void generateSaveFile(BufferedImage buffImg, String savePath) {
    int temp = savePath.lastIndexOf(".") + 1;
    try {
      File outFile = new File(savePath);
      if(!outFile.exists()){
        outFile.createNewFile();
      }
      ImageIO.write(buffImg, savePath.substring(temp), outFile);
      System.out.println("ImageIO write...");
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
  
  /**
   * 
   * @Title:     
   * @Description:        java.awt.image.BufferedImage
   * @param buffImg
   *         (BufferedImage)
   * @param waterFile
   *          (BufferedImage)
   * @param x
   *            X   
   * @param y
   *            Y   
   * @param alpha
   *         ,     0.0~1.0:     ~     
   * @return BufferedImage
   * @throws IOException
   */
  public static BufferedImage overlyingImage(BufferedImage buffImg, BufferedImage waterImg, int x, int y, float alpha) throws IOException {

    //   Graphics2D  ,         
    Graphics2D g2d = buffImg.createGraphics();
    int waterImgWidth = waterImg.getWidth();//        
    int waterImgHeight = waterImg.getHeight();//        
    //                 
    g2d.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP, alpha));
    //   
    g2d.drawImage(waterImg, x, y, waterImgWidth, waterImgHeight, null);
    g2d.dispose();//               
    return buffImg;
  }
  
  
  /**
   *                 ,        ,       ;         ,      。
   * mergeImage      ,    。
   *
   * @param img1
   *              
   * @param img2
   *              
   * @param isHorizontal
   *       true         , false         
   * @return       BufferedImage  
   * @throws IOException
   */
  public static BufferedImage mergeImage(BufferedImage img1,
      BufferedImage img2, boolean isHorizontal) throws IOException {
    int w1 = img1.getWidth();
    int h1 = img1.getHeight();
    int w2 = img2.getWidth();
    int h2 = img2.getHeight();

    //       RGB
    int[] ImageArrayOne = new int[w1 * h1];
    ImageArrayOne = img1.getRGB(0, 0, w1, h1, ImageArrayOne, 0, w1); //             RGB    
    int[] ImageArrayTwo = new int[w2 * h2];
    ImageArrayTwo = img2.getRGB(0, 0, w2, h2, ImageArrayTwo, 0, w2);

    //      
    BufferedImage DestImage = null;
    if (isHorizontal) { //       
      DestImage = new BufferedImage(w1+w2, h1, BufferedImage.TYPE_INT_RGB);
      DestImage.setRGB(0, 0, w1, h1, ImageArrayOne, 0, w1); //             RGB
      DestImage.setRGB(w1, 0, w2, h2, ImageArrayTwo, 0, w2);
    } else { //       
      DestImage = new BufferedImage(w1, h1 + h2, BufferedImage.TYPE_INT_RGB);
      DestImage.setRGB(0, 0, w1, h1, ImageArrayOne, 0, w1); //             RGB
      DestImage.setRGB(0, h1, w2, h2, ImageArrayTwo, 0, w2); //        RGB
    }

    return DestImage;
  }

  /**
   * Java         
   */
  public static void overlyingImageTest() {

    String sourceFilePath = "D://test//test1.jpg";
    String waterFilePath = "D://test//test2.jpg";
    String saveFilePath = "D://test//overlyingImageNew.jpg";
    try {
      BufferedImage bufferImage1 = getBufferedImage(sourceFilePath);
      BufferedImage bufferImage2 = getBufferedImage(waterFilePath);

      //      
      BufferedImage buffImg = overlyingImage(bufferImage1, bufferImage2, 0, 0, 1.0f);
      //       
      generateSaveFile(buffImg, saveFilePath);
    } catch (IOException e) {
      e.printStackTrace();
    }

  }
  
  
  /**
   * Java         
   */
  public static void imageMargeTest() {
    //         
    BufferedImage bi1 = null;
    BufferedImage bi2 = null;
    //   mergeImage          
    BufferedImage destImg = null;
    System.out.println("          :");
    String saveFilePath = "D://test//new1.jpg";
    String divingPath = "D://test//new2.jpg";
    String margeImagePath = "D://test//margeNew.jpg";
    try {
      bi1 = getBufferedImage(saveFilePath);
      bi2 = getBufferedImage(divingPath);
      //   mergeImage          
      destImg = mergeImage(bi1, bi2, false);
    } catch (IOException e) {
      e.printStackTrace();
    }
    //     
    generateSaveFile(destImg, margeImagePath);
    System.out.println("      !");
  }

  public static void main(String[] args) {
    //        
    overlyingImageTest();
    //          
    imageMargeTest();
  }

}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기