자바 는 어떻게 그림 의 중첩 과 조합 작업 을 실현 합 니까?
자바 의 그림 처 리 는 주로 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();
}
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.