(笔记四)利用opencv识别标记视频中的目标

预操作:

通过cv2将视频的某一帧图片转为HSV模式,并通过鼠标获取对应区域目标的HSV值,用于后续的目标识别阈值区间的选取

``

python 复制代码
img = cv.imread(r"D:\data\123.png")
img = cv.cvtColor(img, cv.COLOR_BGR2HSV)
plt.figure(1), plt.imshow(img)
plt.show()

(1)将视频中识别的目标掩膜成红色

python 复制代码
end_frame[mask > 0] = [0, 0, 255]

(2)利用cv库读取显示原始视频

(3)在HSV阈值分割识别的视频目标

python 复制代码
hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV)
# 定义分割黑色的上下区间,其代表的是目标物体的hsv空间内的最小值和最大值
low = np.array([60, 60, 60])
up = np.array([130, 120, 120])
mask = cv.inRange(hsv, low, up)        

(4)按位与运算之后的视频目标(目标的真实色彩)

python 复制代码
# 进行按位运算,白色的变为frame原来的颜色,其他还是黑色
res = cv.bitwise_and(frame, frame, mask=mask)

(5)主代码(已经给出解释)

python 复制代码
#!/usr/bin/env python
# -*- coding:utf-8 -*-
"""
@author: LIFEI
@time: 2023/8/29 14:39 
@file: test4.py
@project: pythonProject
@describe: TODO
@# -------------------------------------------------(one)----------------------------------------------
@# -------------------------------------------------(two)----------------------------------------------
"""

# -------------------------------------------------(one)----------------------------------------------
import cv2 as cv
import numpy as np
from matplotlib import pyplot as plt


# img = cv.imread(r"D:\data\123.png")
# img = cv.cvtColor(img, cv.COLOR_BGR2HSV)
# plt.figure(1), plt.imshow(img)
# plt.show()

def identify(path, point):
    # 创建一个video基类
    cap = cv.VideoCapture(path)
    # 当cap被打开时开始循环
    while cap.isOpened():
        #  读取视频
        ret, frame = cap.read()
        # 拷贝图像,赋值给end_frame
        end_frame = np.copy(frame)
        # 将视频的BGR空间转换为HSV空间
        hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV)
        # 定义分割黑色的上下区间,其代表的是目标物体的hsv空间内的最小值和最大值
        low = np.array([60, 60, 60])
        up = np.array([130, 120, 120])
        # 类似与阈值分割,就是将上述的区间类的物体改成白色,其他改为黑色
        mask = cv.inRange(hsv, low, up)
        # 进行按位运算,白色的变为frame原来的颜色,其他还是黑色
        res = cv.bitwise_and(frame, frame, mask=mask)
        # 将end_frame中的mask白色区域变成红色
        end_frame[mask > 0] = [0, 0, 255]
        # 判断帧率是否存在,若是不存在直接退出
        if not ret:
            break
        # 判断输出
        if point == 1:
            cv.imshow("frame", frame)
        elif point == 2:
            cv.imshow("mask", mask)
        elif point == 3:
            cv.imshow("avi", res)
        else:
            cv.imshow("end_frame", end_frame)
        # 这里理解为视频的快慢,1表示原始速度,越大越慢,按'q'退出显示
        if cv.waitKey(15) & 0xFF == ord('q'):
            break

    cv.waitKey(0)
    # 释放
    cap.release()
    cv.destroyAllWindows()


if __name__ == '__main__':
    # 视频的路径
    filepath = r"D:\data\plane.avi"
    # 访问输入的数值,后续循环要用
    value = input('请输入一个数字(1表示ori,2表示mask,3表示res,4表示end_frame):')
    # 转为整型
    value = int(value)
    # 开始操作
    identify(filepath, value)

# -------------------------------------------------(two) - -------------------------------------------
相关推荐
_Kayo_3 小时前
node.js 学习笔记3 HTTP
笔记·学习
星星火柴9367 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
Cx330❀9 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
小幽余生不加糖10 小时前
电路方案分析(二十二)适用于音频应用的25-50W反激电源方案
人工智能·笔记·学习·音视频
..过云雨10 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
岑梓铭11 小时前
考研408《计算机组成原理》复习笔记,第五章(3)——CPU的【数据通路】
笔记·考研·408·计算机组成原理·计组
Blossom.11818 小时前
把 AI 推理塞进「 8 位 MCU 」——0.5 KB RAM 跑通关键词唤醒的魔幻之旅
人工智能·笔记·单片机·嵌入式硬件·深度学习·机器学习·搜索引擎
草莓熊Lotso18 小时前
《吃透 C++ 类和对象(中):const 成员函数与取地址运算符重载解析》
c语言·开发语言·c++·笔记·其他
玖別ԅ(¯﹃¯ԅ)19 小时前
PID学习笔记6-倒立摆的实现
笔记·stm32·单片机
jndingxin20 小时前
OpenCV图像注册模块
人工智能·opencv·计算机视觉