我正在尝试创建一个网络应用程序来检测实时视频源中的面孔。我已经用 Javascript 编写了网络摄像头源代码,因为我想稍后托管该应用程序。
使用 Javascript 获取 feed 的代码
var video = document.querySelector("#videoElement");
if (navigator.mediaDevices.getUserMedia) {
navigator.mediaDevices.getUserMedia({video: true}).then(function(stream) {
video.srcObject = stream;
}).catch(function(err0r) {
console.log("Something went wrong!");
});
}
我的打开相机并检测人脸的Python代码如下
import cv2
cascade = cv2.CascadeClassifier('./haarcascade_frontalface_default.xml')
cam = cv2.VideoCapture(0)
while True:
ret, frame = cam.read()
frame = cv2.flip(frame, 1)
if ret:
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
faces = cascade.detectMultiScale(gray, scaleFactor=1.3, minNeighbors=3)
for (x, y, w, h) in faces:
cropped = cv2.resize(frame[y:y+h, x:x+w], (198,198))
cv2.rectangle(frame, (x, y), (x+w, y+h), (255, 0, 0), 2)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
cv2.destroyAllWindows()
cv2.imshow('Stream', frame)
我的问题是,除了用 Python 打开网络摄像头之外,我还能以某种方式将 Javascript 的 feed 传递到 Python 吗?我想我必须更改这一行以包含来自 Javascript 的代码
cam = cv2.VideoCapture(0)
任何帮助表示赞赏。先感谢您