很多时候,我们需要对脸部位置进行提取以达到某种定位的需求。
这时候就需要对脸部进行分割处理。
脸部的分割算法有好多种,识别的算法更是一片浩洋。
本文只探讨初步的人脸分割,最简单也最常用的方法就是基于肤色的人脸分割,现记录于此。
算法思想:
1.从摄像头获取图像。
2.将图像转化到YCbCr空间。
3.对Cr分量进行OTSU阈值分割。
4.求取分割结果的轮廓,求取面积最大的轮廓。
5.填充最大轮廓得到脸部掩码图,根据掩码图得到人脸。
代码如下:
#include "cxcore.h"
#include "math.h"
#include <cmath>
#include <vector>
#include <stdio.h>
#include <string.h>
#include <sstream>
#include <time.h>
#include <iostream>
#include <cstring>
#include <cv.h>
#include <highgui.h>
#include <assert.h>
using namespace std;
using namespace cv;
void cvSkinOtsu(IplImage* src,IplImage* dst)
{
assert(dst->nChannels == 1 && src->nChannels == 3);