Để so sánh hai hình ảnh -
-
Đọc cả hai bằng cách sử dụng Image.IO.read () phương pháp.
-
Lấy chiều cao và chiều rộng của cả hai để đảm bảo chúng bằng nhau.
-
Nhận các giá trị pixel và nhận các giá trị RGB của cả hai hình ảnh.
-
Nhận tổng sự khác biệt giữa các giá trị RGB của hai hình ảnh này.
-
Tính phần trăm chênh lệch theo công thức sau -
Average = difference/weight*height*3; Percentage = (Average/255)*100;
Ví dụ
import java.awt.Color; import java.awt.image.BufferedImage; import javax.imageio.ImageIO; import java.io.File; public class ComparingImages { public static void main(String[] args) throws Exception { BufferedImage img1 = ImageIO.read(new File("D:\\Images\\test1.jpg")); BufferedImage img2 = ImageIO.read(new File("D:\\Images\\test2.jpg")); int w1 = img1.getWidth(); int w2 = img2.getWidth(); int h1 = img1.getHeight(); int h2 = img2.getHeight(); if ((w1!=w2)||(h1!=h2)) { System.out.println("Both images should have same dimwnsions"); } else { long diff = 0; for (int j = 0; j < h1; j++) { for (int i = 0; i < w1; i++) { //Getting the RGB values of a pixel int pixel1 = img1.getRGB(i, j); Color color1 = new Color(pixel1, true); int r1 = color1.getRed(); int g1 = color1.getGreen(); int b1 = color1.getBlue(); int pixel2 = img2.getRGB(i, j); Color color2 = new Color(pixel2, true); int r2 = color2.getRed(); int g2 = color2.getGreen(); int b2= color2.getBlue(); //sum of differences of RGB values of the two images long data = Math.abs(r1-r2)+Math.abs(g1-g2)+ Math.abs(b1-b2); diff = diff+data; } } double avg = diff/(w1*h1*3); double percentage = (avg/255)*100; System.out.println("Difference: "+percentage); } } }
Đầu vào1
Đầu vào2
Đầu ra
Difference: 92.54901960784314