DDGScreenShot —圖片加高斯模糊,老電影效果

寫在前面

有了簡(jiǎn)單的圖片濾鏡基礎(chǔ)朴则,接下來(lái)就可以做一些難一點(diǎn)操作,圖片合成老電影的特效

整合成一個(gè)三方庫(kù)钓简,以下只是部分代碼乌妒,詳細(xì)代碼及demo請(qǐng)見(jiàn),github地址https://github.com/dudongge/DDGScreenShot

DDGScreenShot 所有功能演示

image
image

具體代碼

//這個(gè)是高斯模糊的代碼外邓,比較的簡(jiǎn)單
func gaussianBlurFilmEffect() {
        filter = CIFilter(name: "CIGaussianBlur")
        filter.setValue(10.0, forKey: "inputRadius")
        let inputImage = CIImage(image: originalImage)
        filter.setValue(inputImage, forKey: kCIInputImageKey)
        let outputImage =  filter.outputImage!
        let cgImage = context.createCGImage(outputImage, from: outputImage.extent)
        self.imageView.image = UIImage(cgImage: cgImage!)

    }
    

    

這個(gè)是合成老電影的過(guò)程)

中間有一些屏蔽的代碼是做輸出校驗(yàn)用的撤蚊,查看當(dāng)前的輸出

func oldFilmEffect(){
        let inputImage = CIImage(image: originalImage)!
        // 1.創(chuàng)建CISepiaTone濾鏡(棕綠色)
        let sepiaToneFilter = CIFilter(name: "CISepiaTone")!
        sepiaToneFilter.setValue(inputImage, forKey: kCIInputImageKey)
        //參數(shù)是強(qiáng)度
        sepiaToneFilter.setValue(1, forKey: kCIInputIntensityKey)
//        let outputImage = sepiaToneFilter.outputImage!
//        let cgImage = context.createCGImage(outputImage, from: outputImage.extent)
//        imageView.image = UIImage(cgImage: cgImage!)
        // 2.創(chuàng)建白班圖濾鏡
        let whiteSpecksFilter = CIFilter(name: "CIColorMatrix")!
        whiteSpecksFilter.setValue(CIFilter(name: "CIRandomGenerator")!.outputImage!.cropped(to: inputImage.extent), forKey: kCIInputImageKey)
        whiteSpecksFilter.setValue(CIVector(x: 0, y: 1, z: 0, w: 0), forKey: "inputRVector")
        whiteSpecksFilter.setValue(CIVector(x: 0, y: 1, z: 0, w: 0), forKey: "inputGVector")
        whiteSpecksFilter.setValue(CIVector(x: 0, y: 1, z: 0, w: 0), forKey: "inputBVector")
        whiteSpecksFilter.setValue(CIVector(x: 0, y: 0, z: 0, w: 0), forKey: "inputBiasVector")
//        let outputImage = whiteSpecksFilter.outputImage!
//        let cgImage = context.createCGImage(outputImage, from: outputImage.extent)
//        imageView.image = UIImage(cgImage: cgImage!)
        // 3.把CISepiaTone濾鏡和白班圖濾鏡以源覆蓋(source over)的方式先組合起來(lái)
        let sourceOverCompositingFilter = CIFilter(name: "CISourceOverCompositing")!
        sourceOverCompositingFilter.setValue(whiteSpecksFilter.outputImage, forKey: kCIInputBackgroundImageKey)
        sourceOverCompositingFilter.setValue(sepiaToneFilter.outputImage, forKey: kCIInputImageKey)
        // 4.用CIAffineTransform濾鏡先對(duì)隨機(jī)噪點(diǎn)圖進(jìn)行處理 應(yīng)用坐標(biāo)系
        let affineTransformFilter = CIFilter(name: "CIAffineTransform")!
        affineTransformFilter.setValue(CIFilter(name: "CIRandomGenerator")!.outputImage!.cropped(to: inputImage.extent), forKey: kCIInputImageKey)
        affineTransformFilter.setValue(NSValue(cgAffineTransform: CGAffineTransform(scaleX: 1.5, y: 25)), forKey: kCIInputTransformKey)
//        let outputImage = affineTransformFilter.outputImage!
//        let cgImage = context.createCGImage(outputImage, from: outputImage.extent)
//        imageView.image = UIImage(cgImage: cgImage!)
        // 5.創(chuàng)建藍(lán)綠色磨砂圖濾鏡
        let darkScratchesFilter = CIFilter(name: "CIColorMatrix")!
        darkScratchesFilter.setValue(affineTransformFilter.outputImage, forKey: kCIInputImageKey)
        darkScratchesFilter.setValue(CIVector(x: 4, y: 0, z: 0, w: 0), forKey: "inputRVector")
        darkScratchesFilter.setValue(CIVector(x: 0, y: 1, z: 0, w: 0), forKey: "inputGVector")
        darkScratchesFilter.setValue(CIVector(x: 0, y: 0, z: 0, w: 0), forKey: "inputBVector")
       darkScratchesFilter.setValue(CIVector(x: 0, y: 0, z: 0, w: 0), forKey: "inputAVector")
        darkScratchesFilter.setValue(CIVector(x: 0, y: 1, z: 1, w: 1), forKey: "inputBiasVector")
        // 6.用CIMinimumComponent濾鏡把藍(lán)綠色磨砂圖濾鏡處理成黑色磨砂圖濾鏡
        let minimumComponentFilter = CIFilter(name: "CIMinimumComponent")!
        minimumComponentFilter.setValue(darkScratchesFilter.outputImage, forKey: kCIInputImageKey)
        // 7.最終組合在一起
        let multiplyCompositingFilter = CIFilter(name: "CIMultiplyCompositing")!
        multiplyCompositingFilter.setValue(minimumComponentFilter.outputImage, forKey: kCIInputBackgroundImageKey)
        multiplyCompositingFilter.setValue(sourceOverCompositingFilter.outputImage, forKey: kCIInputImageKey)
        // 8.最后輸出
        let outputImage = multiplyCompositingFilter.outputImage!
        let cgImage = context.createCGImage(outputImage, from: outputImage.extent)
        imageView.image = UIImage(cgImage: cgImage!)
        
    }

結(jié)束語(yǔ)

看完這一節(jié),對(duì)高斯模糊损话,老電影高級(jí)用法有了更深的認(rèn)識(shí)侦啸,希望能夠幫助到你。
此代碼已經(jīng)上傳到githup[DDGScreenShot](https://github.com/dudongge/DDGScreenShot)
[link](https://github.com/dudongge/DDGScreenShot)
當(dāng)然這只是這個(gè)庫(kù)的功能的一小部分
想看更多功能席镀,可以去github上下載匹中,如果對(duì)您有幫助,希望您不吝給個(gè)star.

歡迎查看DDGScreenShot

其余功能如下

  1. (一)DDGScreenShot — 復(fù)雜屏幕截屏(如view ScrollView webView wkwebView)
  2. (二)DDGScreenShot--iOS 圖片處理--多圖片拼接
  3. (三)DDGScreenShot--iOS 圖片裁剪豪诲,切圓角顶捷,加邊框,你還用cornerRadius屎篱,還有更高級(jí)的用法
  4. (四)DDGScreenShot—圖片擦除功能
  5. (五)DDGScreenShot—截取圖片的任意部分
  6. (六)DDGScreenShot —圖片加各種濾鏡高逼格操作
  7. (七)DDGScreenShot —圖片加高斯模糊服赎,老電影效果
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市交播,隨后出現(xiàn)的幾起案子重虑,更是在濱河造成了極大的恐慌,老刑警劉巖秦士,帶你破解...
    沈念sama閱讀 221,198評(píng)論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缺厉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡隧土,警方通過(guò)查閱死者的電腦和手機(jī)提针,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)曹傀,“玉大人辐脖,你說(shuō)我怎么就攤上這事〗杂洌” “怎么了嗜价?”我有些...
    開封第一講書人閱讀 167,643評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵艇抠,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我久锥,道長(zhǎng)家淤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評(píng)論 1 296
  • 正文 為了忘掉前任瑟由,我火速辦了婚禮媒鼓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘错妖。我一直安慰自己绿鸣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評(píng)論 6 397
  • 文/花漫 我一把揭開白布暂氯。 她就那樣靜靜地躺著潮模,像睡著了一般。 火紅的嫁衣襯著肌膚如雪痴施。 梳的紋絲不亂的頭發(fā)上擎厢,一...
    開封第一講書人閱讀 52,156評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音辣吃,去河邊找鬼动遭。 笑死,一個(gè)胖子當(dāng)著我的面吹牛神得,可吹牛的內(nèi)容都是我干的厘惦。 我是一名探鬼主播,決...
    沈念sama閱讀 40,743評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼哩簿,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼宵蕉!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起节榜,我...
    開封第一講書人閱讀 39,659評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤羡玛,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后宗苍,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體稼稿,經(jīng)...
    沈念sama閱讀 46,200評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評(píng)論 3 340
  • 正文 我和宋清朗相戀三年讳窟,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了让歼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,424評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡挪钓,死狀恐怖是越,靈堂內(nèi)的尸體忽然破棺而出耳舅,到底是詐尸還是另有隱情碌上,我是刑警寧澤倚评,帶...
    沈念sama閱讀 36,107評(píng)論 5 349
  • 正文 年R本政府宣布,位于F島的核電站馏予,受9級(jí)特大地震影響天梧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜霞丧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評(píng)論 3 333
  • 文/蒙蒙 一呢岗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蛹尝,春花似錦后豫、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至愕难,卻和暖如春早龟,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背猫缭。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工葱弟, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人猜丹。 一個(gè)月前我還...
    沈念sama閱讀 48,798評(píng)論 3 376
  • 正文 我出身青樓芝加,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親射窒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子妖混,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評(píng)論 2 359

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