import cv2
import numpy as np
cap = cv2.VideoCapture('video.mp4')
try:
import cv2
backSub = cv2.createBackgroundSubtractorMOG2()
except AttributeError:
backSub = cv2.bgsegm.createBackgroundSubtractorMOG()
#形态学kernel
kernel = cv2.getStructuringElement(cv2.MORPH_RECT,(5,5))
while True:
ret, frame = cap.read()
if ret:
#灰度
cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
#去噪
blur = cv2.GaussianBlur(frame, (3,3), 5)
#去背景
mask = backSub.apply(blur)
#腐蚀
erode = cv2.erode(mask,kernel)
#膨胀
dilate = cv2.dilate(erode,kernel,iterations = 3)
close = cv2.morphologyEx(dilate,cv2.MORPH_CLOSE,kernel)
close = cv2.morphologyEx(close, cv2.MORPH_CLOSE, kernel)
contours,h = cv2.findContours(close,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
for (i, c) in enumerate(contours):
(x,y,w,h) = cv2.boundingRect(c)
cv2.rectangle(frame, (x,y),(x+w,y+h),(0,0,255),2)
cv2.imshow('video',frame)
# cv2.imshow('erode',close)
key = cv2.waitKey(1)
if key == 27:
break
cap.release()
cv2.destroyAllWindows()
opencv 识别运动物体
peanut_wu2025-04-21 16:49
相关推荐
Ulana15 分钟前
计算机基础10大高频考题解析windfantasy199016 分钟前
NCT与GESP哪个更好?线上监考与线下考点的便利性对比执笔论英雄18 分钟前
【LORA】Jerryhut31 分钟前
Bev感知特征空间算法xian_wwq41 分钟前
【学习笔记】基于人工智能的火电机组全局性能一体化优化研究春风LiuK1 小时前
虚实无界:VRAR如何重塑课堂与突破研究边界歌_顿1 小时前
Embedding 模型word2vec/glove/fasttext/elmo/doc2vec/infersent学习总结胡萝卜3.01 小时前
深入C++可调用对象:从function包装到bind参数适配的技术实现Echo_NGC22371 小时前
【KL 散度】深入理解 Kullback-Leibler Divergence:AI 如何衡量“像不像”的问题愤怒的可乐1 小时前
从零构建大模型智能体:OpenAI Function Calling智能体实战