opencv计算机视觉--模板匹配&物体跟踪

一、模板匹配

cv2.matchTemplate(image, templ, method)

image:待搜索图像

templ:模板图像

method:计算匹配程度的方法:

TM_SQDIFF平方差匹配法:该方法采用平方差来进行匹配;匹配越好,值越小;匹配越差,值越大。

TM_CCORR相关匹配法:该方法采用乘法操作;数值越大表明匹配程度越好。

TM_CCOEFF相关系数匹配法:数值越大表明匹配程度越好。

TM_SQDIFF_NORMED归一化平方差匹配法,匹配越好,值越小;匹配越差,值越大。

TM_CCORR_NORMED归一化相关匹配法,数值越大表明匹配程度越好。

TM_CCOEFF_NORMED 归一化相关系数匹配法,数值越大表明匹配程度越好。

相关代码
python 复制代码
import cv2

# 读取图像
kele = cv2.imread('kele.png')   
kele=cv2.resize(kele,dsize=None,fx=1.5,fy=1.5)
tubiao = cv2.imread('tubiao.png') 
tubiao=cv2.resize(tubiao,dsize=None,fx=1.5,fy=1.5)
cv2.imshow('kele', kele) 
cv2.waitKey(0)
cv2.imshow('tubiao', tubiao)  
cv2.waitKey(0)
h, w = tubiao.shape[:2]  # 获取模板图像的高度和宽度

# 使用模板匹配方法
res = cv2.matchTemplate(kele, tubiao, cv2.TM_CCOEFF_NORMED)

min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)
# min_val:最小匹配值
# max_val:最大匹配值(最匹配的位置)
# min_loc:最小匹配值的位置坐标
# max_loc:最大匹配值的位置坐标(最佳匹配位置)

top_left = max_loc  
bottom_right = (top_left[0] + w, top_left[1] + h)  

kele_tubiao = cv2.rectangle(kele, top_left, bottom_right, (0, 255, 0), 2)
cv2.imshow('kele_tubiao', kele_tubiao)
cv2.waitKey(0)
cv2.destroyAllWindows()

注:模板的大小,要和图形中的所对应模板大小相同

二、物体跟踪

1、概念

物体跟踪是计算机视觉中的一个重要任务,指在视频序列中持续定位和追踪特定目标对象的位置。它不同于物体检测(每帧独立检测),跟踪需要维护目标的身份信息,在连续的帧中跟随同一个目标。

2、实际运用
1. 创建跟踪器
python 复制代码
tracker = cv2.TrackerCSRT_create()
  • cv2.TrackerCSRT_create(): 创建 CSRT 跟踪器

  • OpenCV 提供了多种跟踪算法:

    • TrackerCSRT_create(): 高精度,速度较慢

    • TrackerKCF_create(): 平衡精度和速度

    • TrackerMOSSE_create(): 速度最快,精度较低

    • TrackerMIL_create(): 中等性能

2. 选择目标区域
python 复制代码
roi = cv2.selectROI(windowName='Tracking', img=frame, showCrosshair=False)
  • cv2.selectROI(): 让用户在图像上选择矩形区域

  • 参数:

    • windowName: 窗口名称

    • img: 要选择ROI的图像

    • showCrosshair: 是否显示十字准线

  • 返回值:(x, y, width, height) 元组

3. 初始化跟踪器
python 复制代码
tracker.init(frame, roi)
  • tracker.init(): 用第一帧和初始边界框初始化跟踪器

  • 参数:

    • frame: 第一帧图像

    • roi: 初始边界框

4. 更新跟踪器
python 复制代码
success, box = tracker.update(frame)
  • tracker.update(): 在后续帧中更新跟踪器

  • 参数:当前帧图像

  • 返回值:

    • success: 布尔值,跟踪是否成功

    • box: 跟踪到的边界框 (x, y, width, height)

5. 绘制跟踪结果
python 复制代码
cv2.rectangle(frame, pt1=(x, y), pt2=(x + w, y + h), color=(0, 255, 0), thickness=2)
  • 在跟踪到的位置上绘制绿色矩形框
完整代码
python 复制代码
import cv2
# 创建一个CSRT跟踪器实例
tracker = cv2.TrackerCSRT_create()
# 跟踪标志,默认为False
tracking = False
# 打开默认摄像头(通常编号为0)
cap = cv2.VideoCapture(0)
while True:
    # 从摄像头读取一帧图像
    ret, frame = cap.read()
    # 如果没有正确读取到图像,则退出循环
    if not ret:
        break
    # 检查是否有按键被按下,如果是'a'键,则设置跟踪标志为True,并选择ROI
    if cv2.waitKey(1) == ord('s'):
        tracking = True
        # 让用户在当前帧中选择一个矩形区域作为要跟踪的对象
        roi = cv2.selectROI(windowName='Tracking', img=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, pt1=(x, y), pt2=(x + w, y + h), color=(0, 255, 0), thickness=2)
    # 显示处理后的帧
    cv2.imshow('Tracking',frame)
    # 检查是否按下ESC键(ASCII码27),如果按下则退出循环
    if cv2.waitKey(1) == 27:
        break
# 释放摄像头资源
cap.release()
# 关闭所有OpenCV创建的窗口
cv2.destroyAllWindows()
相关推荐
九.九17 小时前
ops-transformer:AI 处理器上的高性能 Transformer 算子库
人工智能·深度学习·transformer
春日见17 小时前
拉取与合并:如何让个人分支既包含你昨天的修改,也包含 develop 最新更新
大数据·人工智能·深度学习·elasticsearch·搜索引擎
恋猫de小郭17 小时前
AI 在提高你工作效率的同时,也一直在增加你的疲惫和焦虑
前端·人工智能·ai编程
YJlio17 小时前
1.7 通过 Sysinternals Live 在线运行工具:不下载也能用的“云端工具箱”
c语言·网络·python·数码相机·ios·django·iphone
deephub17 小时前
Agent Lightning:微软开源的框架无关 Agent 训练方案,LangChain/AutoGen 都能用
人工智能·microsoft·langchain·大语言模型·agent·强化学习
l1t18 小时前
在wsl的python 3.14.3容器中使用databend包
开发语言·数据库·python·databend
大模型RAG和Agent技术实践18 小时前
从零构建本地AI合同审查系统:架构设计与流式交互实战(完整源代码)
人工智能·交互·智能合同审核
老邋遢18 小时前
第三章-AI知识扫盲看这一篇就够了
人工智能
互联网江湖18 小时前
Seedance2.0炸场:长短视频们“修坝”十年,不如AI放水一天?
人工智能
PythonPioneer18 小时前
在AI技术迅猛发展的今天,传统职业该如何“踏浪前行”?
人工智能