日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

java+opencv實現人臉識別功能

瀏覽:155日期:2022-08-13 08:23:59

背景:最近需要用到人臉識別,但又不花錢使用現有的第三方人臉識別接口,為此使用opencv結合java進行人臉識別(ps:opencv是開源的,使用它來做人臉識別存在一定的誤差,效果一般)。

1.安裝opencv官網地址:https://opencv.org/ , 由于官網下載速度是真的慢

百度網盤:

鏈接: https://pan.baidu.com/s/1RpsP-I7v8pP2dkqALDw7FQ

提取碼: pq7v

如果是官網下載,就無腦安裝就行了,安裝完畢后。

將圖一的兩個文件復制到圖二中。

java+opencv實現人臉識別功能java+opencv實現人臉識別功能

從我網盤下載的,忽略這些。

2.在項目中引入pom依賴

<!-- opencv + javacv + ffmpeg--><dependency> <groupId>org.bytedeco.javacpp-presets</groupId> <artifactId>ffmpeg</artifactId> <version>4.1-1.4.4</version></dependency><dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv</artifactId> <version>1.4.4</version></dependency><!-- https://mvnrepository.com/artifact/org.bytedeco.javacpp-presets/ffmpeg-platform --><dependency> <groupId>org.bytedeco.javacpp-presets</groupId> <artifactId>ffmpeg-platform</artifactId> <version>4.1-1.4.4</version></dependency><!-- 視頻攝像頭 --><!-- https://mvnrepository.com/artifact/org.bytedeco/javacv-platform --><dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv-platform</artifactId> <version>1.4.4</version></dependency><!-- https://mvnrepository.com/artifact/org.bytedeco.javacpp-presets/opencv-platform --><dependency> <groupId>org.bytedeco.javacpp-presets</groupId> <artifactId>opencv-platform</artifactId> <version>4.0.1-1.4.4</version></dependency>

1.導入庫依賴File --> Project Structure,點擊Modules,選擇需要使用opencv.jar的項目。

java+opencv實現人臉識別功能java+opencv實現人臉識別功能

選擇直接opencv安裝路徑

java+opencv實現人臉識別功能java+opencv實現人臉識別功能

2.java代碼demo

package org.Litluecat.utils;import org.apache.commons.lang.StringUtils;import org.opencv.core.*;import org.opencv.highgui.HighGui;import org.opencv.highgui.ImageWindow;import org.opencv.imgcodecs.Imgcodecs;import org.opencv.imgproc.Imgproc;import org.opencv.objdetect.CascadeClassifier;import org.opencv.videoio.VideoCapture;import org.opencv.videoio.VideoWriter;import org.opencv.videoio.Videoio;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import java.util.Arrays;/** * 人臉比對工具類 * @author Litluecat * @Title: Opencv 圖片人臉識別、實時攝像頭人臉識別**/public class FaceVideo { private static final Logger log = LoggerFactory.getLogger(FaceVideo.class); private static final String endImgUrl = 'C:UserslenovoDesktop'; /** * opencv的人臉識別xml文件路徑 */ private static final String faceDetectorXML2URL = 'D:Sofewareopencvsourcesdatahaarcascadeshaarcascade_frontalface_alt.xml'; /** * opencv的人眼識別xml文件路徑 */ private static final String eyeDetectorXML2URL = 'D:Sofewareopencvsourcesdatahaarcascadeshaarcascade_eye.xml'; /** * 直方圖大小,越大精度越高,運行越慢 */ private static int Matching_Accuracy = 100000; /** * 初始化人臉探測器 */ private static CascadeClassifier faceDetector; /** * 初始化人眼探測器 */ private static CascadeClassifier eyeDetector; private static int i=0; static {System.loadLibrary(Core.NATIVE_LIBRARY_NAME);faceDetector = new CascadeClassifier(faceDetectorXML2URL);eyeDetector = new CascadeClassifier(eyeDetectorXML2URL); } public static void main(String[] args) {log.info('開始人臉匹配');long begin = System.currentTimeMillis();// 1- 從攝像頭實時人臉識別,識別成功保存圖片到本地try{ getVideoFromCamera(endImgUrl + '2.jpg'); //僅用于強制拋異常,從而關閉GUI界面 Thread.sleep(1000); int err = 1/0; // 2- 比對本地2張圖的人臉相似度 (越接近1越相似)// double compareHist = FaceVideo.compare_image(endImgUrl + 'test1.jpg' , endImgUrl + 'face.jpg');// log.info('匹配度:{}',compareHist);// if (compareHist > 0.72) {//log.info('人臉匹配');// } else {//log.info('人臉不匹配');// }}catch (Exception e){ log.info('開始強制關閉'); log.info('人臉匹配結束,總耗時:{}ms',(System.currentTimeMillis()-begin)); System.exit(0);} } /** * OpenCV-4.1.1 從攝像頭實時讀取 * @param targetImgUrl 比對身份證圖片 * @return: void * @date: 2019年8月19日 17:20:13 */ public static void getVideoFromCamera(String targetImgUrl) {//1 如果要從攝像頭獲取視頻 則要在 VideoCapture 的構造方法寫 0VideoCapture capture = new VideoCapture(0);Mat video = new Mat();int index = 0;if (capture.isOpened()) { while(i<3) {// 匹配成功3次退出capture.read(video);HighGui.imshow('實時人臉識別', getFace(video, targetImgUrl));//窗口延遲等待100ms,返回退出按鍵index = HighGui.waitKey(100);//當退出按鍵為Esc時,退出窗口if (index == 27) { break;} }}else{ log.info('攝像頭未開啟');}//該窗口銷毀不生效,該方法存在問題HighGui.destroyAllWindows();capture.release();return; } /** * OpenCV-4.1.0 人臉識別 * @param image 待處理Mat圖片(視頻中的某一幀) * @param targetImgUrl 匹配身份證照片地址 * @return 處理后的圖片 */ public static Mat getFace(Mat image, String targetImgUrl) {MatOfRect face = new MatOfRect();faceDetector.detectMultiScale(image, face);Rect[] rects=face.toArray();log.info('匹配到 '+rects.length+' 個人臉');if(rects != null && rects.length >= 1) { i++; if(i==3) {// 獲取匹配成功第3次的照片Imgcodecs.imwrite(endImgUrl + 'face.jpg', image);FaceVideoThread faceVideoThread = new FaceVideoThread(targetImgUrl , endImgUrl + 'face.jpg');new Thread(faceVideoThread,'人臉比對線程').start(); }}return image; } /** * 人臉截圖 * @param img * @return */ public static String face2Img(String img) {String faceImg = null;Mat image0 = Imgcodecs.imread(img);Mat image1 = new Mat();// 灰度化Imgproc.cvtColor(image0, image1, Imgproc.COLOR_BGR2GRAY);// 探測人臉MatOfRect faceDetections = new MatOfRect();faceDetector.detectMultiScale(image1, faceDetections);// rect中人臉圖片的范圍for (Rect rect : faceDetections.toArray()) { faceImg = img+'_.jpg'; // 進行圖片裁剪 imageCut(img, faceImg, rect.x, rect.y, rect.width, rect.height);}if(null == faceImg){ log.info('face2Img未識別出該圖像中的人臉,img={}',img);}return faceImg; } /** * 人臉比對 * @param img_1 * @param img_2 * @return */ public static double compare_image(String img_1, String img_2) {Mat mat_1 = conv_Mat(img_1);Mat mat_2 = conv_Mat(img_2);Mat hist_1 = new Mat();Mat hist_2 = new Mat();//顏色范圍MatOfFloat ranges = new MatOfFloat(0f, 256f);//直方圖大小, 越大匹配越精確 (越慢)MatOfInt histSize = new MatOfInt(Matching_Accuracy);Imgproc.calcHist(Arrays.asList(mat_1), new MatOfInt(0), new Mat(), hist_1, histSize, ranges);Imgproc.calcHist(Arrays.asList(mat_2), new MatOfInt(0), new Mat(), hist_2, histSize, ranges);// CORREL 相關系數double res = Imgproc.compareHist(hist_1, hist_2, Imgproc.CV_COMP_CORREL);return res; } /** * 灰度化人臉 * @param img * @return */ public static Mat conv_Mat(String img) {if(StringUtils.isBlank(img)){ return null;}Mat image0 = Imgcodecs.imread(img);Mat image1 = new Mat();//Mat image2 = new Mat();// 灰度化Imgproc.cvtColor(image0, image1, Imgproc.COLOR_BGR2GRAY);//直方均勻//Imgproc.equalizeHist(image1, image2);// 探測人臉MatOfRect faceDetections = new MatOfRect();faceDetector.detectMultiScale(image1, faceDetections);//探測人眼//MatOfRect eyeDetections = new MatOfRect();//eyeDetector.detectMultiScale(image1, eyeDetections);// rect中人臉圖片的范圍Mat face = null;for (Rect rect : faceDetections.toArray()) { //給圖片上畫框框 參數1是圖片 參數2是矩形 參數3是顏色 參數四是畫出來的線條大小 //Imgproc.rectangle(image0,rect,new Scalar(0,0,255),2); //輸出圖片 //Imgcodecs.imwrite(img+'_.jpg',image0); face = new Mat(image1, rect);}if(null == face){ log.info('conv_Mat未識別出該圖像中的人臉,img={}',img);}return face; }}

這邊的人臉識別是另外其線程進行比對,代碼如下。

package org.Litluecat.utils;import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class FaceVideoThread implements Runnable{ private static final Logger log = LoggerFactory.getLogger(FaceVideoThread.class); private String oneImgUrl = null; private String otherImgUrl = null; public FaceVideoThread(String oneImgUrl, String otherImgUrl){this.oneImgUrl = oneImgUrl;this.otherImgUrl = otherImgUrl; } @Override public void run() {try { double compareHist = FaceVideo.compare_image(oneImgUrl , otherImgUrl); log.info('匹配度:{}',compareHist); if (compareHist > 0.72) {log.info('人臉匹配'); } else {log.info('人臉不匹配'); }} catch (Exception e) { e.printStackTrace();} }}

提醒:如果運行異常,請添加你opencv的安裝地址-Djava.library.path=D:Sofewareopencvbuildjavax64;

java+opencv實現人臉識別功能

總結:java+opencv做人臉識別的精度不夠,我也是有待學習,如果大家有更好的方式,能將opencv更好的展現出來,并達到更精準的人臉識別,請分享給我,謝謝。

到此這篇關于java+opencv實現人臉識別的文章就介紹到這了,更多相關java opencv人臉識別內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频一区日韩精品| 婷婷久久免费视频| 老司机精品久久| 欧美不卡视频| 国产白浆在线免费观看| 麻豆国产精品一区二区三区| 日产精品一区二区| 亚洲一区亚洲| 婷婷综合社区| 欧产日产国产精品视频| 日韩av一区二区在线影视| 精品久久久网| 午夜精品免费| 中文字幕一区日韩精品| 国产综合婷婷| 丝袜亚洲精品中文字幕一区| 亚洲欧美日韩精品一区二区 | 国产99久久| 欧美精品中文字幕亚洲专区| 亚洲综合福利| 91欧美极品| 另类综合日韩欧美亚洲| 久久永久免费| 九九久久国产| 精品一区二区三区免费看| 日韩国产欧美一区二区| 黄色在线观看www| 日韩成人亚洲| 欧美13videosex性极品| 国产一区二区三区网| 日韩伦理在线一区| 久久亚洲成人| 亚洲精品乱码日韩| 久久99免费视频| 成人免费网站www网站高清| 久久精品国产www456c0m| 在线日韩电影| 日韩av中文在线观看| 国产精品xxx在线观看| 久久亚洲国产精品尤物| 三级小说欧洲区亚洲区| 99视频+国产日韩欧美| 久久久久久久欧美精品| 青青草国产精品亚洲专区无| 美女尤物国产一区| www.51av欧美视频| 亚洲成人一区| 国产毛片精品| 香蕉人人精品| 国产欧美一区二区精品久久久| 国内精品伊人| 日韩欧美中文字幕电影 | 91久久中文| 久草精品视频| 麻豆视频一区二区| 亚洲国内精品| 麻豆国产欧美日韩综合精品二区| 国产日产精品一区二区三区四区的观看方式| 国产成年精品| 亚洲毛片网站| 日韩在线看片| 国产精品一区二区美女视频免费看| 日韩专区精品| 国产欧美亚洲精品a| 99精品在线免费在线观看| 国产亚洲第一伦理第一区| 婷婷成人在线| 久久av超碰| 久久国产99| 一区二区自拍| 亚洲午夜一级| 国产在线|日韩| 亚洲国产日韩欧美在线| 久久国产直播| av高清一区| 国产精品免费看| 久久国内精品| 国产视频网站一区二区三区| 蜜桃一区二区三区在线观看| 免费黄色成人| 视频一区中文| 国产资源在线观看入口av| 免费一级欧美在线观看视频| 国产精品资源| 免费在线欧美黄色| 国产精品xxx| 国产精品99久久免费| 国产精品一国产精品k频道56| 日本欧美一区二区| 欧美一区激情| 久久免费视频66| 精品国产鲁一鲁****| 蜜臀久久精品| 九九精品调教| 亚洲高清激情| 国产一区二区精品| 亚洲欧洲午夜| 蜜桃视频在线观看一区二区| 国产精品美女| 日韩av在线播放中文字幕| 国产精品高潮呻吟久久久久| 国产亚洲欧美日韩精品一区二区三区 | 欧美特黄一级大片| 国产婷婷精品| 国产精品欧美三级在线观看 | 99成人在线视频| 国产亚洲毛片| 日本一区二区三区中文字幕| 亚洲欧洲日韩| 国产精品欧美大片| 国产在线成人| 国产精品久久777777毛茸茸| 日韩在线不卡| 日韩精品高清不卡| 免费看精品久久片| 亚洲欧洲午夜| 视频一区中文| 国产精品99一区二区| 日本不卡免费高清视频在线| 精品久久中文| 国产精品国产三级在线观看| 亚州欧美在线| 久久久久一区| 久久精品国内一区二区三区| 深夜福利一区| 亚洲www啪成人一区二区| 日本成人精品| 蜜桃久久av| 久久99蜜桃| 日本亚洲欧洲无免费码在线| 日韩久久电影| 国产精品综合色区在线观看| 午夜亚洲福利在线老司机| 国产欧美一区二区三区精品观看| 欧美午夜不卡| 欧美精品资源| 日韩国产一区二区| 欧美日本不卡| 日韩欧美久久| 欧美激情一区| 精品伊人久久久| 日韩欧美不卡| 久久男人av| 国产欧美综合一区二区三区| 亚洲色图综合| 老司机精品视频在线播放| aa国产精品| 日韩国产欧美三级| 成人午夜国产| 欧美91在线| 欧美精品中文字幕亚洲专区| 午夜国产一区二区| 亚洲精品极品| 精品中文字幕一区二区三区av| 亚洲精品在线a| 亚洲人亚洲人色久| 午夜影院欧美| 免费一二一二在线视频| 国产精品一区2区3区| 日韩激情一二三区| 日韩中文字幕一区二区三区| 中文在线免费视频| 国产精品香蕉| 午夜av一区| 一级成人国产| 国产精品夜夜夜| 国产日产一区| 色狠狠一区二区三区| 国产精品国码视频| 蜜臀av免费一区二区三区| 亚洲欧美日本日韩| 久久中文字幕一区二区| 美女福利一区二区三区| 麻豆精品少妇| 久久夜色精品| 日韩精品专区| 日本在线不卡视频| 日韩精品一区二区三区中文在线 | 韩国一区二区三区视频| 国产一区二区亚洲| 国产麻豆精品| 中文字幕日韩亚洲| 免费久久精品| 亚洲精品无吗| 免费看久久久| 精品资源在线| 日韩在线卡一卡二| 久久av免费| 91亚洲国产成人久久精品| 精品午夜av| 高清不卡亚洲| 久久狠狠亚洲综合| 狠狠久久伊人| 色婷婷久久久| 久久婷婷国产| 亚洲高清av| 一区二区视频欧美| 亚洲最新av| 日本一不卡视频| 国精品一区二区|