美顏濾鏡

GPUImage

  • GPUImage:是一個(gè)基于OpenGL ES 2.0圖像和視頻處理的開源iOS框架簸呈,提供各種各樣的圖像處理濾鏡牵敷,并且支持照相機(jī)和攝像機(jī)的實(shí)時(shí)濾鏡虽界,內(nèi)置120多種濾鏡效果炫加,并且能夠自定義圖像濾鏡窟哺。
    濾鏡處理的原理:就是把靜態(tài)圖片或者視頻的每一幀進(jìn)行圖形變換再顯示出來泻轰。它的本質(zhì)就是像素點(diǎn)的坐標(biāo)和顏色變化

GPUImage處理畫面原理

  • GPUImage采用鏈?zhǔn)椒绞絹硖幚懋嬅?通過addTarget:方法為鏈條添加每個(gè)環(huán)節(jié)的對(duì)象,處理完一個(gè)target,就會(huì)把上一個(gè)環(huán)節(jié)處理好的圖像數(shù)據(jù)傳遞下一個(gè)target去處理且轨,稱為GPUImage處理鏈浮声。
    • 一般的target可分為兩類
      • 中間環(huán)節(jié)的target, 一般是各種filter, 是GPUImageFilter或者是子類.
      • 最終環(huán)節(jié)的target, GPUImageView:用于顯示到屏幕上, 或者GPUImageMovieWriter:寫成視頻文件。
  • GPUImage處理主要分為3個(gè)環(huán)節(jié)
    • source(視頻旋奢、圖片源) -> filter(濾鏡) -> final target (處理后視頻泳挥、圖片)
    • GPUImaged的Source:都繼承GPUImageOutput的子類,作為GPUImage的數(shù)據(jù)源,就好比外界的光線至朗,作為眼睛的輸出源
    • GPUImageVideoCamera:用于實(shí)時(shí)拍攝視頻
    • GPUImageStillCamera:用于實(shí)時(shí)拍攝照片
    • GPUImagePicture:用于處理已經(jīng)拍攝好的圖片屉符,比如png,jpg圖片
    • GPUImageMovie:用于處理已經(jīng)拍攝好的視頻,比如mp4文件
  • GPUImage的filter:GPUimageFilter類或者子類,這個(gè)類繼承自 GPUImageOutput,并且遵守GPUImageInput協(xié)議锹引,這樣既能流進(jìn)矗钟,又能流出,就好比我們的墨鏡嫌变,光線通過墨鏡的處理吨艇,最終進(jìn)入我們眼睛
  • GPUImage的final target:GPUImageView,GPUImageMovieWriter就好比我們眼睛,最終輸入目標(biāo)初澎。

美顏原理

  • 磨皮(GPUImageBilateralFilter):本質(zhì)就是讓像素點(diǎn)模糊秸应,可以使用高斯模糊虑凛,但是可能導(dǎo)致邊緣會(huì)不清晰,用雙邊濾波(Bilateral Filter) 软啼,有針對(duì)性的模糊像素點(diǎn)桑谍,能保證邊緣不被模糊。
  • 美白(GPUImageBrightnessFilter):本質(zhì)就是提高亮度祸挪。

GPUImage實(shí)戰(zhàn)

GPUImage原生美顏

  • 步驟一:使用Cocoapods導(dǎo)入GPUImage

  • 步驟二:創(chuàng)建視頻源GPUImageVideoCamera

  • 步驟三:創(chuàng)建最終目的源:GPUImageView

  • 步驟四:創(chuàng)建濾鏡組(GPUImageFilterGroup)锣披,需要組合亮度(GPUImageBrightnessFilter)和雙邊濾波(GPUImageBilateralFilter)這兩個(gè)濾鏡達(dá)到美顏效果.

  • 步驟五:設(shè)置濾鏡組鏈

  • 步驟六:設(shè)置GPUImage處理鏈,從數(shù)據(jù)源 => 濾鏡 => 最終界面效果

  • 步驟七:開始采集視頻
    注意點(diǎn):

  • SessionPreset最好使用AVCaptureSessionPresetHigh贿条,會(huì)自動(dòng)識(shí)別雹仿,如果用太高分辨率,當(dāng)前設(shè)備不支持會(huì)直接報(bào)錯(cuò)

  • GPUImageVideoCamera必須要強(qiáng)引用整以,否則會(huì)被銷毀胧辽,不能持續(xù)采集視頻.
    必須調(diào)用startCameraCapture,底層才會(huì)把采集到的視頻源公黑,渲染到GPUImageView中邑商,就能顯示了。

  • GPUImageBilateralFilter的distanceNormalizationFactor值越小凡蚜,磨皮效果越- 好,distanceNormalizationFactor取值范圍: 大于1人断。

- (void)viewDidLoad {
    [super viewDidLoad];
    
    // 創(chuàng)建視頻源
    // SessionPreset:屏幕分辨率,AVCaptureSessionPresetHigh會(huì)自適應(yīng)高分辨率
    // cameraPosition:攝像頭方向
    GPUImageVideoCamera *videoCamera = [[GPUImageVideoCamera alloc] initWithSessionPreset:AVCaptureSessionPresetHigh cameraPosition:AVCaptureDevicePositionFront];
     videoCamera.outputImageOrientation = UIInterfaceOrientationPortrait;
    _videoCamera = videoCamera;

    // 創(chuàng)建最終預(yù)覽View
    GPUImageView *captureVideoPreview = [[GPUImageView alloc] initWithFrame:self.view.bounds];
    [self.view insertSubview:captureVideoPreview atIndex:0];
    
    // 創(chuàng)建濾鏡:磨皮朝蜘,美白恶迈,組合濾鏡
    GPUImageFilterGroup *groupFilter = [[GPUImageFilterGroup alloc] init];
    
    // 磨皮濾鏡
    GPUImageBilateralFilter *bilateralFilter = [[GPUImageBilateralFilter alloc] init];
    [groupFilter addTarget:bilateralFilter];
    _bilateralFilter = bilateralFilter;
    
    // 美白濾鏡
    GPUImageBrightnessFilter *brightnessFilter = [[GPUImageBrightnessFilter alloc] init];
    [groupFilter addTarget:brightnessFilter];
    _brightnessFilter = brightnessFilter;
    
    // 設(shè)置濾鏡組鏈
    [bilateralFilter addTarget:brightnessFilter];
    [groupFilter setInitialFilters:@[bilateralFilter]];
    groupFilter.terminalFilter = brightnessFilter;
    
    // 設(shè)置GPUImage響應(yīng)鏈,從數(shù)據(jù)源 => 濾鏡 => 最終界面效果
    [videoCamera addTarget:groupFilter];
    [groupFilter addTarget:captureVideoPreview];
    
    // 必須調(diào)用startCameraCapture谱醇,底層才會(huì)把采集到的視頻源暇仲,渲染到GPUImageView中,就能顯示了枣抱。
    // 開始采集視頻
    [videoCamera startCameraCapture];
}

- (IBAction)brightnessFilter:(UISlider *)sender {
    _brightnessFilter.brightness = sender.value;
}

- (IBAction)bilateralFilter:(UISlider *)sender {
    // 值越小熔吗,磨皮效果越好
    CGFloat maxValue = 10;
    [_bilateralFilter setDistanceNormalizationFactor:(maxValue - sender.value)];
}

利用美顏濾鏡實(shí)現(xiàn)

  • 步驟一:使用Cocoapods導(dǎo)入GPUImage

  • 步驟二:導(dǎo)入GPUImageBeautifyFilter文件夾

  • 步驟三:創(chuàng)建視頻源GPUImageVideoCamera

  • 步驟四:創(chuàng)建最終目的源:GPUImageView

  • 步驟五:創(chuàng)建最終美顏濾鏡:GPUImageBeautifyFilter

  • 步驟六:設(shè)置GPUImage處理鏈,從數(shù)據(jù)源 => 濾鏡 => 最終界面效果
    注意:

  • 切換美顏效果原理:移除之前所有處理鏈佳晶,重新設(shè)置處理鏈

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    // 創(chuàng)建視頻源
    // SessionPreset:屏幕分辨率桅狠,AVCaptureSessionPresetHigh會(huì)自適應(yīng)高分辨率
    // cameraPosition:攝像頭方向
    GPUImageVideoCamera *videoCamera = [[GPUImageVideoCamera alloc] initWithSessionPreset:AVCaptureSessionPresetHigh cameraPosition:AVCaptureDevicePositionFront];
    videoCamera.outputImageOrientation = UIInterfaceOrientationPortrait;
    _videoCamera = videoCamera;
    
    // 創(chuàng)建最終預(yù)覽View
    GPUImageView *captureVideoPreview = [[GPUImageView alloc] initWithFrame:self.view.bounds];
    [self.view insertSubview:captureVideoPreview atIndex:0];
    _captureVideoPreview = captureVideoPreview;
    
    // 設(shè)置處理鏈
    [_videoCamera addTarget:_captureVideoPreview];
    
    // 必須調(diào)用startCameraCapture,底層才會(huì)把采集到的視頻源轿秧,渲染到GPUImageView中中跌,就能顯示了。
    // 開始采集視頻
    [videoCamera startCameraCapture];

}

- (IBAction)openBeautifyFilter:(UISwitch *)sender {
    
    // 切換美顏效果原理:移除之前所有處理鏈菇篡,重新設(shè)置處理鏈
    if (sender.on) {
        
        // 移除之前所有處理鏈
        [_videoCamera removeAllTargets];
        
        // 創(chuàng)建美顏濾鏡
        GPUImageBeautifyFilter *beautifyFilter = [[GPUImageBeautifyFilter alloc] init];
        
        // 設(shè)置GPUImage處理鏈漩符,從數(shù)據(jù)源 => 濾鏡 => 最終界面效果
        [_videoCamera addTarget:beautifyFilter];
        [beautifyFilter addTarget:_captureVideoPreview];
        
    } else {
        
        // 移除之前所有處理鏈
        [_videoCamera removeAllTargets];
        [_videoCamera addTarget:_captureVideoPreview];
    }
    
    
}

GPUImage擴(kuò)展

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市驱还,隨后出現(xiàn)的幾起案子嗜暴,更是在濱河造成了極大的恐慌凸克,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闷沥,死亡現(xiàn)場(chǎng)離奇詭異萎战,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)舆逃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門蚂维,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人路狮,你說我怎么就攤上這事虫啥。” “怎么了奄妨?”我有些...
    開封第一講書人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵涂籽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我展蒂,道長(zhǎng)又活,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任锰悼,我火速辦了婚禮,結(jié)果婚禮上团赏,老公的妹妹穿的比我還像新娘箕般。我一直安慰自己,他們只是感情好舔清,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開白布丝里。 她就那樣靜靜地躺著,像睡著了一般体谒。 火紅的嫁衣襯著肌膚如雪杯聚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,268評(píng)論 1 309
  • 那天抒痒,我揣著相機(jī)與錄音幌绍,去河邊找鬼。 笑死故响,一個(gè)胖子當(dāng)著我的面吹牛傀广,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播彩届,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼伪冰,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了樟蠕?” 一聲冷哼從身側(cè)響起贮聂,我...
    開封第一講書人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤靠柑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后吓懈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體病往,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年骄瓣,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了停巷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡榕栏,死狀恐怖畔勤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情扒磁,我是刑警寧澤庆揪,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站妨托,受9級(jí)特大地震影響缸榛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜兰伤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一内颗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧敦腔,春花似錦均澳、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至判族,卻和暖如春躺盛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背形帮。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來泰國打工槽惫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沃缘。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓躯枢,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親槐臀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锄蹂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容