import numpy as np
import cv2
import time
# cv2.VideoCapture.set(cv2.CAP_PROP_FPS,30)
# cap = cv2.VideoCapture(0)
cap = cv2.VideoCapture(r'D:\work\QT\yumiQt/output00.avi')
# cap = cv2.VideoCapture('../yumi.MP4')
# cap.set(cv2.CAP_PROP_FRAME_WIDTH, 640)
# cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)
#上面更改了宽高,是永久性的,更改后不用在加他了吧,必须和相机支持参数相同,否则也是更改不成功
print(cv2.VideoWriter_fourcc('M', 'J', 'P', 'G'))#编码1196444237
print(cv2.VideoWriter_fourcc('Y','U','Y','V'))#编码1448695129
print('-------')
'''更改参数'''
cap.set(cv2.CAP_PROP_FOURCC, cv2.VideoWriter_fourcc('M', 'J', 'P', 'G'))
w=cap.get(cv2.CAP_PROP_FRAME_WIDTH)
h=cap.get(cv2.CAP_PROP_FRAME_HEIGHT)
g = cap.get(cv2.CAP_PROP_FOURCC)
print(g)
print(w)
print(h)
# 结构元素提取
kernel = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (3, 3))
# 创建混合高斯模型用于背景建模
fgbg = cv2.createBackgroundSubtractorMOG2()
start_time = time.time()
fps = cap.get(cv2.CAP_PROP_FPS)
yumi = []
zhen = 0
i = 0
yumi_num = 0
while (True):
# zhen += 1
ret, frame = cap.read()
if not ret:
print("Can't receive frame (stream end?). Exiting ...")
break
fgmask = fgbg.apply(frame)
# 形态学开运算去噪点
fgmask = cv2.morphologyEx(fgmask, cv2.MORPH_OPEN, kernel)
ret, fgmask = cv2.threshold(fgmask, 137, 255, cv2.THRESH_BINARY)
# 寻找视频中的轮廓
'''实时帧率'''
if (time.time() - start_time) != 0: # 实时显示帧数
cv2.putText(frame, "FPS {0}".format(float('%.1f' % (1 / (time.time() - start_time)))), (50, 50),
cv2.FONT_HERSHEY_SIMPLEX, 2, (0, 0, 255),
3)
cv2.imshow('frame', frame)
print("FPS: ", 1 / (time.time() - start_time))
# zhen = 0
start_time = time.time()
print(fps)#get到的参数帧率
key = cv2.waitKey(1) & 0xff
if key == ord(" "):
cv2.waitKey(0)
if key == ord("q"):
break
cap.release()
cv2.destroyAllWindows()
opencv中更改摄像头参数,更改mpjg和帧率遇到的问题
最新推荐文章于 2024-08-20 15:00:00 发布