opencv基于HSV的肤色分割
//函数功能:在HSV颜色空间对图像进行肤色模型分割 //输入:src-待处理的图像,imgout-输出图像 //返回值:返回一个iplimgae指针,指向处理后的结果 IplImage* SkinSegmentHSV(IplImage* src,IplImage* imgout)
{
//定义一些中间指针,指向处理过程中的中间变量
IplImage* HSV = NULL;
IplImage* HImg= NULL;
IplImage* SImg= NULL;
IplImage* VImg= NULL;
//指向处理后的结果
IplImage* result = NULL;
if (!src||!imgout) { return NULL; }
//获取输入图像的大小
CvSize SrcSize = cvGetSize(src);
//为中间结果指针分配存储空间
HSV = cvCreateImage(SrcSize,8,3);
HImg= cvCreateImage(SrcSize,8,1);
SImg= cvCreateImage(SrcSize,8,1);
VImg= cvCreateImage(SrcSize,8,1);
result= cvCreateImage(cvGetSize(imgout),8,1);
//将图像从RGB颜色空间转换到HSV空间
cvCvtColor(src,HSV,CV_BGR2HSV);
//将HSV分解为三张单通道图像,便于后面就行处理
cvSplit(HSV,HImg,SImg,VImg,NULL);
int i,j; int value = 0;
//对通道H进行处理
for (i = 0; i < HImg->height; i++)
{
for (j = 0; j < HImg->width; j++)
{
value = cvGetReal2D(HImg,i,j);
if (value >=0 && value <= 25)
{ *(HImg->imageData+i*HImg->widthStep+j) = 255; }
else { *(HImg->imageData+i*HImg->widthStep+j) = 0; }
}
}
//对通道S进行处理
for (i = 0; i < SImg->height; i++) { for (j = 0; j < SImg->width; j++)
{ value = cvGetReal2D(SImg,i,j);
if (value >=26 && value <= 200)
{ *(SImg->imageData+i*SImg->widthStep+j) = 255; }
else { *(SImg->imageData+i*SImg->widthStep+j) = 0; }
}
}
//对通道V进行处理
for (i = 0; i < VImg->height; i++) {
for (j = 0; j < VImg->width; j++) {
value = cvGetReal2D(VImg,i,j);
if (value >=20 && value <= 200) { *(VImg->imageData+i*VImg->widthStep+j) = 255; }
else { *(VImg->imageData+i*VImg->widthStep+j) = 0; } } }
cvAnd(HImg,SImg,result,0);
cvAnd(VImg,result,result,0);
//对所得到的结果进行形态学腐蚀处理,去除小区域部分
cvErode(result,result); cvErode(result,result); cvErode(result,result); cvDilate(result,result);
//将处理后的结果赋值给输出图像
cvCopy(result,imgout);
//释放相关资源
cvReleaseImage(&src); cvReleaseImage(&HSV); cvReleaseImage(&HImg); cvReleaseImage(&SImg); cvReleaseImage(&VImg); cvReleaseImage(&result);
//返回处理后的结果
return imgout;
}
opencv基于HSV的肤色分割的更多相关文章
- Android上掌纹识别第一步:基于OpenCV的6种肤色分割 源码和效果图
Android上掌纹识别第一步:基于OpenCV的6种肤色分割 源码和效果图 分类: OpenCV图像处理2013-02-21 21:35 6459人阅读 评论(8) 收藏 举报 原文链接 ht ...
- VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法]
VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法] - tingya的专栏 - 博客频道 - CSDN.NET VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法] 分类 ...
- [UWP]分享一个基于HSV色轮的调色板应用
1. 前言 上一篇文章介绍了HSV色轮,这次分享一个基于HSV色轮的调色板应用,应用地址:ColorfulBox - Microsoft Store 2. 功能 ColorfulBox是Adobe 色 ...
- 基于FPGA的肤色识别算法实现
大家好,给大家介绍一下,这是基于FPGA的肤色识别算法实现. 我们今天这篇文章有两个内容一是实现基于FPGA的彩色图片转灰度实现,然后在这个基础上实现基于FPGA的肤色检测算法实现. 将彩色图像转化为 ...
- segMatch:基于3D点云分割的回环检测
该论文的地址是:https://arxiv.org/pdf/1609.07720.pdf segmatch是一个提供车辆的回环检测的技术,使用提取和匹配分割的三维激光点云技术.分割的例子可以在下面的图 ...
- opencv基于PCA降维算法的人脸识别
opencv基于PCA降维算法的人脸识别(att_faces) 一.数据提取与处理 # 导入所需模块 import matplotlib.pyplot as plt import numpy as n ...
- 基于HSV彩色空间与直方图信息的植物叶脉FFCM算法提取
宣旭峰,王美丽,张建锋. 基于HSV彩色空间与直方图信息的植物叶脉FFCM算法提取[J/OL]. 计算机应用研究,2018,(08):1-7. (2017-07-21)[2017-10-09]. ht ...
- OpenCV 基于超像素分割的图像区域选取方法及源码
本系列文章由 @yhl_leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/51386993 工程源码GitHub: ...
- 基于标记的分水岭分割算法/OpenCV中距离变换
Opencv分水岭算法——watershed自动图像分割用法 OpenCV距离变换distanceTransform应用 图像分割作为图像识别的基础,在图像处理中占有重要地位,通常需要在进行图像分割算 ...
随机推荐
- Ext JS treegrid 发生的在tree上增加itemclick 与在其它列上增加actioncolumn 发生事件冲突(event conflict)的解决办法
Ext JS treegrid 发生的在tree上增加itemclick 与在其它列上增加actioncolumn 发生事件冲突(event conflict)的解决办法 最近在适用Ext JS4开发 ...
- LintCode "Subarray Sum II"
Sliding window doesn't work. So it is a typical partial_sum base solution. As below. However if you ...
- WeX5和BeX5比较
http://wex5.com/cn/wex5和bex5比较/ WeX5和BeX5比较 许多对WeX5和BeX5略有了解得人都知道,WeX5和BeX5是完全共用前端框架技术的.但是WeX5和BeX5是 ...
- 解密:wp-includes/load.php
描述:定义加载 WP 所需要的函数.1)wp_unregister_GLOBALS(),关闭’GLOBALS’, ‘_GET’, ‘_POST’, ‘_COOKIE’, ‘_REQUEST’, ‘_S ...
- MySQL命名、设计及使用规范--------来自标点符的《MySQL命名、设计及使用规范》
原文地址:http://www.biaodianfu.com/mysql-best-practices.html 最近在看MySQL相关的内容,整理如下规范,作为一名刚刚学习MySQL的菜鸟,整理的内 ...
- nginx软负载的搭建
Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器,在高连接并发的情况下Nginx 是 Apa ...
- DBA_Oracle DBA常用表汇总(概念)
2014-06-20 Created By BaoXinjian
- psutil模块安装指南(win与linux)
1.windows下psutil模块安装: https://pypi.python.org/packages/3.4/p/psutil/ 下载符合版本的软件包下载,然后安装即可. 2.ubuntu下载 ...
- js让iframe高度自动
HTML: <iframe id="yb_if" width="940px" src="连接" frameborder=0 allow ...
- JAVA 什么时候使用静态
static所修饰的内容是成员(成员属性.成员方法) 从两方面入手:1.什么时候使用静态的成员属性:当属于同一个类的所有对象出现共享数据时,需要将存储这个共享数据的成员变量用static修饰 2.什么 ...