日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS8 Core Image In Swift:更复杂的滤镜

發布時間:2024/3/24 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS8 Core Image In Swift:更复杂的滤镜 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

iOS8 Core Image In Swift:自動改善圖像以及內置濾鏡的使用

iOS8 Core Image In Swift:更復雜的濾鏡

iOS8 Core Image In Swift:人臉檢測以及馬賽克

iOS8 Core Image In Swift:視頻實時濾鏡


上面那篇文章主要是Core Image的基礎,只是為了說明CIImage、CIFilter、CIContext,以及基礎濾鏡的簡單使用。在上一篇中幾乎沒有對濾鏡進行更復雜的操作,都是直接把inputImage扔給CIFilter而已,而Core Image實際上還能對濾鏡進行更加細粒度的控制,我們在新的工程中對其進行探索。為此,我重新建立了一個空的workspace,并把之前所使用的工程添加到這個workspace中,編譯、運行,沒問題的話我們就開始創建新的工程。

通過workspace左下角的Add Files to添加已有的工程文件(xx.xcodeproj):



當添加工程到workspace的時候,記得要把被添加的工程關掉,不然workspacce不能識別。
另外,在流程上這篇也會與上一篇不同,上一篇一開始我就給出了代碼,然后先看效果再步步為營,這篇不會在一開始給出代碼。



動態改變濾鏡參數的值

用Single View Application的工程模板建立一個新的工程,在View上放一個UIImageView,還是同樣的frame,同樣的ContentMode設置為Aspect Fit,同樣的關閉Auto Layout以及Size Classes,最后把上個工程中使用的圖片復制過來,在這個工程中同樣使用這張圖。

做完上面這些基礎工作后,我們回到VC中,把showFiltersInConsole方法從上個工程中復制過來,然后在viewDidLoad里調用,在運行之前我們先看看Core Image有哪些類別,畢竟全部的濾鏡有127種,不可能一一用到的。

類別有很多,而且我們從上一篇中知道了濾鏡可以同時屬于不同的類別,除此之外,類別還分為兩大類:

按效果分類:

  • kCICategoryDistortionEffect 扭曲效果,比如bump、旋轉、hole
  • kCICategoryGeometryAdjustment 幾何開著調整,比如仿射變換、平切、透視轉換
  • kCICategoryCompositeOperation 合并,比如源覆蓋(source over)、最小化、源在頂(source atop)、色彩混合模式
  • kCICategoryHalftoneEffect Halftone效果,比如screen、line screen、hatched
  • kCICategoryColorAdjustment 色彩調整,比如伽馬調整、白點調整、曝光
  • kCICategoryColorEffect 色彩效果,比如色調調整、posterize
  • kCICategoryTransition 圖像間轉換,比如dissolve、disintegrate with mask、swipe
  • kCICategoryTileEffect 瓦片效果,比如parallelogram、triangle
  • kCICategoryGenerator 圖像生成器,比如stripes、constant color、checkerboard
  • kCICategoryGradient 漸變,比如軸向漸變、仿射漸變、高斯漸變
  • kCICategoryStylize 風格化,比如像素化、水晶化
  • kCICategorySharpen 銳化、發光
  • kCICategoryBlur 模糊,比如高斯模糊、焦點模糊、運動模糊

按使用場景分類:

  • kCICategoryStillImage 能用于靜態圖像
  • kCICategoryVideo 能用于視頻
  • kCICategoryInterlaced 能用于交錯圖像
  • kCICategoryNonSquarePixels 能用于非矩形像素
  • kCICategoryHighDynamicRange 能用于HDR
這些專業詞太難翻譯了,有不準確的地方還望告知

此外還有我們之前用到的kCICategoryBuiltIn。 我們把kCICategoryColorAdjustment這個類別下的濾鏡打印出來看看:

有11個濾鏡,其中有一個CIHueAdjust,這個看名字應該是修改圖像色調的,效果應該會比較明顯,看看它有哪些參數:

它的詳細信息里除了我們之前了解的inputImage和所屬分類信息以外,多了個inputAngle,顯然這是一個輸入參數,而且這個參數也打印的非常清晰,其中包括了:
  • 參數類型:NSNumber
  • 默認值:0
  • kCIAttributeIdentity:雖然這個值大部分情況下與默認值是一樣的,但是它們的含義不一樣,kCIAttributeIdentity表示的含義是這個值被應用到參數上的時候,就表示被應用的參數不會對inputImage造成任何影響
  • 最大值:?
  • 最小值:-?
  • 屬性類型:角度
上面的這些參數以及取值對不同的CIFilter來說都不一樣,要具體情況具體分析。 了解了以上情況后,我們就可以開始編碼了。首先在VC里添加上個工程中的常用屬性:

class?ViewController:?UIViewController?{

? ??@IBOutlet?var?imageView:?UIImageView!

? ??@IBOutlet?var?slider:?UISlider!

? ??lazy?var?originalImage:?UIImage?= {

? ? ? ??return?UIImage(named:?"Image")

? ? }()

?? ?

? ??lazy?var?context:?CIContext?= {

? ? ? ??return?CIContext(options:?nil)

? ? }()

?? ?

? ??var?filter:?CIFilter!

......

與之前工程中不同的是,我多加了一個UISlider,Main.storyboard中VC的view像這樣:

把UIImageView及UISlider的連線與VC中的連接起來,然后我們在viewDidLoad方法里寫上:?

override?func?viewDidLoad() {

? ??super.viewDidLoad()

?? ?

? ??imageView.layer.shadowOpacity?=?0.8

? ??imageView.layer.shadowColor?=?UIColor.blackColor().CGColor

? ??imageView.layer.shadowOffset?=?CGSize(width:?1, height:?1)

?? ?

? ??slider.maximumValue?=?Float(M_PI)

? ??slider.minimumValue?=?Float(-M_PI)

? ??slider.value?=?0

? ??slider.addTarget(self, action:?"valueChanged", forControlEvents:?UIControlEvents.ValueChanged)


? ??let?inputImage =?CIImage(image:?originalImage)

? ??filter?=?CIFilter(name:?"CIHueAdjust")

? ??filter.setValue(inputImage, forKey:?kCIInputImageKey)

? ??slider.sendActionsForControlEvents(UIControlEvents.ValueChanged)

?? ?

? ??showFiltersInConsole()

}

imageView的設置同以前一樣,增加點陰影顯得好看多了。

接著對slider初始化,在之前我們了解到CIHueAdjust濾鏡的inputAngle參數最大值是?,最小值是負?,默認值是0,就用這些值來初始化,然后添加一個當值發生改變時觸發的事件。

初始化filter,由于只有一個濾鏡,filter對象也可以重用,設置完inputImage后,觸發slider的事件就可以了。

valueChanged方法實現:

@IBAction?func?valueChanged() {

? ??filter.setValue(slider.value, forKey:?kCIInputAngleKey)

? ??let?outputImage =?filter.outputImage

? ??let?cgImage =?context.createCGImage(outputImage, fromRect: outputImage.extent())

? ??imageView.image?=?UIImage(CGImage: cgImage)

}?

filter會在每次觸發這個事件的時候更新inputAngle屬性,同時輸出到imageView上。

雖然我并不是在Storyboard里把slider的valueChanged事件連接到VC的方法上,但是在這里使用@IBAction也是適當的,這樣可以表明這個方法不是業務邏輯方法,而是一個UI控件觸發的方法。

編譯、運行,應該可以看到效果了。




復合濾鏡--老電影效果

在此之前,無論是使用簡單濾鏡,還是能動態修改參數值的濾鏡,都不算復雜,因為我們最多也只是對一個濾鏡設置點參數而已。可是如果現有的濾鏡沒有想要的效果,或者說單個濾鏡實現不了自己想要的效果,就只能自己處理了,其中,最簡單的做法是把多個濾鏡組合起來。 Core Image并沒有內置類似于老電影的效果,就是那種影像有點發黃,同時還會帶點黑條、白條之類的,而我們如果要實現這種效果,總體上就像這樣:

大致過程如下:
  • 需要使用CISepiaTone濾鏡,CISepiaTone能使整體顏色偏棕褐色,又有點像復古
  • 需要創建隨機噪點圖,很像以前電視機沒信號時顯示的圖像,再通過它生成一張白斑圖濾鏡
  • 需要創建另一個隨機噪點圖,然后通過它生成一張黑色磨砂圖濾鏡,就像是一張使用過的黑色砂紙一樣
  • 把它們組合起來
在開始之前首先要知道一件事,我們已經知道了一些簡單的濾鏡,它們只需要設置inputImage就行了;還有一些除了inputImage參數外有其他參數的濾鏡,除此之外,還有一些濾鏡不需要任何參數,就是上面提到的隨機噪點圖,另外,有些Core Image濾鏡會生成無限大小的圖,比如CICategoryTileEffect類別下的濾鏡,在渲染它們生成的圖之前,必須先把這些無限大小的圖裁剪一番,你可以通過CICrop濾鏡來完成這一步,也可以通過在一個有限的矩形范圍之類渲染這張圖來達到同樣的效果。然后我們就動手吧。 在VC里添加一個IBAction方法:oldFilmEffect,然后在Storyboard的VC上增加一個按鈕,就叫“老電影”,然后連接到oldFilmEffect方法上,oldFilmEffect方法實現的代碼稍后給出,這里先描述下詳細步驟,其實通過這些詳細步驟,已經可以自己先實現出來了:

應用CISepiaTone濾鏡到原圖上

  • 設置inputImage為原圖
  • 設置inputIntensity為1.0

創建白斑圖濾鏡

用CIRandomGenerator生成隨機噪點濾鏡,然后通過imageByCroppingToRect方法對其進行裁剪,在imageByCroppingToRect方法內Core Image隱式的使用了CICrop濾鏡。 接下來使用CIColorMatrix濾鏡,該濾鏡可以很方便的調整圖片中RGBA各分量的值,其參數設置如下:
  • 設置inputImage為CIRandomGenerator生成的隨機噪點圖
  • 設置inputRVector、inputGVector和inputBVector為(0,1,0,0)
  • 設置inputBiasVector為(0,0,0,0)
CISourceOverCompositing(源覆蓋)濾鏡把前景圖(inputImage)覆蓋在背景圖(inputBackgroundImage)上:
  • 設置inputImage為CISepiaTone濾鏡生成的圖
  • 設置inputBackgroundImage為白斑圖濾鏡

創建黑色磨砂圖濾鏡

還是先用CIRandomGenerator生成隨機噪點圖,然后用CIAffineTransform濾鏡對其進行處理,其實就是把生成的點放大。參數設置如下:
  • 設置inputImage為CIRandomGenerator生成的隨機噪點圖
  • 設置inputTransform為x放大1.5倍、y放大25倍,把點拉長、拉厚,但是它們仍然是有顏色的
在這里除了使用CIAffineTransform濾鏡外,還有一種替代方法可以達到同樣的效果,同時不用顯式創建CIAffineTransform濾鏡,就是使用CIImage的imageByApplyingTransform:方法。 再次用CIColorMatrix濾鏡對顏色進行處理:
  • 設置inputImage為CIAffineTransform生成的圖
  • 設置inputRVector為(4,0,0,0)
  • 設置inputGVector、inputBVector和inputAVector為(0,0,0,0)
  • 設置inputBiasVector為(0,1,1,1)
現在產生的是一個藍綠色磨砂圖濾鏡,再把CIMinimumComponent濾鏡應用到這個藍綠色磨砂圖濾鏡產生的圖上。CIMinimumComponent濾鏡會使用r、g、b的最小值生成一張灰度圖像。

把所有的濾鏡組合起來

使用CIMultiplyCompositing做最后的組合,參數設置如下:
  • 設置inputImage為CISourceOverCompositing濾鏡生成的圖(內含CISepiaTone、白斑圖濾鏡的效果)
  • 設置inputBackgroundImage為CIMinimumComponent濾鏡生成的圖(內含黑色磨砂圖濾鏡效果)
最后把CIMultiplyCompositing生成出的圖輸出到imageView上,還是以前的方式,先轉成CGImage,再把CGImage轉成UIImage。
有點小長,而且同時用到了多個濾鏡,其實想表達的意思并沒有那么復雜,可以使用kCICategoryBuiltIn把所有的濾鏡打印出來,然后對照著看它們的參數。

這里是oldFilmEffect方法實現:

@IBAction?func?oldFilmEffect() {

? ??let?inputImage =?CIImage(image:?originalImage)

? ??// 1.創建CISepiaTone濾鏡

? ??let?sepiaToneFilter =?CIFilter(name:?"CISepiaTone")

? ? sepiaToneFilter.setValue(inputImage, forKey:?kCIInputImageKey)

? ? sepiaToneFilter.setValue(1, forKey:?kCIInputIntensityKey)

? ??// 2.創建白斑圖濾鏡

? ??let?whiteSpecksFilter =?CIFilter(name:?"CIColorMatrix")

? ? whiteSpecksFilter.setValue(CIFilter(name:?"CIRandomGenerator").outputImage.imageByCroppingToRect(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")

? ??// 3.CISepiaTone濾鏡和白斑圖濾鏡以源覆蓋(source over)的方式先組合起來

? ??let?sourceOverCompositingFilter =?CIFilter(name:?"CISourceOverCompositing")

? ? sourceOverCompositingFilter.setValue(whiteSpecksFilter.outputImage, forKey:?kCIInputBackgroundImageKey)

? ? sourceOverCompositingFilter.setValue(sepiaToneFilter.outputImage, forKey:?kCIInputImageKey)

? ??// ---------上面算是完成了一半

? ??// 4.CIAffineTransform濾鏡先對隨機噪點圖進行處理

? ??let?affineTransformFilter =?CIFilter(name:?"CIAffineTransform")

? ? affineTransformFilter.setValue(CIFilter(name:?"CIRandomGenerator").outputImage.imageByCroppingToRect(inputImage.extent()), forKey:?kCIInputImageKey

? ? affineTransformFilter.setValue(NSValue(CGAffineTransform:?CGAffineTransformMakeScale(1.5,?25)), forKey:?kCIInputTransformKey)

? ??// 5.創建藍綠色磨砂圖濾鏡

? ??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:?0, 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濾鏡把藍綠色磨砂圖濾鏡處理成黑色磨砂圖濾鏡

? ??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, fromRect: outputImage.extent())

? ??imageView.image?=?UIImage(CGImage: cgImage)

}

以上就是一個老電影濾鏡的“配方”了。 編譯、運行,顯示效果如下:




子類化CIFilter

有時可能會對一些圖片應用同樣的濾鏡,我們可能會像上面那樣把一連串的濾鏡組合起來,以達到自己想要的效果,那么我們就可以把這些操作封裝到一個CIFilter的子類中,然后在多個地方反復使用,就像使用Core Image預置的濾鏡那樣。 CICategoryColorEffect類別中有個CIColorInvert濾鏡,這個濾鏡提供反色功能,實現起來并不復雜,因為我們并不是做一個真正的自定義濾鏡,而是在里面對Core Image已有濾鏡的封裝,我們可以為子類定義一些輸入參數,參照蘋果對CIFilter子類的命名約定,輸入參數必須用input作前綴,如inputImage,然后再重寫outputImage方法就行了。
現在我們回到Xcode中,做以下幾件事:
  • 新建一個Cocoa Touch Class,類名就叫CIColorInvert,繼承自CIFilter
  • 添加一個inputImage參數,類型自然是CIImage,由外界賦值。
  • 重寫outputImage屬性的getter。如果你之前寫過Objective-C,應該對屬性有這樣一個印象:子類要重寫父類的屬性,只需要單獨寫個getter或setter方法就行了,但在Swift里,不能通過這種方式重寫屬性,必須連getter、setter(如果父類的屬性支持setter的話)一起重寫。在我們的例子中outputImage在CIFilter中只是一個getter屬性,
  • 在outputImage里通過CIColorMatrix濾鏡對圖像的各向量進行調整。
  • CIColorInvert類實現:

    class?CIColorInvert:?CIFilter?{

    ? ??var?inputImage:?CIImage!

    ?? ?

    ? ??override?var?outputImage:?CIImage! {

    ? ? ? ??get?{

    ? ? ? ? ? ??return?CIFilter(name:?"CIColorMatrix", withInputParameters: [

    ? ? ? ? ? ? ? ??kCIInputImageKey?:?inputImage,

    ? ? ? ? ? ? ? ??"inputRVector"?:?CIVector(x: -1, y:?0, z:?0),

    ? ? ? ? ? ? ? ??"inputGVector"?:?CIVector(x:?0, y: -1, z:?0),

    ? ? ? ? ? ? ? ??"inputBVector"?:?CIVector(x:?0, y:?0, z: -1),

    ? ? ? ? ? ? ? ??"inputBiasVector"?:?CIVector(x:?1, y:?1, z:?1),

    ? ? ? ? ? ? ]).outputImage

    ? ? ? ? }

    ? ? }

    }

    然后在Storyboard的VC上增加一個按鈕“反色”,連接到VC的colorInvert方法上,colorInvert方法實現如下:

    @IBAction?func?colorInvert() {

    ? ??let?colorInvertFilter =?CIColorInvert()

    ? ? colorInvertFilter.inputImage?=?CIImage(image:?imageView.image)

    ? ??let?outputImage = colorInvertFilter.outputImage

    ? ??let?cgImage =?context.createCGImage(outputImage, fromRect: outputImage.extent())

    ? ??imageView.image?=?UIImage(CGImage: cgImage)

    }?

    這樣一下,一個對Core Image預置濾鏡的簡單封裝就完成了,每一個濾鏡的效果就像是一張配方,CIFilter就是裝有配方的瓶子,所以子類化CIFilter并不算自定義濾鏡,但是從iOS 8開始,Core Image是支持真正的自定義濾鏡的,自定義的濾鏡被稱之為內核(CIKernel),在WWDC視頻里對其有50分鐘的介紹:https://developer.apple.com/videos/wwdc/2014/#515。 運行后反色的效果,再次點擊反色按鈕后顯示原圖:


    簡單摳圖并更換背景

    利用Core Image預置的濾鏡能滿足大部分使用場景,我們做一個簡單的替換背景的功能。 為了方便測試,加入兩張新的圖:
    點擊圖片可以打開原圖。 將兩張圖添加到當前工程中,然后把ViewController的屬性originalImage改為返回左邊的圖:

    ......

    lazy?var?originalImage:?UIImage?= {

    ? ??return?UIImage(named:?"Image2")

    }()

    ......

    然后在Storyboard的VC上增加兩個按鈕:一個用于顯示原圖:

    @IBAction?func?showOriginalImage() {

    ? ??self.imageView.image?=?originalImage

    }

    另一個按鈕就叫“更換背景”,連接到VC的IBAction方法replaceBackground上。 我們先看要做的事情:
    • 消除深綠色
    • 組合圖片

    消除深綠色

    就像Photoshop的魔法棒一樣,Core Image也有類似的濾鏡,但是沒有那么簡單粗暴,使用起來很麻煩。 在Core Image里,我們為了消除某種顏色,需要使用CIColorCube濾鏡,而CIColorCube濾鏡需要一張cube映射表,這張表其實就是張顏色表(3D顏色查找表),把你想消除的顏色的alpha值設置為0,其他的顏色不變,Core Image將會把圖像數據上的顏色映射為表中的顏色,以此來達到消除某種顏色的目的。 CIColorCube的這張表默認不會對inputImage作任何處理,但在我們這里要將所有的深綠色干掉,所以需要自己來建立這張表。
    我們要消除的“深綠色”并不只是視覺上的一種顏色,而是顏色的范圍,最直接的方法是將RGBA轉成HSV(Hue,Saturation,Value),在HSV的格式下,顏色是圍繞圓柱體中軸的角度來表現的,在這種表現方法下,你能把顏色的范圍想象成連在一起的扇形,然后直接把該塊區域干掉(alpha設為0),這就表示我們實際上需要指定顏色區域的范圍------圍繞圓柱體中軸線的最小角度以及最大角度,此范圍內的顏色alpha設為0。最后,Cube Map表中的數據必須乘以alpha,所以創建Cube Map的最后一步是把RGB值乘以你剛剛計算出來的alpha值:如果是想要消除的顏色,乘出來就是0,反之則不變。這是一張代表顏色值區域的HSV(Hue值)圖:
    可以看到如果是純綠色,其取值是120度,藍色是240度,我們這種情況取值大概在60到90左右(偏綠一點),在這個網站上可以看到更詳細的RGB顏色對應的HSV值。 那么接下來我們就準備創建Cube Map表,創建Cube Map表的方法在蘋果官方示例中可以找到,是C語言實現的,為了方便起見,我們就直接創建一個C文件來包含這些代碼。 在工程里選擇新建一個.c文件,我取名為CubeMap.c,在創建這個.c文件的時候,不出意外的話Xcode會問你是否需要創建一個橋接頭文件(xxxx.Bridging-Header.H),選擇是,Xcode會創建該文件,并自動把其路徑放到編譯選項的Objective-C Bridging Header中。如果你要自己添加這個文件,并且需要手動修改Objective-C Bridging Header的編譯選項,可以看這里。 .c文件搞完以后,即把蘋果官方示例中的代碼(以下代碼)添加進去:

    struct?CubeMap {

    ? ??int?length;

    ? ??float?dimension;

    ? ??float?*data;

    };


    struct?CubeMap?createCubeMap(float?minHueAngle,?float?maxHueAngle) {

    ? ??const?unsigned?int?size =?64;

    ? ??struct?CubeMap?map;

    ? ? map.length?= size * size * size *?sizeof?(float) *?4;

    ? ? map.dimension?= size;

    ? ??float?*cubeData = (float?*)malloc?(map.length);

    ? ??float?rgb[3], hsv[3], *c = cubeData;

    ?? ?

    ? ??for?(int?z =?0; z < size; z++){

    ? ? ? ? rgb[2] = ((double)z)/(size-1);?// Blue value

    ? ? ? ??for?(int?y =?0; y < size; y++){

    ? ? ? ? ? ? rgb[1] = ((double)y)/(size-1);?// Green value

    ? ? ? ? ? ??for?(int?x =?0; x < size; x ++){

    ? ? ? ? ? ? ? ? rgb[0] = ((double)x)/(size-1);?// Red value

    ? ? ? ? ? ? ? ??rgbToHSV(rgb,hsv);

    ? ? ? ? ? ? ? ??// Use the hue value to determine which to make transparent

    ? ? ? ? ? ? ? ??// The minimum and maximum hue angle depends on

    ? ? ? ? ? ? ? ??// the color you want to remove

    ? ? ? ? ? ? ? ??float?alpha = (hsv[0] > minHueAngle && hsv[0] < maxHueAngle) ??0.0f:?1.0f;

    ? ? ? ? ? ? ? ??// Calculate premultiplied alpha values for the cube

    ? ? ? ? ? ? ? ? c[0] = rgb[0] * alpha;

    ? ? ? ? ? ? ? ? c[1] = rgb[1] * alpha;

    ? ? ? ? ? ? ? ? c[2] = rgb[2] * alpha;

    ? ? ? ? ? ? ? ? c[3] = alpha;

    ? ? ? ? ? ? ? ? c +=?4;?// advance our pointer into memory for the next color value

    ? ? ? ? ? ? }

    ? ? ? ? }

    ? ? }

    ? ? map.data?= cubeData;

    ? ??return?map;

    }

    我將這個方法稍微改造了一下,選回一個結構體,因為外面要用到length和dimension。蘋果沒有提供rgbToHSV方法的實現,可以用我找到的這個:

    void?rgbToHSV(float?*rgb,?float?*hsv) {

    ? ??float?min, max, delta;

    ? ??float?r = rgb[0], g = rgb[1], b = rgb[2];

    ? ??float?*h = hsv, *s = hsv +?1, *v = hsv +?2;

    ?? ?

    ? ? min =?fmin(fmin(r, g), b );

    ? ? max =?fmax(fmax(r, g), b );

    ? ? *v = max;

    ? ? delta = max - min;

    ? ??if( max !=?0?)

    ? ? ? ? *s = delta / max;

    ? ??else?{

    ? ? ? ? *s =?0;

    ? ? ? ? *h = -1;

    ? ? ? ??return;

    ? ? }

    ? ??if( r == max )

    ? ? ? ? *h = ( g - b ) / delta;

    ? ??else?if( g == max )

    ? ? ? ? *h =?2?+ ( b - r ) / delta;

    ? ??else

    ? ? ? ? *h =?4?+ ( r - g ) / delta;

    ? ? *h *=?60;

    ? ??if( *h <?0?)

    ? ? ? ? *h +=?360;

    }

    我在.c文件中導入的庫:

    #include?<stdio.h>

    #include?<stdlib.h>

    #include?<math.h>

    對了,如果那個橋接文件里沒有導入這個.c文件的話是不行的,Swift的類會找不到這里面的方法。

    //? ComplexFilters-Bridging-Header.h

    //? Use this file to import your target's public headers that you would like to expose to Swift.

    //


    #import?"CubeMap.c"?


    組合圖片

    VC中的replaceBackground方法只需要做三件事:
    • 創建Cube Map表
    • 創建CIColorCube濾鏡并使用Cube Map
    • 用CISourceOverCompositing濾鏡將處理過的人物圖像和未處理過的背景圖粘合起來
    方法實現如下:

    @IBAction?func?replaceBackground() {

    ? ??let?cubeMap =?createCubeMap(60,90)

    ? ??let?data =?NSData(bytesNoCopy: cubeMap.data, length:?Int(cubeMap.length), freeWhenDone:?true)

    ? ??let?colorCubeFilter =?CIFilter(name:?"CIColorCube")

    ?? ?

    ? ? colorCubeFilter.setValue(cubeMap.dimension, forKey:?"inputCubeDimension")

    ? ? colorCubeFilter.setValue(data, forKey:?"inputCubeData")

    ? ? colorCubeFilter.setValue(CIImage(image:?imageView.image), forKey:?kCIInputImageKey)

    ? ??var?outputImage = colorCubeFilter.outputImage

    ?? ?

    ? ??let?sourceOverCompositingFilter =?CIFilter(name:?"CISourceOverCompositing")

    ? ? sourceOverCompositingFilter.setValue(outputImage, forKey:?kCIInputImageKey)

    ? ? sourceOverCompositingFilter.setValue(CIImage(image:?UIImage(named:?"background")), forKey:?kCIInputBackgroundImageKey)


    ? ? outputImage = sourceOverCompositingFilter.outputImage

    ? ??let?cgImage =?context.createCGImage(outputImage, fromRect: outputImage.extent())

    ? ??imageView.image?=?UIImage(CGImage: cgImage)

    }

    參數設置都還比較簡單,CISourceOverCompositing濾鏡目前已經使用過多次了,并沒有什么復雜的。編譯、運行,可以分兩次執行,先看消除深綠色的效果,再看最后使用CISourceOverCompositing濾鏡組合圖片之后的效果:


    GitHub下載地址

    我在GitHub上會保持更新。


    UPDATED:

    我在更換背景的右側,新加入了一個顯示圖2的button,已在GitHub上更新。



    參考資料:

    http://www.docin.com/p-387777241.html

    https://developer.apple.com/library/mac/documentation/graphicsimaging/conceptual/CoreImaging/ci_intro/ci_intro.html


    總結

    以上是生活随笔為你收集整理的iOS8 Core Image In Swift:更复杂的滤镜的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    少妇bbbb搡bbbb搡bbbb | 97超碰人人澡 | 一本一本久久a久久精品综合小说 | 九九热久久久 | 免费视频黄 | bbbbb女女女女女bbbbb国产 | 国产亚洲精品久久久久久无几年桃 | 天天爱天天操天天爽 | 热久久99这里有精品 | 久久国产精品免费一区二区三区 | 亚洲国产高清在线观看视频 | 国产香蕉97碰碰久久人人 | 国产色久 | 波多野结衣电影一区 | 99热手机在线观看 | 激情五月看片 | 久久99精品久久只有精品 | 九九热在线免费观看 | a亚洲视频| 国产视频一区在线 | 午夜精品一区二区三区免费视频 | 黄色大片日本 | 在线观看av网 | 中文字幕中文字幕在线中文字幕三区 | 激情网站网址 | 免费黄色在线播放 | 亚洲黄色免费网站 | 91在线精品视频 | 外国av网 | 日韩天堂在线观看 | av大全在线 | 色五月成人 | 中国黄色一级大片 | 亚洲va欧美 | 亚洲国产日韩欧美 | 欧美一级激情 | 久久久国产高清 | 91资源在线播放 | 日韩欧美在线视频一区二区三区 | 狠狠的日日 | 亚洲另类视频在线观看 | 国内精品久久久久久中文字幕 | 久草在线手机观看 | 国产一级不卡视频 | 亚洲免费a | 亚洲成人高清在线 | 欧美激情精品久久久久 | 久久亚洲综合色 | 亚洲第一久久久 | 色综合久久久久综合 | 欧美资源 | 日韩精品视 | 最近中文字幕大全中文字幕免费 | 国产精品一区二区三区四区在线观看 | 久久色视频 | 97在线精品国自产拍中文 | 国产黄色在线 | 97成人在线视频 | 伊人电影天堂 | av播放在线 | 日韩中文字幕91 | 日本精a在线观看 | 中文字幕在线观看视频免费 | 三级动图 | 成人黄色在线播放 | 久草在线免费资源 | 色偷偷av男人天堂 | av专区在线 | 黄色一级动作片 | 日日操网站 | 91成人天堂久久成人 | 黄色国产高清 | 特级aaa毛片 | 国产传媒中文字幕 | bbbb操bbbb| 波多野结衣视频一区 | 国产成人精品女人久久久 | 国产亚洲在线 | 久久99国产精品免费 | www免费视频com━ | 亚洲最大在线视频 | 日日夜夜免费精品视频 | 色天天综合久久久久综合片 | 国产精品久久久久久一区二区 | 久久久精品网 | 免费看毛片在线 | 国产午夜精品理论片在线 | 国产精品1区2区 | 欧美日韩视频一区二区 | 久热久草| 国产免费片 | 日韩午夜电影网 | 99视频国产精品免费观看 | 国产精品久久久久婷婷 | 国产午夜精品视频 | 国产精品你懂的在线观看 | 丝袜美女在线 | 日韩精品免费一线在线观看 | 亚洲精品五月 | 成年人黄色大片在线 | 一级免费观看 | 视频一区二区精品 | 日韩四虎| 色综合久久久 | 国产精品免费在线视频 | 成人av在线一区二区 | 免费看片网址 | 91精品国产电影 | 麻豆久久久久 | 国产婷婷精品av在线 | 欧美极品裸体 | 麻豆首页| 久久综合九色九九 | 在线韩国电影免费观影完整版 | 97超碰人人| 精品亚洲成a人在线观看 | 日本韩国精品一区二区在线观看 | 久久亚洲欧美日韩精品专区 | 最近在线中文字幕 | 777久久久 | 久久免费99精品久久久久久 | 国产在线国偷精品产拍免费yy | 国产精品第二页 | 久久爱导航 | 久久99最新地址 | 久久人人做 | 高潮毛片无遮挡高清免费 | 欧美一区二区三区免费观看 | 在线看中文字幕 | 国产精品一区二区三区免费视频 | av线上看| 91麻豆精品国产91久久久无限制版 | 亚洲电影院| 久久久久久久久久网站 | 91在线蜜桃臀 | 国产一区二区在线精品 | 二区中文字幕 | 欧美孕妇视频 | 欧美尹人| 最近日韩免费视频 | 97色在线观看 | 激情在线网站 | 午夜精品一区二区三区在线播放 | 久草免费在线视频 | 啪啪凸凸| 国产麻豆剧果冻传媒视频播放量 | 四月婷婷在线观看 | 欧美天天射 | 国产精品免费小视频 | 天天伊人网 | 91污在线观看 | 国产破处视频在线播放 | 免费看黄色91 | 人人模人人爽 | 91精品国产综合久久久久久久 | 99国产精品久久久久久久久久 | 毛片在线播放网址 | 国内精品久久久久久久久久清纯 | 9热精品| 久久成人精品电影 | 亚洲综合欧美日韩狠狠色 | 欧美精品在线观看免费 | 日韩av电影中文字幕 | 亚洲在线精品 | 天堂av在线中文在线 | 亚洲精品视频中文字幕 | 精品字幕 | 96久久久| 国产一区视频在线观看免费 | 久久av免费观看 | 18国产精品白浆在线观看免费 | 91亚洲永久精品 | 欧美日韩高清一区二区 | 免费观看丰满少妇做爰 | 欧美色精品天天在线观看视频 | 一区二区三区高清 | 国产精品久久久久久久久婷婷 | 久久国产精品视频观看 | 毛片基地黄久久久久久天堂 | 免费a一级 | av天天干| 欧美日韩xxxxx | 成年人免费在线观看 | 波多野结衣电影一区二区 | 日韩精品一区二区三区第95 | 亚洲视频在线视频 | 激情av网址| 色综合久久88色综合天天 | 婷婷在线不卡 | 亚洲黄色av一区 | 少妇bbw撒尿 | 亚洲va天堂va欧美ⅴa在线 | 麻豆视频免费看 | 精品你懂的 | 久久精品五月 | 在线av资源 | 国产尤物在线视频 | 日韩色视频在线观看 | 成人精品一区二区三区电影免费 | 97高清视频 | 91资源在线观看 | 在线观看网站你懂的 | 亚洲毛片一区二区三区 | av在线一 | 亚洲每日更新 | 精品一区二区三区在线播放 | 久久久久免费 | 九九综合在线 | 国产成人精品a | 三级黄色欧美 | 色播五月激情综合网 | 国产97视频 | 国产精品免费小视频 | av看片在线观看 | 久久夜色精品国产欧美乱极品 | 国产麻豆剧传媒免费观看 | 国产精品69久久久久 | 91色网址 | 蜜臀精品久久久久久蜜臀 | 人人干狠狠操 | 免费av高清| 四月婷婷在线观看 | 欧美日韩调教 | 久久久精品国产免费观看一区二区 | 国产最新在线视频 | 久草97| 狠狠操.com | av黄色在线 | 欧美日韩高清一区 | 在线免费观看麻豆 | 在线观看国产一区 | 国内视频| 伊人影院在线观看 | 天堂av官网 | 激情五月av | 在线午夜| 丁香九月婷婷综合 | 欧美日韩xxx| 六月激情| 亚洲丝袜一区 | 国产精品a成v人在线播放 | 日日爱av | 国产99在线免费 | 日本视频网 | 国产又粗又猛又爽又黄的视频免费 | 欧美视频不卡 | 久草网视频在线观看 | 香蕉视频久久久 | 国产精品mv在线观看 | 亚洲国产av精品毛片鲁大师 | 国产精品免费视频观看 | 人人草网站| 麻豆视传媒官网免费观看 | 天天曰天天射 | 人人舔人人舔 | 欧美日韩xx| 日本久久高清视频 | 国产精华国产精品 | 国产精品久一 | 国产三级午夜理伦三级 | 午夜精品久久久久久久99 | 91精品免费在线视频 | 在线亚洲午夜片av大片 | 日日干日日| 综合色综合色 | 国产精品女同一区二区三区久久夜 | 天天射天天爱天天干 | 69久久久久久久 | 日韩电影在线观看一区二区 | 国产精品久久久久久久久久99 | 亚洲一一在线 | 最近高清中文字幕 | 91精品国产一区二区在线观看 | 日韩精品一区二 | 国产精品网站 | 一区二区三区日韩精品 | 国产午夜三级一二三区 | 手机在线观看国产精品 | 91在线看黄| 久久99国产视频 | 日韩精品一区二区三区外面 | 成人一区二区在线 | 一区二区影院 | 欧美精品久久久久久久久久白贞 | 国产中文字幕av | 国产一级性生活 | 日日夜夜爱 | 六月婷婷网 | 国产精品美女久久久久久久久久久 | 99操视频| 久久99亚洲精品久久久久 | 91av观看| 日韩免费在线视频 | 97网站| 色五月激情五月 | 成人影视免费 | 亚洲永久精品国产 | 久99久中文字幕在线 | 国产精品久久久久久99 | 九九热精品视频在线播放 | 激情欧美丁香 | 午夜精品久久一牛影视 | 国产一区二区精品久久91 | 久草视频网 | 天天操狠狠操网站 | 国产欧美日韩精品一区二区免费 | 久久久久久久久久久免费av | 91成人蝌蚪| 国产精品一区二区久久精品爱涩 | 99中文字幕在线观看 | 99热在线国产精品 | 中文字幕在线电影 | 亚洲免费不卡 | 成人黄色大片在线观看 | 精品毛片久久久久久 | 99精品欧美一区二区三区 | 日韩在线免费电影 | 五月天激情视频 | 精品亚洲欧美一区 | 九九亚洲精品 | 日韩一级黄色大片 | 久久久视频在线 | 久久亚洲免费 | 偷拍区另类综合在线 | 日韩免费看片 | 日韩一级电影在线观看 | 五月精品 | 国产一级二级在线观看 | 在线观看色网 | a级成人毛片 | 国产精成人品免费观看 | av一级在线 | 韩日电影在线观看 | 成人国产精品免费 | 久久手机视频 | 91人人揉日日捏人人看 | 色综合天天综合网国产成人网 | 国产精品久久久久久久久久久久午 | 免费开视频 | 一区二区精品视频 | www.操.com| 亚洲精品乱码白浆高清久久久久久 | 涩涩在线 | 丁香花五月 | 韩国av一区二区三区在线观看 | 国产资源 | 又湿又紧又大又爽a视频国产 | 国产在线观看免费 | 91视频在线免费下载 | 天天操夜夜操 | 草久久av| 日本黄色免费观看 | 久草在线在线精品观看 | 久久久国产一区二区 | 久久精品精品 | 国产视频2021 | 亚洲精品伦理在线 | 国产999精品久久久 免费a网站 | 国产在线精品二区 | 精品视频123区在线观看 | 97免费在线观看视频 | 黄色av一区 | 欧美精品中文字幕亚洲专区 | 国产手机在线观看 | 国产亚洲精品综合一区91 | 最新三级在线 | 久久经典国产视频 | 97视频免费观看 | 香蕉视频在线播放 | 精品亚洲男同gayvideo网站 | 狠狠狠狠狠狠狠干 | 97干com | 国产麻豆精品久久 | 在线观看视频精品 | 四虎影视成人永久免费观看亚洲欧美 | 精品麻豆入口免费 | 久久视频6| 日韩成人黄色av | 五月天丁香 | 99久热在线精品视频观看 | 999在线精品 | 91在线免费播放视频 | 免费av网站在线 | 国产亚洲精品久久网站 | 可以免费看av| 不卡的av在线播放 | 久久99网站 | 国产97在线看 | 玖玖精品在线 | 欧美久久影院 | 日韩深夜在线观看 | 手机看片国产 | 久久久久久伊人 | 国产视频一区二区在线观看 | 久久久午夜精品理论片中文字幕 | 成人国产一区 | 天天操天天添天天吹 | 日韩在线视频免费播放 | 久久视频在线观看免费 | 日韩有码欧美 | 成人一级黄色片 | 六月丁香激情综合 | 精品亚洲午夜久久久久91 | 在线免费观看涩涩 | 香蕉影院在线观看 | 青青看片| www夜夜操com | 国产日韩精品视频 | 日韩天堂在线观看 | 精品在线免费观看 | 国产综合在线视频 | 国内精品在线观看视频 | 精品久久免费看 | 日本精品在线看 | 黄色精品视频 | 全久久久久久久久久久电影 | 亚洲一二视频 | 久久夜色网| 天天弄天天干 | 天天干夜夜夜 | 玖玖爱在线观看 | 久久久天堂 | 久久艹欧美 | 丁香婷婷色月天 | 日本公妇在线观看高清 | 波多野结衣精品 | 国产精品久久久毛片 | 欧美视频xxx | 伊人久在线 | 国产一级二级三级视频 | 久热爱| 久久精品a | 国产精品久久久久久久妇 | 免费久久久 | 国产一区高清在线 | 91麻豆精品国产 | 欧洲精品在线视频 | 国产91大片 | 国产色在线,com | 蜜桃av人人夜夜澡人人爽 | 黄色电影网站在线观看 | av久久在线 | 亚洲欧美视屏 | 久久国产精品一区二区三区四区 | 国产精品女人久久久 | 悠悠av资源片 | 免费av试看 | 视频在线观看一区 | 91精品一区二区三区蜜桃 | 天天射天天操天天 | 国产大片免费久久 | 欧美性生活免费 | 中文字幕在线观看完整版 | 99超碰在线观看 | 久草免费电影 | 有码中文在线 | 成人免费影院 | 亚洲电影成人 | 免费看一级一片 | 中文字幕在线视频精品 | 天堂在线视频中文网 | 久久这里有精品 | 日韩免费av网址 | 91黄色在线看 | 日韩91在线 | 久久91网| 亚洲精品久久久久久久蜜桃 | 97超碰中文字幕 | 亚洲精品久久久蜜臀下载官网 | 在线观看91久久久久久 | 激情视频免费在线 | 亚洲综合成人专区片 | 亚洲色影爱久久精品 | 中国精品一区二区 | 91日韩在线专区 | www.久草视频 | 国产午夜亚洲精品 | 久草网视频 | 国产一区二区三区四区大秀 | 草樱av | 91精品网站 | 日韩免费在线看 | 国产成人91 | 看国产黄色片 | 久久精品中文字幕 | 欧美成人播放 | 激情久久网 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 天天搞夜夜骑 | 在线观看的av网站 | 欧美视频二区 | 色欧美88888久久久久久影院 | 日韩精品一区在线播放 | 伊人激情网 | 国产又粗又猛又爽又黄的视频免费 | av片免费播放 | 国产伦精品一区二区三区照片91 | 久久视频国产 | 久久天天操| 久久99热精品 | 黄色日本免费 | av资源中文字幕 | 在线观看免费 | 在线观看免费观看在线91 | 三级av网站| 九九亚洲精品 | 国产精品都在这里 | 国产福利91精品一区二区三区 | 亚洲日韩欧美一区二区在线 | 国产白浆视频 | www中文在线 | 成人免费观看完整版电影 | 久久精品伊人 | 波多野结衣在线观看一区 | 亚洲一区二区三区在线看 | 成人黄色在线电影 | 中文字幕丝袜美腿 | 国产区网址 | 久久免费视频3 | 欧美日韩在线精品一区二区 | 亚洲三级黄色 | 97色在线观看免费视频 | 青青网视频 | 超碰97成人 | 99久久er热在这里只有精品15 | 精品免费视频123区 午夜久久成人 | 黄色免费大片 | 久久久久久久亚洲精品 | www.天天色 | av丁香| 午夜日b视频 | 久久超 | 国模一区二区三区四区 | 狠色狠色综合久久 | 在线观看黄色大片 | 99热官网| 麻豆免费观看视频 | 日韩欧美一区二区三区免费观看 | 91精品专区 | 婷婷国产在线 | 久久成人国产精品一区二区 | 激情综合中文娱乐网 | 91丨九色丨丝袜 | 精品国产欧美一区二区 | 麻花豆传媒mv在线观看网站 | 精品一二三四视频 | 久草在线视频免赞 | 中文字幕精品一区二区精品 | 亚洲人成在线观看 | 最新日本中文字幕 | 欧美精品久久久久久 | 日日干视频 | 最新中文字幕视频 | 97色综合| 精品视频在线播放 | 黄色av一级 | 18做爰免费视频网站 | 嫩草伊人久久精品少妇av | 久久精品视频在线看 | 日韩伦理片一区二区三区 | 黄色小说网站在线 | 成年人视频在线免费 | 91免费观看视频网站 | 久久久久精 | 欧美一级电影免费观看 | 亚洲另类视频在线观看 | av观看免费在线 | 久久99热这里只有精品 | 国产精品欧美久久 | 在线免费视| 麻豆一区二区三区视频 | 国产精品色视频 | 成年人黄色在线观看 | 日韩在线激情 | 免费一级毛毛片 | 成人三级网站在线观看 | 99视频在线 | 27xxoo无遮挡动态视频 | 国产区免费 | 国产极品尤物在线 | 国产性xxxx | 91久久精品日日躁夜夜躁国产 | 国产一级在线看 | 午夜电影av | 97国产精品 | 午夜视频免费播放 | 成人亚洲综合 | 亚洲成人精品在线观看 | 探花视频在线观看免费 | 久久9精品 | 四虎在线免费视频 | 亚洲综合一区二区精品导航 | 亚洲伊人色 | 黄色午夜 | 婷婷激情欧美 | 国产精品久久久av | 99久久精品国产亚洲 | 一区三区视频在线观看 | 91尤物国产尤物福利在线播放 | 久久精品99国产精品日本 | 五月激情六月丁香 | 国产精品国产三级国产aⅴ入口 | 在线观看中文字幕av | 99在线精品观看 | 国产精品久久久久久久久久久久午夜 | 午夜美女网站 | 一区二区观看 | 欧美精品久久99 | 毛片.com| 亚洲精品国内 | 免费视频一二三区 | 免费观看国产精品视频 | 日韩色一区二区三区 | a色网站 | 色在线免费视频 | 香蕉国产91| 欧美精品在线观看一区 | 天天视频亚洲 | 亚洲国产经典视频 | 国产成人久久精品77777 | 西西www4444大胆视频 | 制服丝袜天堂 | 色网站在线免费观看 | 免费色黄| 中文字幕激情 | 亚洲人成人天堂h久久 | 国产三级视频在线 | 欧美精品久久久久久久久免 | 国产黄色片在线 | 99久久9 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 不卡视频在线 | 国产成人久久av | 欧美一级电影片 | 日韩在线中文字幕视频 | 亚洲一级片 | 五月激情电影 | 中文国产成人精品久久一 | 亚洲日日日 | 久久久久 | 国产一级特黄毛片在线毛片 | 久久精品成人 | 国产中文欧美日韩在线 | 亚洲一区二区黄色 | 97精品国产一二三产区 | 国产精品综合久久久久久 | 高清不卡毛片 | 成人资源在线 | 992tv成人免费看片 | 九九热精品视频在线观看 | 久久久久欧美精品999 | 91视频观看免费 | 又湿又紧又大又爽a视频国产 | 天天射天天爱天天干 | 国产精品成人av电影 | 美国av大片 | 日韩剧情 | 婷婷av网| 欧美日bb| 欧美日韩在线观看不卡 | 超碰在线天天 | 99精品免费网 | 久久99久| 中文字幕在线第一页 | 国产三级在线播放 | 国内精品久久久精品电影院 | 91在线视频免费 | 黄色网大全| 国产精品精品 | 在线小视频你懂的 | 黄色国产成人 | 国产区在线看 | 久久理论电影 | 一区二区精品在线观看 | 美女在线观看网站 | 欧美日韩在线视频观看 | 一本一本久久aa综合精品 | 九九精品视频在线观看 | 中文字幕久久精品亚洲乱码 | 国产一区欧美日韩 | 在线播放日韩av | 免费观看午夜视频 | 99久久精品国产亚洲 | 91精品成人久久 | 久久午夜电影 | 国产91精品看黄网站 | 精品一区电影 | www.伊人网 | 中文字幕在线播放视频 | 69国产精品视频免费观看 | 日韩三级视频在线观看 | 激情影院在线观看 | 日日操夜夜操狠狠操 | 啪啪肉肉污av国网站 | 久久久精品免费看 | 精品国产一区在线观看 | 色婷婷久久一区二区 | 91精品综合在线观看 | 狠狠干婷婷 | 国产美女精品久久久 | 欧美日韩国产一区二区三区在线观看 | 黄色字幕网 | 久久久久久久久久久网 | 免费久久精品视频 | 99成人免费视频 | 五月在线视频 | 91色亚洲 | 日韩理论在线视频 | 国产特级毛片 | 国产美女在线精品免费观看 | 日韩精品一区二区免费 | 狠狠狠狠狠狠天天爱 | 欧美日韩在线第一页 | 亚洲国产综合在线 | 91九色蝌蚪国产 | 999国产精品视频 | 精品国产一区二 | 91麻豆精品久久久久久 | 久久免费av电影 | 最新av网址大全 | 国产精品正在播放 | 久久这里只有精品9 | 亚洲婷婷网 | 久久99国产精品视频 | 久久久久免费观看 | 一区二区三区 中文字幕 | 欧美日韩在线第一页 | 久久6精品 | 国产精品亚洲片在线播放 | 日日夜夜国产 | 国内精品久久久久影院优 | 99热精品国产 | 日韩高清在线不卡 | 精品国产色 | 美女免费黄视频网站 | 天天射天天操天天色 | av一级在线观看 | 免费久久99精品国产 | 午夜精品一区二区三区在线视频 | 视频91| 国产资源网站 | 欧美a级片免费看 | 免费看一级黄色大全 | 国产成人在线精品 | 九九热在线视频 | 四虎永久视频 | 99国产在线| 精品国产一区二区三区不卡 | 国际精品久久 | 亚洲国产精品久久久久婷婷884 | 91超级碰碰| 成人毛片在线观看视频 | 国产在线看一区 | 狠狠操影视 | 超碰大片 | 成人久久视频 | 又爽又黄又刺激的视频 | 黄色在线网站噜噜噜 | 久久r精品 | 国产精品一区二区美女视频免费看 | 国产精品欧美激情在线观看 | 黄色网址在线播放 | 久久艹在线| 国产日韩精品久久 | 日韩福利在线观看 | 免费看久久久 | 欧美一二三四在线 | 麻豆视频在线 | 久久久精品日本 | 欧美日韩视频观看 | 深夜国产福利 | 日韩免费一区二区在线观看 | 久久视奸 | 中文字幕色在线 | 91精品视频免费观看 | 国产中文字幕在线免费观看 | 国产69精品久久99不卡的观看体验 | 99久久精品免费看国产 | 中文在线字幕免 | av电影在线不卡 | 国产999免费视频 | 91av电影在线观看 | 成人在线观看免费 | 免费精品视频在线 | 91麻豆精品国产91久久久无限制版 | 亚洲人精品午夜 | av中文在线观看 | 99久久一区 | 久久久精品在线观看 | 国精产品永久999 | 国产精品成人一区二区 | 免费特级黄毛片 | 日韩试看| 日本久久免费视频 | 亚洲年轻女教师毛茸茸 | 国产精品欧美久久久久无广告 | 黄色视屏免费在线观看 | 91av在线免费 | 最新日本中文字幕 | 欧美少妇xxx| 国产中文字幕大全 | 亚洲国产经典视频 | 天海翼一区二区三区免费 | 亚洲天堂色婷婷 | 欧美日韩3p | 日日色综合 | 欧美日韩综合在线 | 亚洲黄色在线观看 | 在线观看 国产 | 久久精品亚洲 | 亚洲天堂网在线播放 | 又黄又刺激 | 欧美日韩精品电影 | 亚洲精品字幕 | 国产一区二区三区在线 | 久草爱| 久久99这里只有精品 | 久久99国产精品久久 | 国产特级毛片 | 丰满少妇在线观看资源站 | 六月丁香色婷婷 | 国产成人99av超碰超爽 | 国产在线观看免费av | 99热这里只有精品在线观看 | 国产精品国产精品 | 成年人免费看片 | 亚洲狠狠| 日韩在线观看视频免费 | 久久精品久久精品久久 | 精品国自产在线观看 | 日韩精品专区 | 国产精品一区二区麻豆 | 日韩电影精品一区 | 五月婷婷六月丁香激情 | 免费黄色av电影 | 欧美国产91| 97超碰超碰久久福利超碰 | 亚洲精品国偷拍自产在线观看蜜桃 | 中文在线a∨在线 | 91自拍视频在线 | 成人黄色影片在线 | 成年人免费在线 | 亚洲1区 在线 | 欧美a影视 | 日本久久成人 | 91在线免费公开视频 | 国产在线视频一区二区 | 亚洲综合色丁香婷婷六月图片 | 亚洲精品高清视频在线观看 | 国产在线国偷精品产拍免费yy | 99这里只有精品99 | 91成人午夜 | 国产在线播放不卡 | 久草手机视频 | 综合激情 | 国产精品一区二区在线免费观看 | 在线视频a | 中文字幕在线免费观看 | 免费av的网站 | 天天色棕合合合合合合 | 中文视频在线看 | 色综合狠狠干 | 久久久天堂 | 国产成人免费av电影 | 天天综合婷婷 | 91看片淫黄大片在线播放 | 一区二区av | 成人永久在线 | 国产天天综合 | 在线播放精品一区二区三区 | 久久乐九色婷婷综合色狠狠182 | 国产高清日韩 | 久艹视频免费观看 | 国产精品久久久区三区天天噜 | 99精品视频在线观看播放 | 在线观看91| 亚洲美女在线一区 | 视色网站| 91视频三区 | 麻豆 videos| 婷婷免费在线视频 | 国产小视频在线看 | 午夜久久久精品 | 久久久电影网站 | 97在线观看视频免费 | 91精品视频免费观看 | 一区二区三区免费在线观看视频 | 国产一区二区日本 | 91免费高清在线观看 | 人人插人人看 | av再线观看 | 四虎在线免费观看视频 | 久久精品成人热国产成 | 国产一级精品在线观看 | 国产一区 在线播放 | 奇米网8888 | 欧美成人性网 | 欧美一二三区播放 | 久久国内免费视频 | 欧美日韩免费一区二区三区 | 色综合天天在线 | www.黄色片网站 | 91精品对白一区国产伦 | 激情丁香综合 | 亚洲欧洲日韩 | 伊人官网| 黄色免费看片网站 | 91精品人成在线观看 | 欧美一级欧美一级 | 婷婷色5月 | 国产xvideos免费视频播放 | 久久久久久久久久久黄色 | 亚洲精品动漫成人3d无尽在线 | 黄色免费在线视频 | 久久草在线视频国产 | 成人av在线直播 | 国产乱码精品一区二区蜜臀 | 国产成人一区二区三区 | 中文字幕一区二区三区四区 | 欧美男男激情videos | www.五月婷婷 | 中文字幕人成乱码在线观看 | 国产精品九九视频 | 麻豆激情电影 | 日韩在线视频在线观看 | 伊人色综合久久天天 | 久久精品99国产 | 日韩精品一区二区三区高清免费 | 91网在线观看 | 国产亚洲精品美女 | 日韩av高清在线观看 | 国产在线观看 | 国产亚洲精品久久久久动 | 国产成人免费在线 | 激情五月播播久久久精品 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 色婷婷骚婷婷 | 成人动态视频 | 欧美性色网站 | 九色在线视频 | 首页国产精品 | 免费观看av | 福利视频第一页 | 欧美激情视频一区二区三区免费 | 色婷婷综合久久久中文字幕 | 欧美日韩免费在线视频 | 久久久久久美女 | 亚洲成人国产精品 | 国产精品久久久久久久久久久不卡 | 六月天色婷婷 | 久久福利剧场 | 成人亚洲综合 | 久久人人爽人人爽人人片av软件 | 国产自产高清不卡 | 国产视频一二三 | 麻豆va一区二区三区久久浪 | 欧美精品久久久久久久久老牛影院 | www.色就是色| 三级午夜片 | 区一区二区三在线观看 | 永久免费av在线播放 | 亚洲理论片在线观看 | 久久免费视频5 | 午夜国产在线 | 久亚洲精品 | www.狠狠插.com| 一级性视频 | 99国内精品 | 久久精品99国产精品日本 | 日日夜夜人人天天 | 亚洲jizzjizz日本少妇 | 成人小视频在线观看免费 | 黄色免费大全 | 五月激情亚洲 | 国产成人三级一区二区在线观看一 | 久久免费一级片 | 久久综合久久综合九色 | 一区二区精品视频 | 久久私人影院 | 香蕉网在线观看 | 91久久精品一区二区三区 | 一 级 黄 色 片免费看的 | 中文久草 | 2023国产精品自产拍在线观看 | 91在线看网站 | 欧美黑人性猛交 | 欧美激情综合五月色丁香小说 | 国产精品久久久久久久久毛片 | 国产热re99久久6国产精品 | 国产 视频 高清 免费 | 99久久久久免费精品国产 | 亚洲 中文 欧美 日韩vr 在线 | 精品女同一区二区三区在线观看 | 成年人免费在线观看网站 | 91在线视频观看 | 91字幕| 视频国产在线观看18 | 99免费在线播放99久久免费 |