OpenCV (C++) 颜色跟随
#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++) 颜色跟随的更多相关文章
- OpenCV——视频颜色识别
#include <opencv2/opencv.hpp> #include <iostream> using namespace std; using namespace c ...
- android——字体颜色跟随状态改变
TextView的字体颜色也可以和ImageView的background一样,跟随状态发生改变.只需要自定义一下字体颜色.在color文件夹下面,新建一个颜色文件的xml. OK ,这就完成 了. ...
- opencv之颜色过滤只留下图片中的红色区域
如图,这次需要在图片中找到卷尺的红色刻度,所以需要对图像做过滤,只留下红色部分. 一开始的想法是分别找到RGB值,然后找到红色区域的部分保留就可以了,不过好像很难确定红色区域的RGB取值范围,所以要把 ...
- opencv::基于颜色跟踪检测
基于颜色跟踪 inRange过滤 形态学操作提取 轮廓查找 外接矩形获取 位置标定
- OpenCV随机颜色,用于画图调试
static Scalar randomColor(int64 seed) { RNG rng(seed); int icolor = (unsigned)rng; return Scalar(ico ...
- opencv颜色识别代码分享
android 平台 opencv 实现颜色识别代码:http://www.eyesourcecode.com/thread-40682-1-1.htmlopencv的颜色识别简单实现的代码:http ...
- 【Windows 10 应用开发】跟随系统主题颜色
有些时候,希望应用程序中的某些颜色可以与系统的主题颜色相同,并且当系统主题色改变时进行同步. 实现过程并不复杂,主要用到 UISettings 类,它公开一个 GetColorValue 方法,访问这 ...
- OpenCV成长之路(3):模仿PhotoShop中魔术棒工具
本文的主题实际上是图像的颜色空间的转换,借助一个颜色选取程序来说明OpenCV中颜色转换函数的用法以及一些注意事项. 一.几种常见的颜色空间: RGB颜色空间:RGB采用加法混色法,因为它是描述各种“ ...
- 批量分割视频opencv
前言 视频处理过程中,会用到对等长的视频进行处理,此时要对大视频进行分割. 实现步骤 1.批量读取视频集: 2.视频分割: 测试代码 1.批量读取视频集: /********************* ...
随机推荐
- ionic 项目中ios上遇到的软键盘输入法自动弹出的问题
一. 安装插件 cordova plugin add ionic-plugin-keyboard 二. 软键盘显示监听 window.addEventListener('native.keyboar ...
- 程序员Web面试之前端框架等知识
基于前面2篇博客: 程序员Web面试之jQuery 程序员Web面试之JSON 您已经可以顺利进入Web开发的大门. 但是要动手干,还需要了解一些已有的前端框架.UI套件,即要站在巨人肩膀上而不是从轮 ...
- SoapUI SoapUI测试WebService协议接口简介
SoapUI测试WebService协议接口简介 by:授客 QQ:1033553122 1. 创建项目,入口:File -> New SOAP Project,或者右键默认项目Project- ...
- 自定义ScrollView 实现上拉下拉的回弹效果--并且子控件中有Viewpager的情况
onInterceptTouchEvent就是对子控件中Viewpager的处理:左右滑动应该让viewpager消费 public class MyScrollView extends Scroll ...
- JavaScript大杂烩5 - JavaScript对象的若干问题
1. 类型检查:instanceof与typeof 这是两个相似的操作符,instanceof用于检测函数的实例类型,主要是在面向对象编程中检查new出来的对象类型,需要注意instanceof是检查 ...
- 2.网络编程-udp
# 使用套接字发送udp数据import socket s = socket.socket(socket.AF_INET, SOCK_DGRAM) s.sendto(b"hello" ...
- 从零自学Java-10.充分利用现有对象
1.超类和子类的设计:2.建立继承层次:3.覆盖方法. 程序StringLister:使用数组列表和特殊的for循环将一系列字符串按字母顺序显示到屏幕上.这些字符串来自一个数组和命令行参数 packa ...
- python第一百零五天 ---Django 基础 路由系统 URL 模板语言 ORM 操作
一 路由系统 URL 1 url(r'^index/',views.index) url(r'^home/', views.Home.as_view()) 2 url(r'^detail-(\d+). ...
- 第五章 绘图基础(ALTWIND)
线上箭头表示画线的方向.WINDING模式和ALTERNATE模式都会填充三个封闭的L型区域,号码从1到3.两个更小的内部区域,号码为4和5,在ALTERNATE模式下不被填充.但是在WINDING模 ...
- WCF REST模式下的UriTemplate路径问题
问题:在WCF4.0中,用UriTemplate进行表明路径参数的时候会出现问题 1.创建的项目是Service.Interface[4.0]和Service[4.0]还有Client[4.0] 2. ...