//函数功能:在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的肤色分割的更多相关文章

  1. Android上掌纹识别第一步:基于OpenCV的6种肤色分割 源码和效果图

    Android上掌纹识别第一步:基于OpenCV的6种肤色分割 源码和效果图 分类: OpenCV图像处理2013-02-21 21:35 6459人阅读 评论(8) 收藏 举报   原文链接  ht ...

  2. VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法]

    VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法] - tingya的专栏 - 博客频道 - CSDN.NET VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法] 分类 ...

  3. [UWP]分享一个基于HSV色轮的调色板应用

    1. 前言 上一篇文章介绍了HSV色轮,这次分享一个基于HSV色轮的调色板应用,应用地址:ColorfulBox - Microsoft Store 2. 功能 ColorfulBox是Adobe 色 ...

  4. 基于FPGA的肤色识别算法实现

    大家好,给大家介绍一下,这是基于FPGA的肤色识别算法实现. 我们今天这篇文章有两个内容一是实现基于FPGA的彩色图片转灰度实现,然后在这个基础上实现基于FPGA的肤色检测算法实现. 将彩色图像转化为 ...

  5. segMatch:基于3D点云分割的回环检测

    该论文的地址是:https://arxiv.org/pdf/1609.07720.pdf segmatch是一个提供车辆的回环检测的技术,使用提取和匹配分割的三维激光点云技术.分割的例子可以在下面的图 ...

  6. opencv基于PCA降维算法的人脸识别

    opencv基于PCA降维算法的人脸识别(att_faces) 一.数据提取与处理 # 导入所需模块 import matplotlib.pyplot as plt import numpy as n ...

  7. 基于HSV彩色空间与直方图信息的植物叶脉FFCM算法提取

    宣旭峰,王美丽,张建锋. 基于HSV彩色空间与直方图信息的植物叶脉FFCM算法提取[J/OL]. 计算机应用研究,2018,(08):1-7. (2017-07-21)[2017-10-09]. ht ...

  8. OpenCV 基于超像素分割的图像区域选取方法及源码

    本系列文章由 @yhl_leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/51386993 工程源码GitHub: ...

  9. 基于标记的分水岭分割算法/OpenCV中距离变换

    Opencv分水岭算法——watershed自动图像分割用法 OpenCV距离变换distanceTransform应用 图像分割作为图像识别的基础,在图像处理中占有重要地位,通常需要在进行图像分割算 ...

随机推荐

  1. SSH_框架整合2—查询显示

    4. 完成功能. (1)com.atguigu.ssh.actions包下新建EmployeeAction.java package com.atguigu.ssh.actions; import j ...

  2. DDD学习笔记二

    参考:感谢博主的分享... http://www.cnblogs.com/netfocus/archive/2012/02/12/2347938.html DDD ==> 领域驱动设计(Doma ...

  3. 【转】c# winform DataGridView导出数据到Excel中,可以导出当前页和全部数据

    准备工作就是可以分页的DataGridView,和两个按钮,一个用来导出当前页数据到Excel,一个用来导出全部数据到Excel 没有使用SaveFileDialog,但却可以弹出保存对话框来 先做导 ...

  4. 回到顶部缓动效果代码 --- tween动画函数库

    function animateGoTop() { var top = $(document).scrollTop(); var end = 0; var dur = 500; var t = 0; ...

  5. 黄聪:360浏览器如何使用插件实现解除网页禁用右键复制的限制(Enable Copy)

    使用Enable Copy插件即可. 插件下载:Enable-Copy_v1.15.rar

  6. HDU 1532 Drainage Ditches EK算法 flod算法

    题意:输入m n, m是边数,n是点数. 接下来m行: 起点,终点,容量.求以 1 为源点, n为汇点的最大流. #include<stdio.h> #include<string. ...

  7. MVC ViewData和ViewBag[转]

    转自:http://blog.csdn.net/a497785609/article/details/7854402#t0       视图数据可以通过ViewBag属性访问,它主要是为了从Contr ...

  8. JQ获取当前是第几个元素,以及直接选取第几个元素的方法

    一.获取当前是第几个元素的方法使用:$(this).index() 实例: $(function () { $('.menu li').mouseover(function () { alert($( ...

  9. 读取缓存模拟----FIFO

    本例是模拟缓存的存储和读取. 存储:使用一个Map来存放,key是文件名,值为缓存对象 读取:返回相应的key对应的缓存.(如果缓存被修改,就重新加载缓存,再从缓存Map中读取相应缓存) 测试类:每2 ...

  10. U盘安装Linux CentOS 6.5 64位操作系统(来自互联网)

    从centOS6.5开始直接把iso文件写入u盘就行了. 方法1:windows平台:1.用UltraISO打开iso(如:CentOS-6.5-x86_64-bin-DVD1.iso)2.然后点“启 ...