#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. TCP服务器/客户端代码示例

    TCP服务器代码: #include <errno.h> #include <string.h> #include <stdlib.h> #include < ...

  2. 漫画|你还记得原生的JDBC怎么连接数据库吗?

    数据表的设计范式 在实际开发中最为常见的设计范式有三个: 第一范式是最基本的范式.如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式: 第二范式需要确保数据库表中的每一列都 ...

  3. 使用git push命令如何忽略不想提交的文件夹或者文件

    如下场景是在window下的操作. 在使用node的时候有个node_modules文件夹很大,一般情况下不想提交,忽略的办法如: 方法一(来自评论区):直接在仓库根目录:执行命令echo 'node ...

  4. HTML5 template元素

    前言 转自http://www.zhangxinxu.com/wordpress/2014/07/hello-html5-template-tag/ 在单页面应用,我们对页面的无刷新有了更高的要求,H ...

  5. linux学习笔记-软件包的相关知识

    我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! 一.软件包种类 1.源码包 源码包即提供源代码的发行包 2.二进制包 二进制包即提供二进制文件的发行包 安装方法查找二进制包官网 ...

  6. blfs(systemv版本)学习笔记-总页

    我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! lfs(systemv版本)学习笔记:https://www.cnblogs.com/renren-study-notes/p/ ...

  7. 关于<checkbox>checked默认问题

    这个问题困扰我有一段时间了,今天终于解决了. 接手现在的项目半个月了,我看之前的人写的<checkbox checked="false" />一直没有生效,但是需求上没 ...

  8. CSS--选择符大全(常用css选择符)

    (一)元素选择符 E(某个元素,如p) id(使用id,如#idName) class(使用class,如.myclass) 通配符:* (二)关系选择符 包含选择符:E F(E所有的F包含子代,孙代 ...

  9. java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderL,spring获取context

    今天学习spring项目的时候出现了下面的错误信息: java.lang.ClassNotFoundException: org.springframework.web.context.Context ...

  10. Android--实现ViewPager边界回弹效果(转)

    该View转自   http://blog.csdn.net/Kalwang/article/details/4708721  ,感谢这位大神. public class BounceBackView ...