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

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

java+opencv實現人臉識別功能

瀏覽:153日期: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久久,三上悠亚国产精品一区二区三区
国产美女久久| 国产日韩欧美三区| 精品视频在线观看网站| 高清精品久久| 精品国产亚洲一区二区三区| 国产suv精品一区二区四区视频| 红杏一区二区三区| 日韩影院二区| 午夜欧美精品久久久久久久| 丝袜美腿亚洲色图| 欧美天堂在线| 成人福利av| 亚洲精品国产偷自在线观看| 日韩精品一二三四| 久久激情五月激情| 国产伦理一区| 丝袜亚洲另类欧美| 国产精品一区二区av日韩在线| 精品亚洲成人| 日韩欧美一区二区三区免费观看| 久久久夜精品| 亚洲色图网站| 日韩88av| 午夜亚洲福利在线老司机| 国产欧美日韩精品一区二区免费 | 日韩精品免费视频人成| 国产精品成人3p一区二区三区| 国产在线观看www| 久久午夜影视| 福利一区和二区| 午夜亚洲福利在线老司机| 欧美激情三区| 亚洲福利国产| 日韩1区2区日韩1区2区| 国产精品麻豆久久| 日韩在线一区二区| 欧美国产偷国产精品三区| 爽好多水快深点欧美视频| 欧美精品不卡| 亚洲一级淫片| 久久高清免费| 久久久久97| 噜噜噜久久亚洲精品国产品小说| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 久久精品亚洲| 亚洲大全视频| 免费精品一区| 亚洲精品福利| 99久久激情| 麻豆一区二区三区| 伊人久久大香伊蕉在人线观看热v| 热三久草你在线| 国产精品蜜月aⅴ在线| av成人国产| 大香伊人久久精品一区二区| 在线观看一区| 亚洲国产福利| 国产亚洲第一伦理第一区| 亚洲欧洲日本mm| 色偷偷偷在线视频播放| 国产精品中文字幕亚洲欧美| 噜噜噜躁狠狠躁狠狠精品视频| 日韩av自拍| 国产欧美日韩影院| 亚洲婷婷丁香| 亚洲一区日本| 亚洲香蕉网站| 亚洲性色av| 精品久久网站| 国产精品黄色片| 亚洲精品成人一区| 美女精品一区| 亚洲一区网站| 亚洲精品小说| 欧美日韩中文字幕一区二区三区| 成人精品国产亚洲| 九九久久国产| 久久精品理论片| 国产精成人品2018| 久久成人福利| 国产精品大片免费观看| 欧美视频精品全部免费观看| 亚洲九九精品| 色婷婷成人网| 亚洲精品系列| 免费在线看一区| 石原莉奈一区二区三区在线观看| 亚洲福利一区| 亚洲少妇一区| 免费在线观看日韩欧美| 亚洲在线免费| 丝袜美腿亚洲色图| 亚洲精品婷婷| 日韩和欧美一区二区| 日韩av网站在线观看| 欧美日一区二区三区在线观看国产免| 亚洲一区二区三区中文字幕在线观看| 视频一区免费在线观看| 少妇精品久久久一区二区| 亚洲毛片视频| 奇米亚洲欧美| 精品视频免费| 久久在线视频免费观看| 久久午夜精品| 日本久久一区| 美女久久久精品| 国产中文欧美日韩在线| 精品三级久久| 国产精品7m凸凹视频分类| 亚洲深夜影院| 色8久久久久| 久久精品一区二区国产| 日韩欧美在线中字| 亚洲高清影视| 日韩精品一二区| 日韩不卡在线观看日韩不卡视频 | 日本va欧美va瓶| 欧美91在线| 成人日韩精品| 日av在线不卡| 麻豆一区二区在线| 欧美日韩在线观看视频小说| 水蜜桃久久夜色精品一区的特点| 日韩精品社区| 97人人精品| 久久99伊人| 国产伦精品一区二区三区千人斩| 国产精品麻豆久久| 亚洲性色视频| 婷婷精品在线| 日韩av有码| 欧美专区18| 麻豆国产一区| 1024精品久久久久久久久| 日韩av网站在线免费观看| yellow在线观看网址| 日韩影院在线观看| 精品日韩一区| 免费看欧美美女黄的网站| 精品欧美日韩精品| 麻豆精品91| 福利片在线一区二区| 蜜桃91丨九色丨蝌蚪91桃色| 欧美激情福利| 夜夜精品视频| 国内精品亚洲| 中文字幕一区二区三区日韩精品 | 蜜桃视频第一区免费观看| 麻豆成人av在线| 伊人久久亚洲影院| 精品国产中文字幕第一页| 蜜桃视频免费观看一区| 国语精品一区| 深夜日韩欧美| 在线观看精品| 国产欧美日韩一区二区三区四区 | 久久亚洲色图| 精品国产第一福利网站| 日韩精品中文字幕一区二区| 蜜桃精品在线| 久久不卡国产精品一区二区| 老鸭窝毛片一区二区三区| 成人精品高清在线视频| 中文字幕一区二区av| 久久久亚洲一区| 久久不卡国产精品一区二区| 伊人久久大香伊蕉在人线观看热v| www.com.cn成人| 久久不见久久见免费视频7| 中文精品电影| 免费欧美一区| 久久电影tv| 嫩呦国产一区二区三区av| 亚洲精品美女91| 婷婷丁香综合| 久久久久国产| 丰满少妇一区| 日韩国产欧美在线播放| 最新日韩欧美| 91精品国产乱码久久久久久久 | 久久精品国产亚洲aⅴ| 日韩精品国产欧美| 欧美日韩一区二区三区不卡视频 | 亚洲一区二区免费看| 欧产日产国产精品视频| 久久91视频| 欧美91在线| 国产精品九九| 亚洲一区二区日韩| 国产视频欧美| 999在线观看精品免费不卡网站| 日韩在线看片| 美女福利一区二区三区| 日韩av自拍| 色欧美自拍视频| 国产不卡一区| 国产欧美一区二区三区精品酒店| 日韩午夜在线| 日韩精品视频中文字幕| 国模精品一区|