博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python opencv视频中对象跟踪
阅读量:3900 次
发布时间:2019-05-23

本文共 932 字,大约阅读时间需要 3 分钟。

使用meanShift、CamShift捕捉对象

import cv2import numpy as npcapture = cv2.VideoCapture('dance1.mp4')ret,frame = capture.read()x,y,w,h = 700,0,160,160track_window = (x,y,w,h )roi = frame[y:y+h, x:x+w]hsv_roi = cv2.cvtColor(roi, cv2.COLOR_BGR2HSV)mask = cv2.inRange(hsv_roi, np.array((0, 60,32)), np.array((180,255,255)))roi_hist = cv2.calcHist([hsv_roi],[0],mask,[180],[0,180])cv2.normalize(roi_hist,roi_hist,0,255,cv2.NORM_MINMAX)# 设置终止条件,term_crit = (cv2.TERM_CRITERIA_COUNT, 6, 1 )while(1): ret, frame = capture.read() if ret == True:     hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)     dst = cv2.calcBackProject([hsv],[0],roi_hist,[0,180],1)     # 应用meanshift或者来获取新位置     ret, track_window = cv2.CamShift(dst, track_window, term_crit)     # 在图像上绘制     x,y,w,h = track_window     img2 = cv2.rectangle(frame, (x,y), (x+w,y+h), 255,2)     cv2.imshow('img2',img2)     k = cv2.waitKey(30) & 0xff     if k == 27:        break else:     break

在这里插入图片描述

在这里插入图片描述

转载地址:http://vhben.baihongyu.com/

你可能感兴趣的文章
【Java.Web】MVC —— 基于Servlet Controller的Model2 —— 示例
查看>>
【Java.Web】MVC —— 基于Filter Dispatcher的Model2 —— 示例
查看>>
【Java.Web】MVC —— Action的验证器 —— Validator
查看>>
【Java.Spring.MVC】使用Spring MVC构建Web应用程序
查看>>
【DB.PL/SQL】程序流程控制 —— 异常处理
查看>>
【Java.IO】I/O 【字节】【处理流】 - 之 - 【压缩流】 - ZipInputStream,ZipOutputStream
查看>>
【Java.JDBC/ORM】纯JDBC系统的开发随想
查看>>
【Unix/Linux】【系统】环境变量
查看>>
【Architecture】CPU-bound(计算密集型) 和I/O bound(I/O密集型)
查看>>
【MacOS】Mac 系统下类似于 apt-get 的软件包管理器 -- Homebrew
查看>>
为窗口添加鼠标HOVER和LEAVE事件
查看>>
VC小技巧20个
查看>>
MFC Feature Pack for Visual C++ 2008的BUG之一
查看>>
POJ - 2739 Sum of Consecutive Prime Numbers
查看>>
STL map映照容器(一)map创建、元素插入、元素删除和遍历访问
查看>>
Leetcode - 557反转字符串中的单词III
查看>>
Leetcode - 160相交链表
查看>>
Leetcode - 11盛最多水的容器
查看>>
Leetcode - 141环形链表
查看>>
Leetcode - 14最长公共前缀
查看>>