# -*-coding:utf-8 -*-
import cv2
import time
import datetime
import numpy as np
camera = cv2.VideoCapture(0)
if (camera.isOpened()):
print('Open')
else:
print('请打开摄像头')
#查看视频size
size = (int(camera.get(cv2.CAP_PROP_FRAME_WIDTH)),
int(camera.get(cv2.CAP_PROP_FRAME_HEIGHT)))
print('size:'+repr(size))
es = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (9, 4))
kernel = np.ones((5, 5), np.uint8)
pre_frame = None
while(1):
ret, frame = camera.read()
gray_lwpCV = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
#gray_lwpCV = cv2.resize(gray_lwpCV, (500, 500))
gray_lwpCV = cv2.GaussianBlur(gray_lwpCV, (21, 21), 0)
#将当前第一帧作为对比
if pre_frame is None:
pre_frame = gray_lwpCV
continue;
# absdiff把两幅图的差的绝对值输出到另一幅图上面来
img_delta = cv2.absdiff(pre_frame, gray_lwpCV)
thresh = cv2.threshold(img_delta, 10, 255, cv2.THRESH_BINARY)[1]
thresh = cv2.dilate(thresh, es, iterations=2)
# findContours检测物体轮廓(寻找轮廓的图像,轮廓的检索模式,轮廓的近似办法)
contours, hierarchy = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
for c in contours:
# 设置判断的范围
if cv2.contourArea(c) < 1500:
continue
else:
(x, y, w, h) = cv2.boundingRect(c)
cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
cv2.putText(frame, "当前时间: {}".format(str(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))) ), (10, 20),
cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 0, 255), 2)
break
pre_frame = gray_lwpCV
cv2.imshow("capture", frame)
cv2.imshow("Frame Delta", img_delta)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
camera.release()
cv2.destroyAllWindows()