#include<opencv2/opencv.hpp>
#include<iostream> using namespace cv;
using namespace std; Rect roi;
Mat frame, mask;
void processFrame(Mat &binary, Rect &rect); int main(int argc, char* argv) {
VideoCapture capture();//打开摄像头
if (!capture.isOpened()) {
printf("Could not find Video data..");
return -;
} Mat kernel1 = getStructuringElement(MORPH_RECT, Size(, ), Point(-, -));
Mat kernel2 = getStructuringElement(MORPH_RECT, Size(, ), Point(-, -)); namedWindow("input_Video", CV_WINDOW_AUTOSIZE);
namedWindow("mask_Video", CV_WINDOW_AUTOSIZE);
while (capture.read(frame))//读取当前帧
{ inRange(frame, Scalar(, , ), Scalar(, , ), mask);//过滤得到Scalar1到Scalar2之间的图像 //形态学操作
morphologyEx(mask, mask, MORPH_OPEN, kernel1, Point(-, -));//开操作,去掉噪声
dilate(mask, mask, kernel2, Point(-, -), );//膨胀,填补空洞
imshow("mask_Video", mask); processFrame(mask, roi); // 轮廓发现与位置标定
rectangle(frame, roi, Scalar(, , ), , , );//画出外接矩形
imshow("input_Video", frame); char c = waitKey();//延时100ms
if (c == ) //等待“Esc”
{
break;
}
}
capture.release();//释放视频的内存
waitKey();
return ; } //binary:输入图像
//rect:返回的ROI区域
void processFrame(Mat &binary, Rect &rect) {
Point p, center;
vector<vector<Point>> contours;
vector<Vec4i> hireachy;
//发现最外层轮廓
findContours(binary, contours, hireachy, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE, Point(, )); if (contours.size() > ) //判断是否有轮廓被找到
{
double maxArea = 0.0;
for (size_t t = ; t < contours.size(); t++) {
double area = contourArea(contours[static_cast<int>(t)]);//获取轮廓的面积
if (area > maxArea)//面积筛选,只画出最大的轮廓
{
maxArea = area;
rect = boundingRect(contours[static_cast<int>(t)]);//获取最小外界矩形 //计算并输出坐标
center.x = rect.x + cvRound(rect.width / 2.0);
center.y = rect.y + cvRound(rect.height / 2.0);
center.x = center.x - frame.cols / ;
center.y = center.y - frame.rows / ; cout << center.x << "," << center.y << endl;
}
} }
else {
rect.x = rect.y = rect.width = rect.height = ;
} }

 inRange()函数 :

此函数作用:可实现二值化功能(这点类似threshold()函数),更关键的是可以同时针对多通道进行操作,使用起来非常方便! 主要是将在两个阈值内的像素值设置为白色(255),而不在阈值区间内的像素值设置为黑色(0),该功能类似于之间所讲的双阈值化操作。

void inRange(InputArray src, InputArray lowerb,
InputArray upperb, OutputArray dst);

参数解释:

参数1:输入要处理的图像,可以为单通道或多通道。

参数2:包含下边界的数组或标量。

参数3:包含上边界数组或标量。

参数4:输出图像,与输入图像src 尺寸相同且为CV_8U 类型。

请注意:该函数输出的dst是一幅二值化之后的图像。

OpenCV (C++) 颜色跟随的更多相关文章

  1. OpenCV——视频颜色识别

    #include <opencv2/opencv.hpp> #include <iostream> using namespace std; using namespace c ...

  2. android——字体颜色跟随状态改变

    TextView的字体颜色也可以和ImageView的background一样,跟随状态发生改变.只需要自定义一下字体颜色.在color文件夹下面,新建一个颜色文件的xml. OK ,这就完成 了. ...

  3. opencv之颜色过滤只留下图片中的红色区域

    如图,这次需要在图片中找到卷尺的红色刻度,所以需要对图像做过滤,只留下红色部分. 一开始的想法是分别找到RGB值,然后找到红色区域的部分保留就可以了,不过好像很难确定红色区域的RGB取值范围,所以要把 ...

  4. opencv::基于颜色跟踪检测

    基于颜色跟踪 inRange过滤 形态学操作提取 轮廓查找 外接矩形获取 位置标定

  5. OpenCV随机颜色,用于画图调试

    static Scalar randomColor(int64 seed) { RNG rng(seed); int icolor = (unsigned)rng; return Scalar(ico ...

  6. opencv颜色识别代码分享

    android 平台 opencv 实现颜色识别代码:http://www.eyesourcecode.com/thread-40682-1-1.htmlopencv的颜色识别简单实现的代码:http ...

  7. 【Windows 10 应用开发】跟随系统主题颜色

    有些时候,希望应用程序中的某些颜色可以与系统的主题颜色相同,并且当系统主题色改变时进行同步. 实现过程并不复杂,主要用到 UISettings 类,它公开一个 GetColorValue 方法,访问这 ...

  8. OpenCV成长之路(3):模仿PhotoShop中魔术棒工具

    本文的主题实际上是图像的颜色空间的转换,借助一个颜色选取程序来说明OpenCV中颜色转换函数的用法以及一些注意事项. 一.几种常见的颜色空间: RGB颜色空间:RGB采用加法混色法,因为它是描述各种“ ...

  9. 批量分割视频opencv

    前言 视频处理过程中,会用到对等长的视频进行处理,此时要对大视频进行分割. 实现步骤 1.批量读取视频集: 2.视频分割: 测试代码 1.批量读取视频集: /********************* ...

随机推荐

  1. [redis] Redis的介绍

    mysql数据库:数据以“文件的形式”存储在硬盘里 网站的瓶颈是在数据库的访问上,mysql数据库是运行在硬盘上面的,把数据放到内存里速度就快多了 Redis是一款内存高速缓存数据库,使用c语言编写, ...

  2. 【操作系统】二、JVM线程与Linux内核线程的映射

    Linux从内核2.6开始使用NPTL (Native POSIX Thread Library)支持,但这时线程本质上还轻量级进程. Java里的线程是由JVM来管理的,它如何对应到操作系统的线程是 ...

  3. 【Java深入研究】5、Proxy动态代理机制详解

    在学习Spring的时候,我们知道Spring主要有两大思想,一个是IoC,另一个就是AOP,对于IoC,依赖注入就不用多说了,而对于Spring的核心AOP来说,我们不但要知道怎么通过AOP来满足的 ...

  4. webpack4 系列教程(五): 处理CSS

    这节课讲解webpack4中打包css的应用.v4 版本和 v3 版本并没有特别的出入. >>> 本节课源码 >>> 所有课程源码 教程所示图片使用的是 githu ...

  5. 一些关于Viewport与device-width的东西~(转)

    内容转自 http://www.cnblogs.com/koukouyifan/p/4066567.html 非常感谢 口口一凡 为我们提供的这篇文章,受益匪浅,特地转到自己的博客收藏起来. 以下是原 ...

  6. selenium win7+selenium2.0+python环境搭建

    win7+selenium2.0+python环境搭建 by:授客 QQ:1033553122 步骤1:下载python 担心最新版的支持不太好,这里我下载的是python 2.7(selenium之 ...

  7. Application.Current的使用

    来源 http://www.cnblogs.com/symons/archive/2010/03/15/1686200.html Application.Current的使用 WPF程序对应一个App ...

  8. springboot 学习之路 20 (整合RabbitMQ)

    整合RabbitMQ: 我的操作系统是window7 ,所以在整合ribbotMQ之前需要先安装rabbitMq服务:安装步骤请参考:window下安装RabbitMQ  这个详细介绍了安装步骤,请按 ...

  9. 03-12_MBean层次结构

    本文重点: Mbeans层次结构与WLST关系介绍 WebLogic Mbeans的类型 weblogic服务器的MBeans生命周期             Mbeans层次结构与WLST关系介绍: ...

  10. EF Core扩展工具记录

    Microsoft.EntityFrameworkCore.AutoHistory Microsoft.EntityFrameworkCore 的一个插件,支持自动记录数据更改历史记录. GitHub ...