导入 OpenCV
import cv2
图像操作:读取、显示、保存
img = cv2.imread('pic.jpg')
cv2.imshow('window', img)
cv2.imwrite('picture', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
图像操作:缩放、翻转
img = cv2.resize(img, (1280, 720))
img = cv2.flip(img, 1)
图像操作:画框、写字
cv2.rectangle(img, (x1, y1), (x2, y2), (0, 0, 255))
cv2.putText(img, 'text', (x, y), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255))
调用 USB 摄像头
cap = cv2.VideoCapture(0)
while 1:
ret, img = cap.read()
if ret:
cv2.imshow('window', img)
if cv2.waitKey(1) == ord('q'):
break
cv2.destroyAllWindows()
cap.release()
计算时间
cap = cv2.VideoCapture(0)
q = cv2.getTickCount()
while 1:
ret, img = cap.read()
if ret:
cv2.imshow('window', img)
t = cv2.getTickCount()
print((t-q)/cv2.getTickFrequency())
q = t
if cv2.waitKey(1) == ord('q'):
break
cv2.destroyAllWindows()
cap.release()
调用模型
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
cap = cv2.VideoCapture(0)
while 1:
ret, frame = cap.read()
if ret:
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
faces = face_cascade.detectMultiScale(gray, 1.1, 5, minSize = (5,5))
for x, y, w, h in faces:
cv2.rectangle(frame, (x, y), (x+w-1, y+h-1), (0, 0, 255))
cv2.imshow('window', frame)
if cv2.waitKey(1) == ord('q'):
break
cv2.destroyAllWindows()
cap.release()