IOS開發(fā)--使用lookup table為圖片添加濾鏡

在涉及到圖片的應用中庙楚,基本上都會加入圖片濾鏡的相關功能。

IOS自身也自帶了功能強大的濾鏡相關的API趴樱,具體希望了解的朋友可以查詢一下蘋果的文檔馒闷。

今天這里要介紹的是lookup table(顏色查找表),簡而言之就是通過將每一個原始的顏色進行轉換之后成為一個新的顏色叁征。

打一個比方纳账,比如原始顏色是紅色(r:255,g:0捺疼,b:0)疏虫,進行轉換后變?yōu)榫G色(r:0,g:255啤呼,b:0)卧秘,以后所有是紅色的地方都會被自動轉換為綠色。

而顏色查找表就是將所有的顏色進行一次(矩陣)轉換官扣,而很多的濾鏡功能就是提供了這么一個轉換的矩陣翅敌,在原始色彩的基礎上進行顏色的轉換。

Original Lookup Table

然而IOS自帶的圖像處理API中并沒有提供顏色查找表相關的內容醇锚。即使如此,善解人意的GPUImage的大大們給我們提供了一個相關的接口坯临,今天就來簡單的介紹一下用法焊唬。


1 圖片添加濾鏡效果


資源:一張圖片(隨意),photoshop

a)在photoshop中載入原始圖片

原始示例圖片


b)調整photoshop中的調整面板看靠,對圖像進行調整赶促,并達到滿意的效果。

在該調整面板對圖像進行調整


調整后的圖像


c)在達到滿意的效果之后挟炬,對original lookup table(原始顏色查找表)進行一次相同的調整操作

調整前


調整后


d)將調整后得到的lookup table另存為NewLookupTable.png


2 代碼中引用lookup table


GPUImage是一個相當出名的第三方圖像處理庫鸥滨,這里就不對這個庫進行介紹了嗦哆。

GPUImage中有一個專門針對lookup table進行處理的濾鏡函數(shù)GPUImageLookupFilter,使用這個函數(shù)就可以直接對圖片進行濾鏡添加操作了婿滓。


//originalImg是你希望添加濾鏡的原始圖片

- (UIImage *)applyFIlter:(UIImage *)originalImg {

UIImage *inputImage =originalImg;

UIImage *outputImage = nil;

GPUImagePicture *stillImageSource = [[GPUImagePicture alloc] initWithImage:inputImage];

//添加濾鏡

GPUImageLookupFilter *lookUpFilter = [[GPUImageLookupFilter alloc] init];

//導入之前保存的NewLookupTable.png文件

GPUImagePicture *lookupImg = [[GPUImagePicturealloc] initWithImage:[UIImageimageNamed: @“NewLookupTable.png”]];

[lookupImg addTarget:lookUpFilteratTextureLocation:1];

[stillImageSource addTarget:lookUpFilteratTextureLocation:0];

[lookUpFilter useNextFrameForImageCapture];

if([lookupImg processImageWithCompletionHandler:nil] && [stillImageSource processImageWithCompletionHandler:nil]) {

outputImage= [lookUpFilterimageFromCurrentFramebuffer];

}

return outputImage;

}

就這樣濾鏡就可以添加成功了老速,很簡單把,哈哈凸主。

對了哈橘券,GPUImage這個庫里面會有一張lookup table的圖片的,在GPUImageLookupFilter相關的文件夾內卿吐,大家可以找一找旁舰。


順便安利一下我最近上線的一款app:畫意


《畫意》效果圖
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市嗡官,隨后出現(xiàn)的幾起案子箭窜,更是在濱河造成了極大的恐慌,老刑警劉巖衍腥,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件磺樱,死亡現(xiàn)場離奇詭異,居然都是意外死亡紧阔,警方通過查閱死者的電腦和手機坊罢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來擅耽,“玉大人活孩,你說我怎么就攤上這事」猿穑” “怎么了憾儒?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長乃沙。 經常有香客問我起趾,道長,這世上最難降的妖魔是什么警儒? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任训裆,我火速辦了婚禮,結果婚禮上蜀铲,老公的妹妹穿的比我還像新娘边琉。我一直安慰自己,他們只是感情好记劝,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布变姨。 她就那樣靜靜地躺著,像睡著了一般厌丑。 火紅的嫁衣襯著肌膚如雪定欧。 梳的紋絲不亂的頭發(fā)上渔呵,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天,我揣著相機與錄音砍鸠,去河邊找鬼扩氢。 笑死,一個胖子當著我的面吹牛睦番,可吹牛的內容都是我干的类茂。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼托嚣,長吁一口氣:“原來是場噩夢啊……” “哼巩检!你這毒婦竟也來了?” 一聲冷哼從身側響起示启,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤兢哭,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后夫嗓,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體迟螺,經...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年舍咖,在試婚紗的時候發(fā)現(xiàn)自己被綠了矩父。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡排霉,死狀恐怖窍株,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情攻柠,我是刑警寧澤球订,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站瑰钮,受9級特大地震影響冒滩,放射性物質發(fā)生泄漏。R本人自食惡果不足惜浪谴,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一港柜、第九天 我趴在偏房一處隱蔽的房頂上張望并淋。 院中可真熱鬧笼呆,春花似錦庇忌、人聲如沸腮考。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽摘刑。三九已至蘸秘,卻和暖如春官卡,著一層夾襖步出監(jiān)牢的瞬間蝗茁,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工寻咒, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留哮翘,地道東北人。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓毛秘,卻偏偏與公主長得像饭寺,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子叫挟,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

推薦閱讀更多精彩內容