首页 > 其他 > 详细

openFrameworks下的肤色检测源码

时间:2014-02-28 13:58:35      阅读:497      评论:0      收藏:0      [点我收藏+]

直接上源码:

void testApp::ofSkinDetector(unsigned char* Pointer, ofImage& image, int CAMERA_WIDTH, int CAMERA_HEIGHT)
{
	int len = CAMERA_WIDTH * CAMERA_HEIGHT * 3;
	unsigned char* SkinP= new unsigned char[len];

	for (int Y = 0; Y < CAMERA_HEIGHT; Y++)
	{
		for (int X = 0; X < CAMERA_WIDTH; X++)
		{
			unsigned char Red = Pointer[CAMERA_WIDTH * Y * 3 + X * 3];
			unsigned char Green = Pointer[CAMERA_WIDTH * Y * 3 + X * 3 + 1];
			unsigned char Blue = Pointer[CAMERA_WIDTH * Y * 3 + X * 3 + 2];
			unsigned char Max = 0, Min = 0;

			if (Red > 95 && Green > 40 && Blue > 20 && Red > Blue && Red > Green && abs(Red - Green) > 15)
			{
				if (Blue >= Green)     
				{
					Max = Blue;
					Min = Green;
				}
				else
				{
					Max = Green;
					Min = Blue;
				}
				if (Red > Max)
					Max = Red;
				else if (Red < Min)
					Min = Red;

				if (Max - Min > 15) 
				{
					SkinP[CAMERA_WIDTH * Y * 3 + X * 3] = 255;
					SkinP[CAMERA_WIDTH * Y * 3 + X * 3 + 1] = 255;
					SkinP[CAMERA_WIDTH * Y * 3 + X * 3 + 2] = 255;
				}
					
			}
		}
	}
	image.setFromPixels(SkinP, CAMERA_WIDTH, CAMERA_HEIGHT, OF_IMAGE_COLOR);

	delete SkinP;
	SkinP = NULL;
}

感谢这位博主的博文:参考博客链接,以上代码也是基于该博文进行的修改。

openFrameworks下的肤色检测源码,布布扣,bubuko.com

openFrameworks下的肤色检测源码

原文:http://blog.csdn.net/panda1234lee/article/details/20049517

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!