Python和OpenCV自制訪客識別程序
效果圖

這是我用Pyqt5,基于OpenCV做的一個Python訪客識別程序,它具體包括如下5個功能:
1、選擇媒體菜單,可以打開本地攝像頭;如果知道rtsp地址,則可以直接訪問局域網(wǎng)內(nèi)的網(wǎng)絡(luò)串流。
2、選擇播放菜單,可以播放/暫停當(dāng)前正在播放中的視頻信息。
3、視頻播放過程,應(yīng)用會每隔1秒掃描一次屏幕中出現(xiàn)的訪客并通過識別判斷是否是新訪客。
4、若是新訪客的,右邊今日訪客欄中就會將該訪客人臉圖像展示出來。
5、今日訪客數(shù)會根據(jù)新增訪客圖像的增加而同步更新。
由于直接用的是OpenCV自帶的模型,所以戴口罩的人臉是無法區(qū)分的。這個暫且不做拓展討論。
這個程序的功能其實說白了就是用OpenCV打開攝像頭,然后進(jìn)行人臉識別,識別的人臉數(shù)據(jù)會存儲在一個image_list的數(shù)組中,若在image_list中沒有發(fā)現(xiàn)相同圖像,就會在右側(cè)Qlabel添加一個新的label并把新增人臉貼上去。
現(xiàn)在來介紹下這個程序的核心代碼實現(xiàn),完整的代碼會在文章結(jié)尾處放置鏈接。
先說打開攝像頭播放或暫停的功能,這個功能我在以前的博文中已經(jīng)具體介紹過,參看Python學(xué)習(xí)之用QTimer計時器實現(xiàn)攝像頭視頻的播放和暫停_pyqt5攝像頭暫停。
然后是人臉識別功能,不多廢話,直接上代碼:
def TrackingFace(self, image):
try:
faces = face_recognition.face_locations(image)
encodings = face_recognition.face_encodings(image, faces)
if faces != ():
i = 0
for (y, w, h, x), f_code in zip(faces, encodings):
image = cv2.rectangle(image, (x, y), (w, h), (0, 0, 255), 2)
# 獲取識別的人臉
roiImg = image[y:h, x:w]
if len(self.image_list) > 0:
# 看看面部是否與已知人臉相匹配。
for j, v in enumerate(self.image_list):
# print(f'{j}: {v}')
match = face_recognition.compare_faces(
[v], f_code, tolerance=0.6)
if match[0]:
print("找到相同圖像")
self.flag = True
break
else:
print("未找到相同圖像")
self.RoiImg(roiImg)
else:
self.image_list.append(f_code)
self.RoiImg(roiImg)
i += 1
except Exception as e:
print(str(e))
return image接下來是將未找到的圖像貼到訪客墻上的功能:
def RoiImg(self, image):
# 將人臉圖像加載到右側(cè)QLabel
im1 = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
im1 = cv2.putText(im1, self.timestr, (10, image.shape[1] - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (255, 255, 255), 1)
im2 = QtGui.QImage(im1[:], im1.shape[1], im1.shape[0], im1.shape[1] * 3, QtGui.QImage.Format_RGB888)
im3 = QtGui.QPixmap(im2).scaled(150, 200)
# 添加新的Label
label = QLabel()
label.setFixedSize(60, 100)
label.setStyleSheet("border:1px solid gray")
label.setPixmap(im3)
label.setScaledContents(True)
count = int(self.scrollArea.width() / 80)
row = int(self.index / count)
colum = self.index % count
self.glay.addWidget(label, row, colum)
self.index += 1
self.label_3.setText(str(self.index))最后,還有個每隔1s掃描一次人臉,其實就是拿兩個時間戳進(jìn)行對比:
t1 = datetime.strptime(self.timestr, '%Y-%m-%d %H:%M:%S')
t2 = datetime.strptime(timestr0, '%Y-%m-%d %H:%M:%S')
seconds = (t2 - t1).seconds
# print('t1=' + str(t1), 't2=' +str(t2), 'seconds=' + str(seconds))
if seconds > 1: # 每隔1秒掃描一次人臉
self.timestr = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
self.TrackingFace(color_frame)到此這篇關(guān)于Python和OpenCV自制訪客識別程序的文章就介紹到這了,更多相關(guān)Python OpenCV訪客識別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python+requests接口自動化框架的實現(xiàn)
這篇文章主要介紹了python+requests接口自動化框架的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
詳解python實現(xiàn)多張多格式圖片轉(zhuǎn)PDF并打包成exe
這篇文章主要為大家介紹了python實現(xiàn)多張多格式圖片轉(zhuǎn)PDF并打包成exe方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
python解釋器pycharm安裝及環(huán)境變量配置教程圖文詳解
這篇文章主要介紹了python解釋器pycharm安裝及環(huán)境變量配置教程圖文詳解,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02
在Python中實現(xiàn)函數(shù)重載的示例代碼
這篇文章主要介紹了在Python中實現(xiàn)函數(shù)重載的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12

