java 对比类_Java实现图像对比类

packagecom.function;importjava.awt.image.BufferedImage;importjava.io.BufferedWriter;importjava.io.File;importjava.io.FileWriter;importjava.io.IOException;import java.util.*;importjavax.imageio.ImageIO;/** 这个是一个照片比对功能实现类*/

public classTools_PhotoMatching {public intmactching(String contrast_photo ,String test_photo) {int contras_rgb[] = new int[3];int test_rgb[] = new int[3];int k = 0;

File contrastfile= new File(contrast_photo); //对比照片路径

File testfile = new File(test_photo); //测试照片路径

BufferedImage contrasphoto = null;

BufferedImage testphoto= null;try{

contrasphoto=ImageIO.read(contrastfile);

testphoto=ImageIO.read(testfile);

}catch(IOException e) {//TODO Auto-generated catch block

e.printStackTrace();

}int contraswidth =contrasphoto.getWidth();int contrasheight =contrasphoto.getHeight();int testwidth =testphoto.getWidth();int testheight =testphoto.getHeight();//File file = new File("C:\\Users\\prize\\Desktop\\TOOLS\\DCIM\\Camera\\log.txt");//File file1 = new File("C:\\Users\\prize\\Desktop\\TOOLS\\DCIM\\Camera\\log1.txt");

try{//FileWriter fileWriter = new FileWriter(file);//FileWriter fileWriter1 = new FileWriter(file1);//BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);//BufferedWriter bufferedWriter2 = new BufferedWriter(fileWriter1);

for (int i = 0; i < testwidth; i++) {for (int j = 0; j < testheight; j++) {//StringBuffer astringBuffer1 = new StringBuffer();//StringBuffer bstringBuffer1 = new StringBuffer();

int pixel1 =contrasphoto.getRGB(i, j);int pixle2=testphoto.getRGB(i, j);

contras_rgb[0] = (pixel1 & 0xff0000) >> 16; //将值转化成16进制

contras_rgb[1] = (pixel1 & 0xff00) >> 8;

contras_rgb[2] = (pixel1 & 0xff);//astringBuffer1.append(i+"行"+j+"列 R="+contras_rgb[0]+"G="+contras_rgb[1]+"B="+contras_rgb[2] );//bufferedWriter.write(astringBuffer1.toString());//bufferedWriter.newLine();

test_rgb[0] = (pixle2 & 0xff0000) >> 16;

test_rgb[1] = (pixle2 & 0xff00) >> 8;

test_rgb[2] = (pixle2 & 0xff);//bstringBuffer1.append(i+"行"+j+"列 R="+test_rgb[0]+"G="+test_rgb[1]+"B="+test_rgb[2]);//bufferedWriter2.write(bstringBuffer1.toString());//bufferedWriter2.newLine();

int Difference_R = Math.abs(contras_rgb[0]-test_rgb[0]); //相减并且求绝对值

int Difference_G= Math.abs(contras_rgb[1]-test_rgb[1]);int Difference_B= Math.abs(contras_rgb[2]-test_rgb[2]);//System.out.println("第"+j+"次:"+Math.abs(Difference));

final int R = 35; //35

final int L = 130;int Q = Difference_R+Difference_G+Difference_B;if (Difference_R > R && Difference_G > R && Q>L) { //判断每个值的浮动不超过35

k++;

}else if (Difference_G >R && Difference_B>R && Q>L) {

k++;

}else if (Difference_R > R && Difference_B>R && Q>L) {

k++;

}

}

}//bufferedWriter.close();//bufferedWriter2.close();//fileWriter.close();//fileWriter1.close();

}catch(Exception e) {//TODO Auto-generated catch block

e.printStackTrace();

}returnk;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值