Java 照片對比功能的實現(xiàn)
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;/* * 這個是一個照片比對功能實現(xiàn)類 */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:UsersprizeDesktopTOOLSDCIMCameralog.txt'); //File file1 = new File('C:UsersprizeDesktopTOOLSDCIMCameralog1.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; //將值轉(zhuǎn)化成16進(jìn)制 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) { //判斷每個值的浮動不超過35k++; }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 照片對比功能實現(xiàn)類的詳細(xì)內(nèi)容,更多關(guān)于Java 照片對比的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Python2.6版本pip安裝步驟解析2. python公司內(nèi)項目對接釘釘審批流程的實現(xiàn)3. python中Ansible模塊的Playbook的具體使用4. Python自動化之定位方法大殺器xpath5. Python本地及虛擬解釋器配置過程解析6. Python 利用flask搭建一個共享服務(wù)器的步驟7. 基于python實現(xiàn)matlab filter函數(shù)過程詳解8. Python中Anaconda3 安裝gdal庫的方法9. python自動化測試三部曲之request+django實現(xiàn)接口測試10. Python importlib模塊重載使用方法詳解
