package com.function; import java.awt.image.BufferedImage; import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.*; import javax.imageio.ImageIO; /* * 这个是一个照片比对功能实现类 */ public class Tools_PhotoMatching { public int mactching(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(); } return k; } }
本文来自博客园,作者:观心静 ,转载请注明原文链接:https://www.cnblogs.com/guanxinjing/p/9708645.html
本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具