通過Core Image添加濾鏡

by : http://cocacola-ty.github.io

處理過程

  1. 讀取圖片

    1. 讀取UIImage類型圖片

    2. 將UIImage轉(zhuǎn)為NSData

    3. 根據(jù)NSData轉(zhuǎn)為CIImage

  2. 處理濾鏡

    1. 創(chuàng)建濾鏡轴踱。根據(jù)濾鏡名稱初始化一個濾鏡

    2. 設(shè)置濾鏡參數(shù)

    3. 設(shè)置濾鏡圖片輸入源事秀,即設(shè)置濾鏡的inputImage參數(shù)

  3. 處理進(jìn)行過濾鏡的圖片

    1. 獲取CIContext业踢,通過該對象將濾鏡的輸出圖像進(jìn)行處理

    2. 通過CIContext對象獲取濾鏡的輸出對象并將圖像轉(zhuǎn)換為CGImage

    3. 將CGImage轉(zhuǎn)換為UIImage

主要類

  • CIContext: Core Image處理上下文,圖像處理在該類完成

  • CIFilter:濾鏡類榄棵,定義各種濾鏡的屬性汹胃。各種濾鏡都屬于該類

  • CIImage:保存圖像數(shù)據(jù)

實(shí)例

        /******讀取圖片部分******/
    // 讀取圖片
    NSString *path = [[NSBundle mainBundle] pathForResource:@"2" ofType:@"jpg"];
    UIImage *image = [UIImage imageWithContentsOfFile:path];
    
    // 將UIImage轉(zhuǎn)CIImage
    NSData *data = UIImagePNGRepresentation(image);
    CIImage *inputImage = [CIImage imageWithData:data];
    

    /******處理濾鏡部分******/
    // 初始化進(jìn)行濾鏡的顏色
    CIColor *sepiaColor = [CIColor colorWithRed:0.76 green:0.65 blue:0.54];
    
    // 通過濾鏡名稱創(chuàng)建濾鏡 初始化濾鏡參數(shù)
    CIFilter *monochromeFilter = [CIFilter filterWithName:@"CIColorMonochrome" withInputParameters:@{@"inputColor":sepiaColor,@"inputIntensity":@1.0}];
    // 設(shè)置濾鏡的輸入圖像
    [monochromeFilter setValue:inputImage forKey:@"inputImage"];
    
    // 根據(jù)濾鏡名稱創(chuàng)建濾鏡 初始化濾鏡基本參數(shù)
    CIFilter *vinFilter = [CIFilter filterWithName:@"CIVignette" withInputParameters:@{@"inputRadius":@1.75,@"inputIntensity":@1.0}];
    // 以經(jīng)過上一個濾鏡處理的圖像作為本次濾鏡的輸入圖像
    [vinFilter setValue:monochromeFilter.outputImage forKey:@"inputImage"];
    
    // 獲取經(jīng)過兩次濾鏡的圖像
    CIImage *outputImage = vinFilter.outputImage;
    
    // 創(chuàng)建高斯模糊濾鏡
    CIFilter *blur = [CIFilter filterWithName:@"CIGaussianBlur" withInputParameters:@{@"inputRadius":@40}];
    [blur setValue:inputImage forKey:@"inputImage"];
    

    /******處理濾鏡之后圖片部分******/
    // 將CIImage轉(zhuǎn)換為CGImage 再轉(zhuǎn)為UIImage
    CIContext *context = [CIContext contextWithOptions:nil];
    struct CGImage *cgImage = [context createCGImage:blur.outputImage fromRect:inputImage.extent];
    
    UIImage *outputUIImage = [UIImage imageWithCGImage:cgImage];
    
    // 顯示處理后的圖片
    UIImageView *imgView = [[UIImageView alloc] init];
    imgView.frame = CGRectMake(40, 40, 200, 200);
    imgView.image = outputUIImage ;
    [self.view addSubview:imgView];

獲取可用的濾鏡列表

  // 所有可用的濾鏡
    NSLog(@"可用的濾鏡\n%@",[CIFilter filterNamesInCategory:kCICategoryBuiltIn])

獲取濾鏡的屬性

    // 濾鏡的屬性
    NSLog(@"%@",blurFilter.attributes)

// 輸出結(jié)果為:

{
    "CIAttributeFilterAvailable_Mac" = "10.4";
    "CIAttributeFilterAvailable_iOS" = 6;
    CIAttributeFilterCategories =     (
        CICategoryBlur,
        CICategoryStillImage,
        CICategoryVideo,
        CICategoryBuiltIn
    );
    CIAttributeFilterDisplayName = "Gaussian Blur";
    CIAttributeFilterName = CIGaussianBlur;
    CIAttributeReferenceDocumentation = "http://developer.apple.com/cgi-bin/apple_ref.cgi?apple_ref=//apple_ref/doc/filter/ci/CIGaussianBlur";
    inputImage =     {
        CIAttributeClass = CIImage;
        CIAttributeDescription = "The image to use as an input image. For filters that also use a background image, this is the foreground image.";
        CIAttributeDisplayName = Image;
        CIAttributeType = CIAttributeTypeImage;
    };
    inputRadius =     {
        CIAttributeClass = NSNumber;
        CIAttributeDefault = 10;
        CIAttributeDescription = "The radius determines how many pixels are used to create the blur. The larger the radius, the blurrier the result.";
        CIAttributeDisplayName = Radius;
        CIAttributeIdentity = 0;
        CIAttributeMin = 0;
        CIAttributeSliderMax = 100;
        CIAttributeSliderMin = 0;
        CIAttributeType = CIAttributeTypeScalar;
    };
}

inputXX即該濾鏡的輸入?yún)?shù)蜓洪。(當(dāng)前濾鏡中即inputRadius)

這樣,通過查詢?yōu)V鏡的attributes的inputXX數(shù)組我們可以得到濾鏡的輸入?yún)?shù)來設(shè)置濾鏡的顯示效果

詳細(xì)解釋輸入?yún)?shù)數(shù)組

  • CIAttributeClass -- 該屬性接收的類型

  • CIAttributeDefault -- 該屬性的默認(rèn)值

  • CIAttributeDescription -- 該屬性的描述

  • CIAttributeDisplayName -- 該屬性的名稱

  • CIAttributeIdentity -- 屬性標(biāo)識

  • CIAttributeMin -- 屬性最小值

  • CIAttributeSliderMax -- 屬性最大值

  • CIAttributeType -- 屬性類型

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末牢裳,一起剝皮案震驚了整個濱河市逢防,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蒲讯,老刑警劉巖忘朝,帶你破解...
    沈念sama閱讀 218,546評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異判帮,居然都是意外死亡局嘁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評論 3 395
  • 文/潘曉璐 我一進(jìn)店門晦墙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悦昵,“玉大人,你說我怎么就攤上這事晌畅〉福” “怎么了?”我有些...
    開封第一講書人閱讀 164,911評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長棋凳。 經(jīng)常有香客問我拦坠,道長,這世上最難降的妖魔是什么剩岳? 我笑而不...
    開封第一講書人閱讀 58,737評論 1 294
  • 正文 為了忘掉前任贞滨,我火速辦了婚禮,結(jié)果婚禮上拍棕,老公的妹妹穿的比我還像新娘晓铆。我一直安慰自己,他們只是感情好莫湘,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評論 6 392
  • 文/花漫 我一把揭開白布尤蒿。 她就那樣靜靜地躺著郑气,像睡著了一般幅垮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上尾组,一...
    開封第一講書人閱讀 51,598評論 1 305
  • 那天忙芒,我揣著相機(jī)與錄音,去河邊找鬼讳侨。 笑死呵萨,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的跨跨。 我是一名探鬼主播潮峦,決...
    沈念sama閱讀 40,338評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼勇婴!你這毒婦竟也來了忱嘹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,249評論 0 276
  • 序言:老撾萬榮一對情侶失蹤耕渴,失蹤者是張志新(化名)和其女友劉穎拘悦,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體橱脸,經(jīng)...
    沈念sama閱讀 45,696評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡础米,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了添诉。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屁桑。...
    茶點(diǎn)故事閱讀 40,013評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖栏赴,靈堂內(nèi)的尸體忽然破棺而出蘑斧,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,731評論 5 346
  • 正文 年R本政府宣布乌叶,位于F島的核電站盆偿,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏准浴。R本人自食惡果不足惜事扭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望乐横。 院中可真熱鬧求橄,春花似錦、人聲如沸葡公。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽催什。三九已至涵亏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蒲凶,已是汗流浹背气筋。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留旋圆,地道東北人宠默。 一個月前我還...
    沈念sama閱讀 48,203評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像灵巧,于是被迫代替她去往敵國和親搀矫。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評論 2 355

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

  • 許多UIView的子類刻肄,如一個UIButton或一個UILabel瓤球,它們知道怎么繪制自己。遲早肄方,你也將想要做一些自...
    shenzhenboy閱讀 1,642評論 2 8
  • 原鏈接:http://www.csdn.net/article/2015-02-13/2823961-core-i...
    hament閱讀 1,013評論 0 1
  • Core Image是一個強(qiáng)大的框架冰垄,它能夠讓你輕松地對圖像進(jìn)行過濾。你能夠通過修改圖像的飽和度权她、色調(diào)或曝光率來獲...
    木易林1閱讀 1,137評論 0 1
  • 前言 最近在研究 Core Image 自定義 Filter 相關(guān)內(nèi)容虹茶,重新學(xué)習(xí)了 Core Image,對 Co...
    泥孩兒0107閱讀 772評論 0 4
  • 生命在繁衍的時候既不希望下一代與其一模一樣隅要,也不希望與其完全不一樣蝴罪,而是要基于更強(qiáng)地適應(yīng)環(huán)境的能力。如果環(huán)境適宜步清,...
    光華同學(xué)閱讀 857評論 0 51