【进阶OpenCV】 (13)--视频物体跟踪

文章目录

  • 物体跟踪
    • 一、跟踪器
    • 二、代码实现
      • [1. 创建CSRT跟踪器实例](#1. 创建CSRT跟踪器实例)
      • [2. 打开视频文件](#2. 打开视频文件)
      • [3. 主循环](#3. 主循环)
        • [3.1 读取每一帧](#3.1 读取每一帧)
        • [3.2 设置跟踪目标](#3.2 设置跟踪目标)
        • [3.3 更新跟踪器,获取对象位置](#3.3 更新跟踪器,获取对象位置)
        • [3.4 显示视频每一帧](#3.4 显示视频每一帧)
      • [4. 释放资源和关闭窗口](#4. 释放资源和关闭窗口)
      • [5. 完整代码展示](#5. 完整代码展示)
  • 总结

物体跟踪

本篇我们来介绍,如何对移动的目标进行跟踪。

我们既然要对物体进行跟踪,当然要使用方法,什么方法能够对目标进行跟踪呢?

我们来介绍一下跟踪器:

一、跟踪器

CSRT跟踪器 ,全称为Channel and Spatial Reliability Tracker,是一种在视频序列中进行目标跟踪的算法实现。CSRT跟踪器能够实时跟踪视频中的目标对象,即使目标对象在视频序列中发生尺度变化、变形或受到遮挡,也能保持稳健的跟踪效果。

  • 定义 :CSRT跟踪器是一种基于判别类模型方法中的相关滤波器跟踪算法,它结合了判别相关滤波器(DCF)和通道与空间可靠性图,以提高跟踪的准确性和鲁棒性。
  • 原理 :CSRT跟踪器利用图像中的颜色和梯度特征 ,在空间和通道上进行可靠性估计。它首先通过深度卷积神经网络(CNN)提取图像特征,然后使用这些特征来训练一个分类器,该分类器能够区分目标对象和其他背景。在跟踪过程中,CSRT利用多通道特征(如颜色、纹理)和空间可靠性来提高跟踪的准确性和鲁棒性。此外,它还考虑了目标的尺度变化和变形,使得跟踪更加稳定。

二、代码实现

1. 创建CSRT跟踪器实例

python 复制代码
import cv2
# 创建一个CSRT跟踪器实例
tracker = cv2.TrackerCSRT_create()
# 跟踪标志,默认为False
tracking = False

2. 打开视频文件

使用cv2.VideoCapture()函数打开视频文件:

python 复制代码
cap = cv2.VideoCapture('video.wmv')

3. 主循环

3.1 读取每一帧
python 复制代码
while True:
    ret, frame = cap.read()  # 如果正确读取,ret为True
    if not ret:
        print("不能读取摄像头")
        break
    frame = cv2.resize(frame,dsize=None,fx=0.5,fy=0.5)
3.2 设置跟踪目标

检查是否有按键被按下,如果是'a'健,则设置跟踪标志为True,并选择ROI,然后可在视频中框选矩形区域,锁定目标:

python 复制代码
# 检查是否有按键被按下,如果是'a'健,则设置跟踪标志为True,并选择ROI
if cv2.waitKey(1) == ord('a'):
    tracking = True
    # 让用户在当前帧中选择一个矩形区域作为要跟踪的对象
    roi = cv2.selectROI('Tracking',frame,showCrosshair=False) # 是否显示十字准星
    # 初始化跟踪器,传入当前帧和选定的ROI
    tracker.init(frame,roi)
3.3 更新跟踪器,获取对象位置
python 复制代码
# 如果跟踪标志为True,则更新跟踪器
if tracking:
    success,box = tracker.update(frame)
    # 如果跟踪成功,获取对象的位置
    if success:
        x,y,w,h = [int(v) for v in box] # 确保所有坐标都是整数
        # 在frame上绘制矩形框以显示跟踪结果
        cv2.rectangle(frame,(x,y),(x+w,y+h),(0,255,0),2)
3.4 显示视频每一帧
python 复制代码
# 显示处理后的帧
cv2.imshow('Tracking',frame)
# 检查是否按下了Esc键(ASCII码27),如果按下则退出循环
if cv2.waitKey(100) == 27:
    break
  • 展示跟踪效果

4. 释放资源和关闭窗口

python 复制代码
# 释放摄像头资源
cap.release()
# 关闭所有创建的窗口
cv2.destroyAllWindows()

5. 完整代码展示

python 复制代码
import cv2
# 创建一个CSRT跟踪器实例
tracker = cv2.TrackerCSRT_create()
# 跟踪标志,默认为False
tracking = False

"""-----打开默认摄像头-----"""
cap = cv2.VideoCapture('video.wmv')
while True:
    ret, frame = cap.read()  # 如果正确读取,ret为True
    if not ret:
        print("不能读取摄像头")
        break
    frame = cv2.resize(frame,dsize=None,fx=0.5,fy=0.5)
    # 检查是否有按键被按下,如果是'a'健,则设置跟踪标志为True,并选择ROI
    if cv2.waitKey(1) == ord('a'):
        tracking = True
        # 让用户在当前帧中选择一个矩形区域作为要跟踪的对象
        roi = cv2.selectROI('Tracking',frame,showCrosshair=False) # 是否显示十字准星
        # 初始化跟踪器,传入当前帧和选定的ROI
        tracker.init(frame,roi)

    # 如果跟踪标志为True,则更新跟踪器
    if tracking:
        success,box = tracker.update(frame)
        # 如果跟踪成功,获取对象的位置
        if success:
            x,y,w,h = [int(v) for v in box] # 确保所有坐标都是整数
            # 在frame上绘制矩形框以显示跟踪结果
            cv2.rectangle(frame,(x,y),(x+w,y+h),(0,255,0),2)
    # 显示处理后的帧
    cv2.imshow('Tracking',frame)
    # 检查是否按下了Esc键(ASCII码27),如果按下则退出循环
    if cv2.waitKey(100) == 27:
        break
# 释放摄像头资源
cap.release()
# 关闭所有创建的窗口
cv2.destroyAllWindows()

总结

本篇介绍了如何使用CSRT跟踪器对移动的目标进行跟踪。

相关推荐
云烟成雨TD4 小时前
Spring AI Alibaba 1.x 系列【22】Agent 并行工具执行与超时 / 协作式取消实战
java·人工智能·spring
阿里云大数据AI技术4 小时前
让 AI 帮你写大数据AI开发代码:MaxFrame Coding Skill 正式发布
人工智能·agent
麦哲思科技任甲林4 小时前
大懒人AI结对工作模式——驾驭AI编程的进阶指南
人工智能·ai编程·结对编程·工作模式·ai赋能
Raink老师4 小时前
【AI面试临阵磨枪】什么是 MCP(Model Control Protocol)、A2A(Agent-to-Agent)协议?
人工智能·面试·职场和发展·ai 面试
明月照山海-4 小时前
机器学习周报四十一
人工智能·机器学习
Daydream.V4 小时前
LSTM项目实战——情感分析项目
人工智能·rnn·lstm
byte轻骑兵5 小时前
从收音机到蓝牙:LE Audio核心BASS服务解析与实战
人工智能·音视频·语音识别·le audio·低功耗音频
饭后一颗花生米5 小时前
2026 AI加持下前端学习路线:从入门到进阶,高效突破核心竞争力
前端·人工智能·学习
默 语5 小时前
“我跑不过我的代码“:今天北京半马,程序员追机器人追到开电瓶车
人工智能·机器人·openclaw
AC赳赳老秦5 小时前
HR必备:OpenClaw批量筛选简历、发送面试通知,优化招聘流程
运维·人工智能·python·eclipse·github·deepseek·openclaw