OpenCV编程-肤色检测

2024-02-14 23:48
文章标签 opencv 检测 编程 肤色

本文主要是介绍OpenCV编程-肤色检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


    最近搞色彩认知计算,对于肤色检测也是兴趣使然。

     

     我们在处理图像时,首先考虑的就是去噪,但是去噪不仅是去掉噪声,也需要考虑光照对图像造成的噪声,所以如果硬件跟得上的话,可以引入颜色恒常性计算来去噪,之后开始正题吧。

     肤色检测说起来很简单,只要是色彩的空间分离,在这个过程中难免有误检,如果对目标能进行有监督的框定,再进行肤色检测,效果应该好很多。 

     接下来贴代码:

  
void SkinDetect(IplImage* src,IplImage* dst)   
{   // 创建图像头IplImage* hsv = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U, 3);//用于存图像的个中间变量,是用来分通道用的,分成hsv通道   IplImage* tmpH1 = cvCreateImage( cvGetSize(src), IPL_DEPTH_8U, 1);//通道的中间变量,用于肤色检测的中D间变量   IplImage* tmpS1 = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* tmpH2 = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* tmpS3 = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* tmpH3 = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* tmpS2 = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* H = cvCreateImage( cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* S = cvCreateImage( cvGetSize(src), IPL_DEPTH_8U, 1);   IplImage* V = cvCreateImage( cvGetSize(src), IPL_DEPTH_8U, 1);     IplImage* src_tmp1=cvCreateImage(cvGetSize(src),8,3);   // 高斯模糊 cvSmooth(src,src_tmp1,CV_GAUSSIAN,3,3); //高斯模糊   // hue色度saturation饱和度value纯度   cvCvtColor(src_tmp1, hsv, CV_BGR2HSV );//颜色转换 cvSplit(hsv,H,S,V,0);//分为3个通道   /*********************肤色检测部分·**************/  cvInRangeS(H,cvScalar(26.0,0.0,0,0),cvScalar(34.0,0.0,0,0),tmpH1);   cvInRangeS(S,cvScalar(43.0,0.0,0,0),cvScalar(255.0,0.0,0,0),tmpS1);   cvAnd(tmpH1,tmpS1,tmpH1,0);   // Red Hue with Low Saturation   // Hue 0 to 26 degree and Sat 20 to 90   cvInRangeS(H,cvScalar(11.0,0.0,0,0),cvScalar(25.0,0.0,0,0),tmpH2);    cvInRangeS(S,cvScalar(43.0,0.0,0,0),cvScalar(255.0,0.0,0,0),tmpS2);   cvAnd(tmpH2,tmpS2,tmpH2,0);   // Red Hue to Pink with Low Saturation   // Hue 340 to 360 degree and Sat 15 to 90   //    cvInRangeS(H,cvScalar(170.0,0.0,0,0),cvScalar(180.0,0.0,0,0),tmpH3);   //    cvInRangeS(S,cvScalar(15.0,0.0,0,0),cvScalar(90.,0.0,0,0),tmpS3);   //    cvAnd(tmpH3,tmpS3,tmpH3,0);   // Combine the Hue and Sat detections   //    cvOr(tmpH3,tmpH2,tmpH2,0);   cvOr(tmpH1,tmpH2,tmpH1,0);   cvCopy(tmpH1,dst);   int avg,white=0,black=0;CvScalar s;for(int i=0;i<dst->height;i++){for (int j = 0;j<dst->width;j++){s = cvGet2D(dst,i,j);if(s.val[0]==255)white++;elseblack++;}}printf("white = %dn",white);printf("black = %dn",black);cvReleaseImage(&hsv);   cvReleaseImage(&tmpH1);   cvReleaseImage(&tmpS1);   cvReleaseImage(&tmpH2);   cvReleaseImage(&tmpS2);   cvReleaseImage(&tmpH3);   cvReleaseImage(&tmpS3);   cvReleaseImage(&H);   cvReleaseImage(&S);   cvReleaseImage(&V);   cvReleaseImage(&src_tmp1);   
}   

测试图像:



得到的图像虽然不好,相信从代码里面能看到原因。




    

这篇关于OpenCV编程-肤色检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/709909

相关文章

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor