当前位置: 首页 > news >正文

python+opencv寻找图片或视频中颜色进行追踪之HSV颜色处理

python+opencv寻找图片或视频中颜色进行追踪之HSV颜色处理

1.颜色空间转换

import cv2img = cv2.imread('1.jpg')
# 转换为灰度图
img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)cv2.imshow('img', img)
cv2.imshow('gray', img_gray)
cv2.waitKey(0)

cv2.cvtColor()用来进行颜色模型转换,参数 1 是要转换的图片,参数 2 是转换模式

2.视频中特定颜色物体追踪

import cv2
import numpy as npdef detect_white(image_path):# 读取图像image = cv2.imread(image_path)# 将图像从RGB转换为HSVhsv_image = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)# 定义白色在HSV颜色空间的阈值范围lower_white = np.array([114,  36, 234], dtype=np.uint8)upper_white = np.array([177 , 10 ,251], dtype=np.uint8)# 应用阈值,提取白色区域white_mask = cv2.inRange(hsv_image, lower_white, upper_white)# 对提取的二值图像进行形态学操作,去除噪音kernel = np.ones((5, 5), np.uint8)white_mask = cv2.morphologyEx(white_mask, cv2.MORPH_OPEN, kernel)# 在原始图像上标记白色区域result = cv2.bitwise_and(image, image, mask=white_mask)# 显示结果图像cv2.imshow("Result", result)cv2.waitKey(0)cv2.destroyAllWindows()# 调用函数进行白色区域识别
detect_white("2.jpg")

3.那蓝色的 HSV 值的上下限 lower 和 upper 范围是怎么得到的呢?


import cv2
import numpy as np# img是你的BGR图像
img = cv2.imread('1111.png')# 将BGR图像转换为HSV图像
hsv_img = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
# 获取H, S, V的最小值和最大值
min_h, max_h = np.min(hsv_img[:,:,0]), np.max(hsv_img[:,:,0])
min_s, max_s = np.min(hsv_img[:,:,1]), np.max(hsv_img[:,:,1])
min_v, max_v = np.min(hsv_img[:,:,2]), np.max(hsv_img[:,:,2])print(min_h, max_h)
print(min_s, max_s)
print(min_v, max_v)

或者:

import cv2img = cv2.imread('2.jpg')
# gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)def mouse_click(event, x, y, flags, para):if event == cv2.EVENT_LBUTTONDOWN:  # 左边鼠标点击print('PIX:', x, y)# print("BGR:", img[y, x])# print("GRAY:", gray[y, x])print("HSV:", hsv[y, x])if __name__ == '__main__':cv2.namedWindow("img")cv2.setMouseCallback("img", mouse_click)while True:cv2.imshow('img', img)if cv2.waitKey() == ord('q'):break
http://www.lryc.cn/news/172289.html

相关文章:

  • ubuntu 22.04 服务器网卡无IP地址
  • 基于SpringBoot的网上点餐系统
  • 浅谈xss
  • 悬崖边:企业如何应对网络安全漏洞趋势
  • MyBatis 动态 SQL、MyBatis 标签、MyBatis关联查询
  • 在Vue中使用Immutable.js
  • 基于Yolov8的工业端面小目标计数检测(1)
  • 1.什么是jwt?jwt的作用是什么?2.jwt的三个部分是什么?三者之间的关系如何?3.JWT运行的流程是什么
  • 十三、MySql的视图
  • MFC扩展库BCGControlBar Pro v33.6亮点 - 流程图、Ribbon Bar功能升级
  • 前端 JS 经典:文件流下载
  • SSL免费证书会报安全提示吗?
  • 为什么要选择Spring cloud Sentinel
  • 第八天:gec6818arm开发板和Ubuntu中安装并且编译移植mysql驱动连接QT执行程序
  • 使用JavaScript实现图片的自动轮播
  • React 如何拿时间戳计算得到开始和结束时间戳
  • leetcode114 二叉树展开为链表
  • Linux系统上使用SQLite
  • 实现一个超级简单的string类(基于c++)
  • uniapp存值和取值,获取登录凭证 code方法
  • 【SpringCloud微服务全家桶学习笔记-服务调用Ribbon/openFeign】
  • Qt使用I.MX6U开发板上的按键(原理:将电脑键盘方向键↓在Qt中的枚举值与开发板中按键定义的枚举值一致,这样电脑端测试效果就与开发板的一致)
  • C++ RAII在HotSpot VM中的重要应用
  • python随手小练
  • MySQL——函数和流程控制
  • 【Vue3 源码讲解】nextTick
  • 什么是ATR,在聚宽量化平台如何计算ATR
  • Python 爬虫实战之爬淘宝商品并做数据分析
  • Python爬虫-requests.exceptions.SSLError: HTTPSConnectionPool疑难杂症解决(1)
  • 12:STM32---RTC实时时钟