opencv2 3.2 类中实现提取蓝天颜色
来源:互联网 发布:windows防火墙怎么打开 编辑:程序博客网 时间:2024/05/12 19:47
#include<iostream>
#include<opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>
using namespace std;
using namespace cv;
class ColorDetector{
private:
int maxDist; //最小差距
Vec3b target ; //目标颜色
Mat result;
public:
ColorDetector():maxDist(100),target(0,0,0)
{
}
void setColorDistanceThreshold(int distance) //设置颜色差距的阈值
{
if(distance<0)
distance=0;
maxDist=distance;
}
int getColorDistanceThreshold() const //取得颜色差距的阈值
{
return maxDist;
}
void setTargetColor(uchar blue,uchar green,uchar red) //设置需要检测的颜色
{
target=Vec3b(blue,green,red);
}
void setTargetColor(Vec3b color)
{
target=color;
}
Vec3b getTargetColor() const
{
return target;
}
Mat process(const cv::Mat &image) ;
int getDistance(const Vec3b &color) ;
};
Mat ColorDetector::process(const cv::Mat &image)
{
result.create(image.rows,image.cols,CV_8U);
Mat_<Vec3b>::const_iterator it=image.begin<Vec3b>();
Mat_<Vec3b>::const_iterator itend=image.end<Vec3b>();
Mat_<uchar>::iterator itout=result.begin<uchar>();
for ( ; it!= itend; ++it, ++itout)
{
if (getDistance(*it)<maxDist)
{
*itout=255;
}
else
{
*itout=0;
}
}
return result;
}
int ColorDetector::getDistance(const Vec3b &color)
{
return abs(color[0]-target[0])+
abs(color[1]-target[1])+
abs(color[2]-target[2]);
}
void main()
{
ColorDetector cdetect;
Mat img=imread("C:\\Users\\Administrator\\Desktop\\工作\\testp\\boldt.jpg");
if(img.empty())
return;
cdetect.setTargetColor(230,190,130);
imshow("original",img);
imshow("result",cdetect.process(img));
waitKey(0);
}
1 0
- opencv2 3.2 类中实现提取蓝天颜色
- opencv2实现形态学骨架提取
- opencv2中MSER区域提取
- OpenCV2提取,设置某个特定点的颜色
- opencv2.4.3特征提取的实现表示方法
- 蓝天
- opencv2.4.3中surf代码分析----(-)特征点提取
- opencv2.4.3中surf代码分析----特征点提取
- RGB图像中特定颜色的提取
- opencv2用反投影实现标定颜色的识别
- opencv2在直方图反投影算法中使用颜色信息
- opencv2反投影算法中使用颜色信息
- OPENCV2 获取彩色图中单一颜色分量
- Opencv2中LUT函数操作(颜色空间缩减)
- 如何在OpenCV2.3中实现CvvImage
- 纯CSS3实现的蓝天白云效果
- OpenCV2.3.1特征点提取
- Palette的使用(提取一个Bitmap 中突出颜色)
- android shape的使用
- HDOL 2007数值统计
- Fragment详解(六):Fragment与Menu
- 本篇文章,主要收录本人工作时iOS开发中代码写法的一些奇妙技巧,会持续更新~
- DB2在操作系统用户下创建数据库schema
- opencv2 3.2 类中实现提取蓝天颜色
- RGCDQ(线段树+数论)
- DB2非自动提交与自动提交的写法
- Pyscada---CommandLine
- java类库
- js小数运算精度问题,js浮点数运算时出现精度问题
- SVN检出maven项目,目录结构不对,解决方法(更新)
- J.U.C体系结构(java.util.concurrent)
- HTML网页基本标签: