티스토리 뷰
코어 이미지는 이미지나 비디오에서
얼굴이나 얼굴의 특징을 탐지할 수 있는 기능을 제공한다.
안면 인식기 설정
코어 이미지에서 안면 인식기를 사용하려면 CIImage 객체가 필요하다.
UIImage *detectUIImage = [self.sourceImageView image];
CGImageRef detectCGImageRef = [detectUIImage CGImage];
CIImage *detectImage = [CIImage imageWithCGImage:detectCGImageRef];
NSDictionary *options = @{CIDetectorAccuracy : CIDetectorAccuracyHigh};
CIDetector *faceDetector = [CIDetector detectorOfType:CIDetectorTypeFace
context:nil
options:options];
NSArray *features = [faceDetector featuresInImage:detectImage];
안면 인식 기능은 CIDetector 가 제공하는데, 현재는 Face 이외에 아래 4가지가 있다.
CORE_IMAGE_EXPORT NSString* const CIDetectorTypeFace NS_AVAILABLE(10_7, 5_0);
CORE_IMAGE_EXPORT NSString* const CIDetectorTypeRectangle NS_AVAILABLE(10_10, 8_0);
CORE_IMAGE_EXPORT NSString* const CIDetectorTypeQRCode NS_AVAILABLE(10_10, 8_0);
CORE_IMAGE_EXPORT NSString* const CIDetectorTypeText NS_AVAILABLE(10_11, 9_0);
options 으로는 Accuracy 를 줄 수 있는데, 높을수록 시간이 오래 걸린다.
안면 특징 처리
NSArray *features = [faceDetector featuresInImage:detectImage];
에서 나온 features 들은 측정된 안면 개수만큼 나온다.
for (CIFaceFeature *face in features) {
CGRect faceRect = [self adjustCoordinateSpaceForMarker:face.bounds
andHeight:detectImage.extent.size.height];
UIView *faceMarker = [[UIView alloc] initWithFrame:faceRect];
faceMarker.layer.borderWidth = 2;
faceMarker.layer.borderColor = [[UIColor redColor] CGColor];
[self.sourceImageView addSubview:faceMarker];
if (face.hasLeftEyePosition) {
CGFloat leftEyeXPos = face.leftEyePosition.x - kEyeMarkerWidth/2;
CGFloat leftEyeYPos = face.leftEyePosition.y - kEyeMarkerWidth/2;
CGRect leftEyeRect =
CGRectMake(leftEyeXPos, leftEyeYPos, kEyeMarkerWidth, kEyeMarkerWidth);
CGRect flippedLeftEyeRect = [self adjustCoordinateSpaceForMarker:leftEyeRect
andHeight:self.sourceImageView.bounds.size.height];
UIView *leftEyeMarker = [[UIView alloc] initWithFrame:flippedLeftEyeRect];
leftEyeMarker.layer.borderWidth = 2;
leftEyeMarker.layer.borderColor = [[UIColor yellowColor] CGColor];
[self.sourceImageView addSubview:leftEyeMarker];
}
//hasRightEyePosition, hasMouthPosition 도 마찬가지..
face 의 크기는 측정해주지만, 눈의 크기는 측정해주지 않기 때문에 임의의 수로 rect 를 그리고 있다.
코어 이미지는 UIKit 과는 다른 좌표 시스템을 사용한다.
코어 이미지의 좌표 시스템에서는 수직 방향 (Y축) 이 뒤집혀 있다.
따라서 좌표값이 0인 위치는 이미지의 상단이 아니고 하단이다.
이를 보정해 주는 코드는 아래에 있다.
- (CGRect)adjustCoordinateSpaceForMarker:(CGRect)marker andHeight:(CGFloat)height {
CGAffineTransform scale = CGAffineTransformMakeScale(1, -1);
CGAffineTransform flip =
CGAffineTransformTranslate(scale, 0, -height);
CGRect flippedRect = CGRectApplyAffineTransform(marker, flip);
return flippedRect;
}
iOS 7 이상에서는 탐지한 얼굴이 미소짓고 있는지 (hasSmile),
눈을 깜박이고 있는지 (leftEyeClosed, rightEyeClosed) 도 가지고 있다.
'iOS 개발 > iOS' 카테고리의 다른 글
[iOS] 코드 사이닝 (프로비저닝 프로파일, 인증서) (2) | 2016.12.22 |
---|---|
[iOS] TextKit 의 사용 (탐지 및 글씨 제외영역 잡기) (0) | 2016.12.02 |
[iOS] CoreImage Filter (CIFilter) 사용하기 (0) | 2016.11.28 |
[iOS] UIImage 의 사용 (load, imageView, picker, resize, stretch) (0) | 2016.11.28 |
[iOS] UIImage, CIImage, CGImage 의 차이점 (0) | 2016.11.25 |
- Total
- Today
- Yesterday
- NSManagedObjectModel
- CGImage
- Swift 3
- AWS
- UIView
- thread
- 읽기 좋은 코드가 좋은 코드다
- docker
- NSManagedObject
- set
- ios
- string
- EffectiveObjectiveC
- Swift 3.0
- CIImage
- NSManagedObjectContext
- dictionary
- workerThread
- Arc
- Block
- Swift
- applicationWillResignActive
- delegate
- RunLoop
- Swift3
- optional
- coredata
- 꺼내먹어요
- Swfit
- HTTP
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |