opencv识别颜色

2024-06-22 10:20
文章标签 opencv 识别 颜色

本文主要是介绍opencv识别颜色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 导入必要的库:首先,需要导入 OpenCV 库和其他可能用到的库,如 NumPy。
  2. 加载图像:使用cv2.imread函数加载包含多种颜色的图像。
  3. 定义颜色范围:在 HSV 颜色空间中定义要识别的颜色范围。可以使用颜色选择器工具来确定所需颜色的 HSV 值范围。
  4. 颜色识别函数:创建一个颜色识别函数,用于在图像中识别指定颜色的区域。
  5. 图像处理:在颜色识别函数中,进行图像处理操作,如转换颜色空间、二值化、膨胀、检测轮廓等。
  6. 绘制轮廓和结果:根据识别到的颜色区域,绘制轮廓、框选目标,并显示结果。

以下是一个使用 OpenCV 进行颜色识别的示例代码

import cv2
import numpy as npdef color_identify(image, color_range):# 转换为 HSV 颜色模型hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)# 二值化处理,表示 HSV 中颜色的范围mask = cv2.inRange(hsv, color_range[0], color_range[1])# 膨胀操作kernel = np.ones((5, 5), dtype=np.uint8)dilate = cv2.dilate(mask, kernel, iterations=1)# 检测图像中轮廓的函数cnts, hierarchy = cv2.findContours(dilate, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)# 判断是否有轮廓if len(cnts) == 0:# 没有即显示原图cv2.imshow("color_identify", image)return# 返回最大面积的轮廓max_cnt = max(cnts, key=cv2.contourArea)# 用于在图像中绘制轮廓cv2.drawContours(image, max_cnt, -1, (0, 0, 255), 2)# 用于计算一个点集的最小边界矩形(x, y, w, h) = cv2.boundingRect(max_cnt)# 将目标框起来cv2.rectangle(image, (x, y), (x+w, y+h), (0, 0, 255), 3)# 在目标的中间画一个小圈cv2.circle(image, (x + (w//2), y + (h//2)), 6, (0, 0, 255), 2)# 打印出目标中点的坐标print("x + w:", x + (w//2), "y + h:", y + (h//2))cv2.imshow("color_identify", image)if __name__ == "__main__":# 打开摄像头cap = cv2.VideoCapture(0)# 设置摄像头参数cap.set(cv2.CAP_PROP_FRAME_WIDTH, 480)cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)cap.set(cv2.CAP_PROP_FPS, 100)while True:# 循环读取每一帧flag, frame = cap.read()# 将图像翻转过来frame = cv2.flip(frame, 1)# 如果读取失败if not flag:print("Camera error!")break# 调用颜色识别函数color_identify(frame, [(0, 150, 150), (10, 255, 255)])  # 识别红色# 等待用户按下‘q'键,如果按下则退出循环sun = cv2.waitKey(1)if sun == ord('q'):break# 关闭摄像头,解除程序占用摄像头cap.release()# cv2 把所有打开的窗口关闭掉cv2.destroyAllWindows()

定义了一个color_identify函数,它接受图像和颜色范围作为参数。在函数内部,首先将图像转换为 HSV 颜色空间,然后使用cv2.inRange函数进行二值化处理,得到指定颜色范围内的像素。接下来,进行膨胀操作和轮廓检测,找到最大面积的轮廓,并绘制轮廓、框选目标和显示结果。

if __name__ == "__main__":部分,打开摄像头并设置参数,然后在循环中读取每一帧图像,调用color_identify函数进行颜色识别。用户按下q键时,退出循环并关闭摄像头。

请注意,这只是一个简单的颜色识别示例代码,实际应用中可能需要根据具体情况进行更多的图像处理和优化。此外,颜色范围的选择可能需要根据实际图像进行调整。

 

这篇关于opencv识别颜色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084015

相关文章

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

基于CTPN(tensorflow)+CRNN(pytorch)+CTC的不定长文本检测和识别

转发来源:https://swift.ctolib.com/ooooverflow-chinese-ocr.html chinese-ocr 基于CTPN(tensorflow)+CRNN(pytorch)+CTC的不定长文本检测和识别 环境部署 sh setup.sh 使用环境: python 3.6 + tensorflow 1.10 +pytorch 0.4.1 注:CPU环境

百度OCR识别结构结构化处理视频

https://edu.csdn.net/course/detail/10506

brew install opencv@2 时报错 Error: Can't create update lock in /usr/local/var/homebrew/locks!

解决方案,报错里已经说明了: 我的解决方案: sudo chown -R "$USER":admin /usr/local   stackoverflow上的答案 I was able to solve the problem by using chown on the folder: sudo chown -R "$USER":admin /usr/local Also you'

Pycharm配置conda环境(解决新版本无法识别可执行文件问题)

引言: 很多小伙伴在下载最新版本的pycharm或者更新到最新版本后为项目配置conda环境的时候,发现文件夹目录中无法显示可执行文件(一般为python.exe),以下就是本人遇到该问题后试验和解决该问题的一些方法和思路。 一般遇到该问题的人群有两种,一种是刚入门对pycharm进行conda环境配置的小白(例如我),不熟悉相关环境配置的操作和过程,还有一种是入坑pycharm有段时间的老手

神经网络第四篇:推理处理之手写数字识别

到目前为止,我们已经介绍完了神经网络的基本结构,现在用一个图像识别示例对前面的知识作整体的总结。本专题知识点如下: MNIST数据集图像数据转图像神经网络的推理处理批处理  MNIST数据集          mnist数据图像 MNIST数据集由0到9的数字图像构成。像素取值在0到255之间。每个图像数据都相应地标有“7”、“2”、“1”等数字标签。MNIST数据集中,

改变背景颜色+碰撞检测

1.让类继承CCLayerColor比如 class HelloWorld:public cocos2d::CCLayerColor{ public : 在.cpp文件中 bool HelloWorld::init(){ if(!CCLayerColor::initWithColor(ccc4(255,255,255,25

vscode python pip : 无法将“pip”项识别为 cmdlet、函数、脚本文件或可运行程序的名称

在vscode中控制台运行python文件出现:无法将"pip”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。 使用vscode开发python,需要安装python开发扩展: 本文已经安装,我们需要找的是python安装所在目录,本文实际路径如下: 如果在本文路径中没有此目录,请尝试在C盘中搜索 python,搜索到相关python目录后,点击Python 3.9进入目录,

《学习OpenCV》课后习题解答7

题目:(P105) 创建一个结构,结构中包含一个整数,一个CvPoint和一个 CvRect;称结构体为“my_struct”。 a. 写两个函数:void Write_my_strct(CvFileStorage* fs, const char * name, my_struct* ms) 和 void read_my_struct(CvFileStorage* fs, CvFileNode

OpenCV中的按钮问题

在HighGUI中,没有显示提供任何形式的按钮。一般有两种方法替代: 1.用只有两个状态的滑动条来替代按钮。开关(switch)事实上就是只有两个状态的滑动条,这两个状态是on和off。然后通过回调函数来实现相关的功能。 实例源码(使用滑动条实现一个开关功能) #include<cv.h>#include<highgui.h>int g_switch_value = 0;void swit