Java实现图像对比类
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; //
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;
} }
Java实现图像对比类的更多相关文章
- c#语法与c++ 及 java语法的对比分析
早期开发的时候一直用c/c++,后来主要用的是java.最近需要用下c#. 熟悉了下c#,发现c#语言在对c/c++基础上做了很多简化,同时参考了很多java的语法习惯,本来在语法上c/c++就有很多 ...
- Java文件类型工具类
package *; import java.util.HashMap; import java.util.Map; /** * <p> * <b>FileTypeEnum2& ...
- JAVA微信支付代码(WeChatPay.java 才是调用类)
微信官方文档:https://pay.weixin.qq.com/wiki/doc/api/index.html MD5Util.java package weixin; import java.se ...
- Java中的Graphics2D类基本使用教程
Java语言在Graphics类提供绘制各种基本的几何图形的基础上,扩展Graphics类提供一个Graphics2D类,它拥用更强大的二维图形处理能力,提供.坐标转换.颜色管理以及文字布局等更精确的 ...
- Java 2-Java 对象和类
Java 对象和类 Java作为一种面向对象语言.支持以下基本概念: 多态 继承 封装 抽象 类 对象 实例 方法 消息解析 本节我们重点研究对象和类的概念. 对象:对象是类的一个实例,有状态和行为. ...
- java 中常用的类
java 中常用的类 Math Math 类,包含用于执行基本数学运算的方法 常用API 取整 l static double abs(double a) 获取double 的绝对值 l sta ...
- Java数学函数Math类
Java数学函数Math类常用: Math.abs(12.3); //12.3 返回这个数的绝对值 Math.abs(-12.3); //12.3 Math.copySign(1.23, -12.3) ...
- Atitit。D&D drag&drop拖拽功能c#.net java swing的对比与实现总结
Atitit.D&D drag&drop拖拽功能c#.net java swing的对比与实现总结 1. 实现一个D&D操作一般包括三个步骤: 1 2. .net黑头的拖曳机制 ...
- Java学习笔记二十四:Java中的Object类
Java中的Object类 一:什么是Object类: Object类是所有类的父类,相当于所有类的老祖宗,如果一个类没有使用extends关键字明确标识继承另外一个类,那么这个类默认继承Object ...
随机推荐
- MapReduce案例:统计共同好友+订单表多表合并+求每个订单中最贵的商品
案例三: 统计共同好友 任务需求: 如下的文本, A:B,C,D,F,E,OB:A,C,E,KC:F,A,D,ID:A,E,F,LE:B,C,D,M,LF:A,B,C,D,E,O,MG:A,C,D,E ...
- CPS(Cyber-Physical Systems)白皮书-摘选
<中国制造2025>提出,“基于信息物理系统的智能装备.智能工厂等智能制造正在引领制造方式变革”,要围绕控制系统.工业软件.工业网络.工业云服务和工业大数据平台等,加强信息物理系统的研发与 ...
- 【java】类的初识
面向过程思想:强调的是功能行为 面向对象思想:不自己亲自做,将功能封装为对象,强调具备功能的对象,指挥对象实现各种功能.以后开发实际就是找对象使用对象,要是对象没有就创建对象并维护对象. 面向对象的三 ...
- windows环境下把Python代码打包成独立执行的exe
windows环境下把Python代码打包成独立执行的exe可执行文件 有时候因为出差,突然急需处理一批数据.虽然写好的脚本存储在云端随用随取,然而编译的环境还需要重新搭建,模块也需要重新装载,从 ...
- Java封装案例
---恢复内容开始--- 在类的getter/setter方法中在getter方法中要先实列话 在构造方法中无参构造(必须要构造)好处很多!!! 描述学生信息及相关联的专业信息 把Subject和St ...
- OpenTSDB(时序数据库官网)
官网地址:http://opentsdb.net/ 下载地址:https://github.com/OpenTSDB/opentsdb/releases ----------------------- ...
- django之中间件middleware
django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 在django项目的se ...
- 结构方程软件Lisrel 8.7 和HLM5.5
这是我亲自使用过的软件,其中lisrel是破解版的,HLM是学生版的 下载地址:http://pan.baidu.com/s/1bnfCOrH
- NIO框架之MINA源码解析(五):NIO超级陷阱和使用同步IO与MINA通信
1.NIO超级陷阱 之所以说NIO超级陷阱,就是因为我在本系列开头的那句话,因为使用缺陷导致客户业务系统瘫痪.当然,我对这个问题进行了很深的追踪,包括对MINA源码的深入了解,但其实之所以会出现这个问 ...
- jmap、jstack、jps无法连接jvm解决办法
转载 http://blog.51cto.com/zhangshaoxiong/1310166 一.背景 在对线上服务器的java应用dump操作时发现,以下报错,不能dump.jps也获取不到jav ...