iOS 基于GPUImage框架搭建人臉識別,自帶濾鏡美顏,掃描區域設置等功能

上一篇寫了 基于AVFoundation框架進行人臉識別
本編編寫基于第三方 GPUImage框架 進行識別,帶濾鏡美顏,掃描區域設置、獲取識別到的人臉等功能!

下面給出基于GPUImage框架搭建人臉檢測功能代碼:
一、導入相關頭文件、設置相關代理和屬性
#import "GPUFaceViewController.h"
#import "GPUImage.h"
#import "GPUImageBeautifyFilter.h"

#define WS(weakSelf) __weak __typeof(&*self) weakSelf = self
#define kWidth [UIScreen mainScreen].bounds.size.width
#define kHeight [UIScreen mainScreen].bounds.size.height

@interface GPUFaceViewController ()<GPUImageVideoCameraDelegate,AVCaptureMetadataOutputObjectsDelegate,AVCaptureVideoDataOutputSampleBufferDelegate>
@property (nonatomic, strong) GPUImageVideoCamera *videoCamera;
@property (nonatomic, strong) GPUImageStillCamera *Camera;
@property (nonatomic, strong) GPUImageView *filterView;
@property (nonatomic, strong) UIButton *beautifyButton;
@property (strong, nonatomic) AVCaptureMetadataOutput *medaDataOutput;
@property (strong, nonatomic) dispatch_queue_t captureQueue;
@property (nonatomic, strong) AVCapturePhotoOutput *iOutput;

@property (nonatomic, strong) NSArray *faceObjects;
@property (nonatomic,strong)UIImageView *imageView;
@property(nonatomic,assign)BOOL isFirst;
@property(nonatomic,strong)UIView *roundView;
@property(nonatomic,strong)UIImageView *faceImgView;
@property(nonatomic,strong)NSData *imageData;
@property (nonatomic, strong) UIView *maskView;

@end

二、界面初始化
 - (void)viewDidLoad {
   [super viewDidLoad];
  // self.view.backgroundColor = [UIColor whiteColor];
   self.title = @"人臉識別";
   _isFirst = YES;
   
   [self faceDeviceInit];
   [self initUI];
}

-(void)initUI{
   _faceImgView = [[UIImageView alloc] initWithFrame:CGRectMake(kWidth - 120 , 64, 120, 120)];
   _faceImgView.backgroundColor = [UIColor blueColor];
   [self.view addSubview:_faceImgView];
   
   
   UILabel *titleLab = [[UILabel alloc] initWithFrame:CGRectMake(52, 100, kWidth - 108, 18)];
   titleLab.text = @"請對準臉部拍攝  提高認證成功率";
   titleLab.textAlignment = NSTextAlignmentCenter;
   titleLab.textColor = [UIColor redColor];
   titleLab.font = [UIFont systemFontOfSize:17];
   [self.view addSubview:titleLab];
}
三、相機設備初始化
//攝像頭相關設置
-(void)faceDeviceInit{
  self.captureQueue = dispatch_queue_create("com.kimsungwhee.mosaiccamera.videoqueue", NULL);
  
  self.videoCamera = [[GPUImageVideoCamera alloc] initWithSessionPreset:AVCaptureSessionPreset1920x1080 cameraPosition:AVCaptureDevicePositionBack];
  self.videoCamera.delegate = self;
  
  self.videoCamera.videoCaptureConnection.videoOrientation = AVCaptureVideoOrientationPortrait;
  
  self.filterView = [[GPUImageView alloc] initWithFrame:CGRectMake(0, 64, kWidth, kHeight-64)];
  self.filterView.backgroundColor = [UIColor clearColor];
  self.filterView.fillMode = kGPUImageFillModePreserveAspectRatioAndFill;
  [self.view addSubview:self.filterView];
  
  [self.videoCamera startCameraCapture];
  
  //美顏
  [self beautify];
  
  //Meta data
  dispatch_async(dispatch_get_main_queue(), ^{
      self.medaDataOutput = [[AVCaptureMetadataOutput alloc] init];
      if ([self.videoCamera.captureSession canAddOutput:self.medaDataOutput]) {
          [self.videoCamera.captureSession addOutput:self.medaDataOutput];
          //類型設置為人臉
          self.medaDataOutput.metadataObjectTypes = @[AVMetadataObjectTypeFace];
          [self.medaDataOutput setMetadataObjectsDelegate:self queue:self.captureQueue];
      }
  });

  //設置有效掃描區域
  [self setScanArea];
  
}
四、設置有效掃描區域
-(void)setScanArea{
    
    _maskView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, kWidth, kHeight)];
    
    _maskView.backgroundColor = [UIColor colorWithRed:0 green:0 blue:0 alpha:0.5];
    
    [self.view addSubview:_maskView];
    
    UIBezierPath *maskPath = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, kWidth, kHeight)];
    
    [maskPath appendPath:[[UIBezierPath bezierPathWithRoundedRect:CGRectMake(73, 206, kWidth - 142, kWidth - 142) cornerRadius:(kWidth - 142)/2.0] bezierPathByReversingPath]];
    
    CAShapeLayer *maskLayer = [[CAShapeLayer alloc] init];
    
    maskLayer.path = maskPath.CGPath;
    
    _maskView.layer.mask = maskLayer;
    
}
五、濾鏡美顏
- (void)beautify {
    [self.videoCamera removeAllTargets];
    GPUImageBeautifyFilter *beautifyFilter = [[GPUImageBeautifyFilter alloc] init];
    [self.videoCamera addTarget:beautifyFilter];
    [beautifyFilter addTarget:self.filterView];
}
六、顯示截取到的圖片,請求人臉識別接口
-(void)uploadFaceImg:(UIImage *)image{
    _faceImgView.image = image;
   
    NSLog(@"imageData:%@",self.imageData);
    WS(weakSelf);
    //這里設置為2秒后可以進行繼續檢測
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        weakSelf.isFirst = YES;
    });
   //這里開始寫請求接口的代碼
    
}
七、GPUImage代理方法

//GPUImage代理方法
- (void)willOutputSampleBuffer:(CMSampleBufferRef)sampleBuffer {
    WS(weakSelf);
    //檢測到人臉
    if (self.faceObjects && self.faceObjects.count > 0) {
        NSLog(@"self.faceObjects.count == %ld",self.faceObjects.count);
       //這個布爾值用于判斷檢測到人臉后,獲取到人臉照片,不用再進行持續檢測
        if (_isFirst) {
             //因為剛開始掃描到的人臉是模糊照片,所以延遲幾秒獲取
            dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
                //該view用來獲取截取人臉的Frame
                UIView *view = [[UIView alloc] initWithFrame:CGRectMake(73, 146, kWidth - 142, kWidth - 142)];
                [self.view addSubview:view];
                
                //截取屏幕
                UIGraphicsBeginImageContext(weakSelf.filterView.bounds.size);
                [weakSelf.filterView drawViewHierarchyInRect:weakSelf.filterView.bounds afterScreenUpdates:YES];;//截取動態圖形
                [weakSelf.filterView.layer renderInContext:UIGraphicsGetCurrentContext()];
                UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
                UIGraphicsEndImageContext();
                
                //截取屏幕中的人臉
                UIImage *faceImage = [UIImage imageWithCGImage:CGImageCreateWithImageInRect(newImage.CGImage, view.frame)];
                //  UIImageWriteToSavedPhotosAlbum(firstImage, self, nil, nil); //將圖片保存到相冊
                //轉換人臉圖片為NSData類型
                weakSelf.imageData = UIImageJPEGRepresentation(faceImage, 0.05);
                //獲取人臉圖片后,請求人臉識別接口
                [self uploadFaceImg:faceImage];
            });
            _isFirst = NO;
            
        }
    }else {
        //無人臉
      // 這里可以寫未獲取到人臉的操作
    }
}
八、實現 AVCaptureMetadataOutput代理
//AVCaptureMetadataOutputObjectsDelegate ===== 拿出當前幀的圖片進行人臉識別
- (void)captureOutput:(AVCaptureOutput *)captureOutput didOutputMetadataObjects:(NSArray *)metadataObjects fromConnection:(AVCaptureConnection *)connection {
    self.faceObjects = metadataObjects;
    

結語:

以上就是基于GPUImage框架編寫人臉識別功能代碼, 如有問題請下方留言指正!
如有幫助請??支持一下 ??
Demo地址: https://github.com/zhwIdea/GPUFaceDetect
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,663評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,125評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,506評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,614評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,402評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,934評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,021評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,168評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,690評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,596評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,784評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,288評論 5 357
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,027評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,404評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,662評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,398評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,743評論 2 370