iOS 視頻濾鏡(相冊視頻或實時拍攝)

昨天研究過GPUImage框架之后,今天自己嘗試著寫了一個簡單的給視頻添加濾鏡的 demo。

Simulator Screen Shot 2016年4月14日 下午5.02.38.png

demo總共分為兩部分,在錄制過程中直接添加濾鏡、給相冊中的視頻添加濾鏡。

Simulator Screen Shot 2016年4月14日 下午5.04.03.png

錄制過程中直接添加濾鏡,【好吧,界面很丑,沒有圖標,自己也懶得去找那些圖標來填充,直接用色塊來表示了】。界面右上角橘黃色按鈕是用來切換前后攝像頭的,中間空出是視頻預覽圖層,下邊一串紅色圓圈是可以選擇的濾鏡,通過選擇不同的濾鏡來實現不同的效果。最下邊是拍攝按鈕,選擇好濾鏡后點擊拍攝就 ok 了。

Simulator Screen Shot 2016年4月14日 下午5.07.25.png

給本地視頻(相冊)添加濾鏡,界面跟上一個差不多,沒什么好說的。

下邊上一段濾鏡的代碼

/**
 *  @author mmmmh, 16-04-14 17:04:34
 *
 *  返回一個數組,數組每一個元素是一個字典,字典里有濾鏡和對應的名字
 *
 *  @return  FileterArr
 */
+(NSArray *)creatFilterArray{
    NSMutableArray * arr = [NSMutableArray arrayWithCapacity:0];
    
//    GPUImageOutput<GPUImageInput> * Filter1 = [[GPUImageBrightnessFilter alloc] init];
//    [(GPUImageBrightnessFilter *)Filter1 setBrightness:0.5];
//    NSString * title1 = @"亮度";
//    NSDictionary * dic1 = [NSDictionary dictionaryWithObjectsAndKeys:Filter1,@"filter",title1,@"name", nil];
//    [arr addObject:dic1];
    
//    GPUImageOutput<GPUImageInput> * Filter2 = [[GPUImageExposureFilter alloc] init];
//    [(GPUImageExposureFilter *)Filter2 setExposure:5];
//    NSString * title2 = @"曝光";
//    NSDictionary * dic2 = [NSDictionary dictionaryWithObjectsAndKeys:Filter2,@"filter",title2,@"name", nil];
//    [arr addObject:dic2];
    
//    GPUImageOutput<GPUImageInput> * Filter3 = [[GPUImageContrastFilter alloc] init];
//    [(GPUImageContrastFilter *)Filter3 setContrast:1.5];
//    NSString * title3 = @"對比度";
//    NSDictionary * dic3 = [NSDictionary dictionaryWithObjectsAndKeys:Filter3,@"filter",title3,@"name", nil];
//    [arr addObject:dic3];
    
//    GPUImageOutput<GPUImageInput> * Filter4 = [[GPUImageSaturationFilter alloc] init];
//    [(GPUImageSaturationFilter *)Filter4 setSaturation:1.5];
//    NSString * title4 = @"飽和度";
//    NSDictionary * dic4 = [NSDictionary dictionaryWithObjectsAndKeys:Filter4,@"filter",title4,@"name", nil];
//    [arr addObject:dic4];
    
    //    GPUImageOutput<GPUImageInput> * Filter5 = [[GPUImageGammaFilter alloc] init];
    //    [(GPUImageGammaFilter *)Filter5 setGamma:1.5];
    //    NSString * title5 = @"伽馬線";
    //    NSDictionary * dic5 = [NSDictionary dictionaryWithObjectsAndKeys:Filter5,@"filter",title5,@"name", nil];
    
    GPUImageOutput<GPUImageInput> * Filter6 = [[GPUImageColorInvertFilter alloc] init];
    NSString * title6 = @"反色";
    NSDictionary * dic6 = [NSDictionary dictionaryWithObjectsAndKeys:Filter6,@"filter",title6,@"name", nil];
    [arr addObject:dic6];
    
    GPUImageOutput<GPUImageInput> * Filter7 = [[GPUImageSepiaFilter alloc] init];
    NSString * title7 = @"褐色懷舊";
    NSDictionary * dic7 = [NSDictionary dictionaryWithObjectsAndKeys:Filter7,@"filter",title7,@"name", nil];
    [arr addObject:dic7];
    
//    GPUImageOutput<GPUImageInput> * Filter8 = [[GPUImageGrayscaleFilter alloc] init];
//    NSString * title8 = @"灰度";
//    NSDictionary * dic8 = [NSDictionary dictionaryWithObjectsAndKeys:Filter8,@"filter",title8,@"name", nil];
//    [arr addObject:dic8];
    
    //    GPUImageOutput<GPUImageInput> * Filter9 = [[GPUImageHistogramGenerator alloc] init];
    //    NSString * title9 = @"色彩直方圖?";
    //    NSDictionary * dic9 = [NSDictionary dictionaryWithObjectsAndKeys:Filter9,@"filter",title9,@"name", nil];
    GPUImageOutput<GPUImageInput> * Filter10 = [[GPUImageRGBFilter alloc] init];
    NSString * title10 = @"RGB";
    [(GPUImageRGBFilter *)Filter10 setRed:0.8];
    [(GPUImageRGBFilter *)Filter10 setGreen:0.3];
    [(GPUImageRGBFilter *)Filter10 setBlue:0.5];
    NSDictionary * dic10 = [NSDictionary dictionaryWithObjectsAndKeys:Filter10,@"filter",title10,@"name", nil];
    [arr addObject:dic10];
    
    GPUImageOutput<GPUImageInput> * Filter11 = [[GPUImageMonochromeFilter alloc] init];
    [(GPUImageMonochromeFilter *)Filter11 setColorRed:0.3 green:0.5 blue:0.8];
    NSString * title11 = @"單色";
    NSDictionary * dic11 = [NSDictionary dictionaryWithObjectsAndKeys:Filter11,@"filter",title11,@"name", nil];
    [arr addObject:dic11];
    
//    GPUImageOutput<GPUImageInput> * Filter12 = [[GPUImageBoxBlurFilter alloc] init];
////    [(GPUImageMonochromeFilter *)Filter11 setColorRed:0.3 green:0.5 blue:0.8];
//    NSString * title12 = @"單色";
//    NSDictionary * dic12 = [NSDictionary dictionaryWithObjectsAndKeys:Filter12,@"filter",title12,@"name", nil];
//    [arr addObject:dic12];
    
//    GPUImageOutput<GPUImageInput> * Filter13 = [[GPUImageSobelEdgeDetectionFilter alloc] init];
////    [(GPUImageSobelEdgeDetectionFilter *)Filter13 ];
//    NSString * title13 = @"漫畫反色";
//    NSDictionary * dic13 = [NSDictionary dictionaryWithObjectsAndKeys:Filter13,@"filter",title13,@"name", nil];
//    [arr addObject:dic13];
    
//    GPUImageOutput<GPUImageInput> * Filter14 = [[GPUImageXYDerivativeFilter alloc] init];
//    //    [(GPUImageSobelEdgeDetectionFilter *)Filter13 ];
//    NSString * title14 = @"藍綠邊緣";
//    NSDictionary * dic14 = [NSDictionary dictionaryWithObjectsAndKeys:Filter14,@"filter",title14,@"name", nil];
//    [arr addObject:dic14];
    
    
    GPUImageOutput<GPUImageInput> * Filter15 = [[GPUImageSketchFilter alloc] init];
    //    [(GPUImageSobelEdgeDetectionFilter *)Filter13 ];
    NSString * title15 = @"素描";
    NSDictionary * dic15 = [NSDictionary dictionaryWithObjectsAndKeys:Filter15,@"filter",title15,@"name", nil];
    [arr addObject:dic15];
    
    GPUImageOutput<GPUImageInput> * Filter16 = [[GPUImageSmoothToonFilter alloc] init];
    //    [(GPUImageSobelEdgeDetectionFilter *)Filter13 ];
    NSString * title16 = @"卡通";
    NSDictionary * dic16 = [NSDictionary dictionaryWithObjectsAndKeys:Filter16,@"filter",title16,@"name", nil];
    [arr addObject:dic16];
    
    
    GPUImageOutput<GPUImageInput> * Filter17 = [[GPUImageColorPackingFilter alloc] init];
    //    [(GPUImageSobelEdgeDetectionFilter *)Filter13 ];
    NSString * title17 = @"監控";
    NSDictionary * dic17 = [NSDictionary dictionaryWithObjectsAndKeys:Filter17,@"filter",title17,@"name", nil];
    [arr addObject:dic17];
    
    
//    GPUImageOutput<GPUImageInput> * Filter18 = [[GPUImageVignetteFilter alloc] init];
//    //    [(GPUImageSobelEdgeDetectionFilter *)Filter13 ];
//    NSString * title18 = @"暈影";
//    NSDictionary * dic18 = [NSDictionary dictionaryWithObjectsAndKeys:Filter18,@"filter",title18,@"name", nil];
//    [arr addObject:dic18];
    
    
    GPUImageOutput<GPUImageInput> * Filter19 = [[GPUImageSwirlFilter alloc] init];
    [(GPUImageSwirlFilter *)Filter19 setRadius:1.0];
    [(GPUImageSwirlFilter*)Filter19 setAngle:0.3];
    NSString * title19 = @"漩渦";
    NSDictionary * dic19 = [NSDictionary dictionaryWithObjectsAndKeys:Filter19,@"filter",title19,@"name", nil];
    [arr addObject:dic19];
    
    GPUImageOutput<GPUImageInput> * Filter20 = [[GPUImageBulgeDistortionFilter alloc] init];
    [(GPUImageBulgeDistortionFilter *)Filter20 setRadius:0.5];//0-1
    [(GPUImageBulgeDistortionFilter*)Filter20 setScale:0.5];//-1.0----1.0
    NSString * title20 = @"魚眼";
    NSDictionary * dic20 = [NSDictionary dictionaryWithObjectsAndKeys:Filter20,@"filter",title20,@"name", nil];
    [arr addObject:dic20];
    
    
    GPUImageOutput<GPUImageInput> * Filter21 = [[GPUImagePinchDistortionFilter alloc] init];
//    [(GPUImagePinchDistortionFilter *)Filter21 setRadius:0.5];
//    [(GPUImagePinchDistortionFilter*)Filter21 setScale:0.5];
    NSString * title21 = @"凹面鏡";
    NSDictionary * dic21 = [NSDictionary dictionaryWithObjectsAndKeys:Filter21,@"filter",title21,@"name", nil];
    [arr addObject:dic21];
    
    
    GPUImageOutput<GPUImageInput> * Filter22 = [[GPUImageStretchDistortionFilter alloc] init];
    //    [(GPUImageStretchDistortionFilter *)Filter21 setRadius:0.5];
    //    [(GPUImageStretchDistortionFilter*)Filter21 setScale:0.5];
    NSString * title22 = @"凹面鏡";
    NSDictionary * dic22 = [NSDictionary dictionaryWithObjectsAndKeys:Filter22,@"filter",title22,@"name", nil];
    [arr addObject:dic22];
    
    
    GPUImageOutput<GPUImageInput> * Filter23 = [[GPUImageGlassSphereFilter alloc] init];
    NSString * title23 = @"水晶球";
    NSDictionary * dic23 = [NSDictionary dictionaryWithObjectsAndKeys:Filter23,@"filter",title23,@"name", nil];
    [arr addObject:dic23];

    
    GPUImageOutput<GPUImageInput> * Filter24 = [[GPUImageSphereRefractionFilter alloc] init];
    NSString * title24 = @"水晶球反";
    NSDictionary * dic24 = [NSDictionary dictionaryWithObjectsAndKeys:Filter24,@"filter",title24,@"name", nil];
    [arr addObject:dic24];
    
    
    GPUImageOutput<GPUImageInput> * Filter25 = [[GPUImageEmbossFilter alloc] init];
    NSString * title25 = @"浮雕";
    NSDictionary * dic25 = [NSDictionary dictionaryWithObjectsAndKeys:Filter25,@"filter",title25,@"name", nil];
    [arr addObject:dic25];
    

//    GPUImageFilterGroup * grop = [[GPUImageFilterGroup alloc] init];
//    GPUImageOutput<GPUImageInput> * Filter100 = [[GPUImageSwirlFilter alloc] init];
//    [(GPUImageSwirlFilter *)Filter100 setRadius:1.0];
//    [(GPUImageSwirlFilter*)Filter100 setAngle:0.3];
//    GPUImageOutput<GPUImageInput> * Filter200 = [[GPUImageGlassSphereFilter alloc] init];
//    [grop addFilter:Filter100];
//    [grop addFilter:Filter200];
//    NSString * title200 = @"grop";
//    NSDictionary * dic250 = [NSDictionary dictionaryWithObjectsAndKeys:grop,@"filter",title200,@"name", nil];
//    [arr addObject:dic250];
    return arr;
}

關于濾鏡的使用,如果有興趣的請自行下載查看,點擊下載demo

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

推薦閱讀更多精彩內容