opencv--颜色物体识别跟踪

HSV颜色空间与人眼较为接近,一般以HSV为颜色检测和识别

H--色调(红-绿-蓝)

S--饱和度(颜色深浅)

V-亮度(颜色亮暗)

opencv H范围(0-180)  S(0-255)  V(0-255)


HSV二值化处理的函数CV_EXPORTS_W void inRange(InputArray src, InputArray lowerb,InputArray upperb, OutputArray dst);

第一个参数是输入图像

第二个参数是低阈值

第三个参数是高阈值//高低阈值指的是hsv的高低阈值,当图像的hsv在高低阈值之间那么输出图像为255白,否则为0

第四个参数是输出图像(大小与输入图像一样,类型是8U)Mat dstImage=Mat::zeros(srcImage.size(),CV_8U);



代码


#include "opencv2/opencv.hpp"
#include "iostream"


using namespace cv;
using namespace std;






int h_min=156;
int s_min=97;
int v_min=159;


int h_max=180;
int s_max=255;
int v_max=255;


void main()
{
Mat srcImage=imread("strawberry4.jpg");
imshow("src",srcImage);
Mat tempImage=srcImage.clone();
cvtColor(srcImage,srcImage,CV_BGR2HSV);
Scalar hsv_min(h_min,s_min,v_min);
Scalar hsv_max(h_max,s_max,v_max);
Mat dstImage=Mat::zeros(srcImage.size(),CV_8U);
inRange(srcImage,hsv_min,hsv_max,dstImage);
Mat element=getStructuringElement(MORPH_RECT,Size(5,5));
morphologyEx(dstImage,dstImage,MORPH_ERODE,element,Point(-1,-1),1);
morphologyEx(dstImage,dstImage,MORPH_DILATE,element,Point(-1,-1),4);
imshow("dst",dstImage);
vector<vector<Point>>contours;
findContours(dstImage,contours,RETR_EXTERNAL,CHAIN_APPROX_NONE);
vector<Rect>rect(contours.size());
for(int i=0;i<contours.size();i++)
{
rect[i]=boundingRect(contours[i]);
int x=rect[i].x;
int y=rect[i].y;
int width=rect[i].width;
int height=rect[i].height;
rectangle(tempImage,Point(x,y),Point(x+width,y+height),Scalar(0,255,0),2);
}
imshow("result",tempImage);
waitKey(0);
}


其中的hsv阈值需要自己用滑动条来确定使用的范围



效果



  • 6
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用Qt和OpenCV实现基于颜色物体区分时,可以按照以下步骤进行操作: 1. 导入Qt和OpenCV的相关库和头文件。 2. 打开摄像头或者读取视频为输入源。 3. 读取每一帧图像。 4. 将图像从BGR色彩空间转换为HSV色彩空间,由于HSV色彩空间更适合进行颜色分析。 5. 设定目标物体颜色范围,使用inRange函数进行颜色分割,得到目标物体的二值图像。 6. 对二值图像进行形态学操作,如腐蚀和膨胀,以消除噪声和填充目标物体内部空洞。 7. 使用findContours函数找到目标物体的轮廓。 8. 根据轮廓的特征,如面积、周长、外接矩形等,对目标物体进行筛选,去除不符合条件的轮廓。 9. 在原始图像上绘制出符合条件的目标物体轮廓。 10. 可以选择添加其他附加功能,如标记目标物体的中心点、显示物体跟踪trajectory等。 11. 循环执行步骤3至步骤10,实现实时的基于颜色物体区分。 12. 释放摄像头或关闭视频文件。 13. 结束程序运行。 通过以上步骤,可以利用Qt和OpenCV实现基于颜色物体区分,通过对目标物体颜色的提取和轮廓分析,实现对不同颜色物体识别和分割。 ### 回答2: Qt是一种跨平台的应用程序框架,而OpenCV是一个功能强大的开源计算机视觉库。结合Qt和OpenCV,我们可以实现基于颜色物体区分。 首先,要使用Qt和OpenCV,在Qt项目中包括OpenCV库并链接到项目中。接下来,我们需要通过Qt提供的界面来获取图像。可以使用Qt的QCamera类来连接到摄像头并捕获实时图像,或者使用Qt的QFileDialog类来选择所需的图像文件。 一旦我们获得了图像,我们就可以使用OpenCV的函数进行图像处理和分析。对于基于颜色物体区分,首先需要将图像从RGB颜色空间转换为HSV颜色空间。在HSV颜色空间中,我们可以更容易地对颜色进行分析。 然后,我们可以根据所需颜色的HSV范围来创建一个掩码。掩码是一个二进制图像,其中白色像素表示在指定颜色范围内的像素,而黑色像素表示不在范围内的像素。我们可以使用OpenCV的inRange函数创建此掩码。 接下来,我们可以使用掩码将原始图像中的物体分割出来。可以使用OpenCV的bitwise_and函数将原始图像与掩码进行按位与操作,从而只保留掩码中的白色区域。 最后,我们可以在Qt界面中显示分割出的物体。可以使用Qt的QPixmap类将OpenCV的Mat对象转换为Qt的QImage对象并显示在Qt的窗口上。 总结起来,使用Qt和OpenCV实现基于颜色物体区分将涉及连接到摄像头或选择图像文件,将图像从RGB转换为HSV颜色空间,创建颜色范围掩码,使用掩码分割图像和在Qt界面中显示结果。 ### 回答3: Qt与OpenCV结合可以实现基于颜色物体区分。首先,我们需要使用Qt框架实现图像的读取和显示功能。通过Qt的图片处理类,我们可以方便地读取和显示图片。 然后,我们集成OpenCV库,通过Qt的信号和槽机制与OpenCV库进行交互。使用OpenCV库的颜色空间转换函数,我们可以将图片转换为HSV色彩空间。HSV色彩空间相对于RGB色彩空间更适合颜色分析。 接下来,我们可以使用OpenCV库的阈值函数来分割图像中的不同颜色区域。通过设置合适的阈值,我们可以将目标物体颜色从背景中区分出来。之后,我们可以通过OpenCV库的形态学操作对图像进行进一步处理,如腐蚀和膨胀,以消除噪声和填充空洞。 最后,使用Qt的绘图功能,我们可以在原始图像上绘制标记框或者轮廓,以展示区分出的目标物体。同时,可以利用Qt的界面设计功能,添加一些按钮和滑动条等控件,以便用户可以交互式地调整参数,实时观察效果。 总之,通过Qt的图像处理和OpenCV的颜色分割技术,我们可以实现基于颜色物体区分。这样的系统可以应用于许多领域,如机器人视觉、工业自动化等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值