CoreImage是Cocoa Touch中一个强大的API,用处非常大.在开始之前,我们先要简单了解下CoreImage framework 组成.
coreImage 主要包含以下几个组成部分
1 定义部分:
CoreImage 和CoreImageDefines ,代表了CoreImage 这个框架和它的定义。
2 操作部分:
滤镜(CIFliter):CIFilter 产生一个CIImage。典型的,接受一到多的图片作为输入,经过一些过滤操作,产生指定输出的图片。
检测(CIDetector):CIDetector 检测处理图片的特性,如使用来检测图片中人脸的眼睛、嘴巴、等等。
特征(CIFeature):CIFeature 代表由 detector处理后产生的特征。
3 图像部分:
画布(CIContext):画布类可被用与处理Quartz 2D 或者 OpenGL。可以用它来关联CoreImage类。如滤镜、颜色等渲染处理。
颜色(CIColor): 图片的关联与画布、图片像素颜色的处理。
向量(CIVector): 图片的坐标向量等几何方法处理。
图片(CIImage): 代表一个图像,可代表关联后输出的图像。
好了,前期基础准备工作做好了,我么创建工程来实践.
先创建一个工程 我命名为人脸识别,简单的在storyboard 中拖一个UImageView 然后生成属性imageView
再往工程中导入一张图片,我导入的是女神贾静雯的,命名为01.jpg
然后我们添加一个方法 - (void)makefaceDetectWithImage:(UIImage *)image
#pragma mark - 识别人脸测试
- (void)makefaceDetectWithImage:(UIImage *)image {
//清除imageview的子控件
for (UIView *view in _imageView.subviews) {
[view removeFromSuperview];
}
// 图像识别能力:可以在CIDetectorAccuracyHigh(较强的处理能力)与CIDetectorAccuracyLow(较弱的处理能力)中选择,因为想让准确度高一些在这里选择CIDetectorAccuracyHigh
NSDictionary *opts = [NSDictionary dictionaryWithObject:
CIDetectorAccuracyHigh forKey:CIDetectorAccuracy];
// 将图像转换为CIImage
CIImage *faceImage = [CIImage imageWithCGImage:image.CGImage];
CIDetector *faceDetector=[CIDetector detectorOfType:CIDetectorTypeFace context:nil options:opts];
// 识别出人脸数组
NSArray *features = [faceDetector featuresInImage:faceImage];
// 得到图片的尺寸
CGSize inputImageSize = [faceImage extent].size;
//将image沿y轴对称
CGAffineTransform transform = CGAffineTransformScale(CGAffineTransformIdentity, 1, -1);
//将图片上移
transform = CGAffineTransformTranslate(transform, 0, -inputImageSize.height);
// 取出所有人脸
for (CIFaceFeature *faceFeature in features){
//获取人脸的frame
CGRect faceViewBounds = CGRectApplyAffineTransform(faceFeature.bounds, transform);
CGSize viewSize = _imageView.bounds.size;
CGFloat scale = MIN(viewSize.width / inputImageSize.width,
viewSize.height / inputImageSize.height);
CGFloat offsetX = (viewSize.width - inputImageSize.width * scale) / 2;
CGFloat offsetY = (viewSize.height - inputImageSize.height * scale) / 2;
// 缩放
CGAffineTransform scaleTransform = CGAffineTransformMakeScale(scale, scale);
// 修正
faceViewBounds = CGRectApplyAffineTransform(faceViewBounds,scaleTransform);
faceViewBounds.origin.x += offsetX;
faceViewBounds.origin.y += offsetY;
//描绘人脸区域
UIView* faceView = [[UIView alloc] initWithFrame:faceViewBounds];
faceView.layer.borderWidth = 1.2;
faceView.layer.borderColor = [[UIColor colorWithRed:220/255.0 green:62/255.0 blue:70/255.0 alpha:1] CGColor];
[_imageView addSubview:faceView];
// 判断是否有左眼位置
if(faceFeature.hasLeftEyePosition){
NSLog(@"---找到了左眼");
}
// 判断是否有右眼位置
if(faceFeature.hasRightEyePosition){
NSLog(@"找到了右眼");
}
// 判断是否有嘴位置
if(faceFeature.hasMouthPosition){
NSLog(@"找到了嘴巴");
}
}
}
然后再viewDidload 里面调用这个方法
看打印结果
2017-09-08 10:03:04.683 人脸识别[2132:66473] ---找到了左眼
2017-09-08 10:03:04.683 人脸识别[2132:66473] 找到了右眼
2017-09-08 10:03:04.683 人脸识别[2132:66473] 找到了嘴巴
效果图
这就是人脸识别的简单应用了 ,当然啦 网上还有很多封装好的第三方库可以使用,但是基本的原理还是要知道的.