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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

iOS Core Image 复杂的滤镜

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

在上一篇中幾乎沒有對濾鏡進行更復雜的操作,都是直接把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控件觸發的方法。

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




復合濾鏡--老電影效果

在此之前,無論是使用簡單濾鏡,還是能動態修改參數值的濾鏡,都不算復雜,因為我們最多也只是對一個濾鏡設置點參數而已??墒侨绻F有的濾鏡沒有想要的效果,或者說單個濾鏡實現不了自己想要的效果,就只能自己處理了,其中,最簡單的做法是把多個濾鏡組合起來。 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

    原文地址:http://blog.csdn.net/zhangao0086/article/details/39120331


    總結

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

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

    男女全黄一级一级高潮免费看 | 在线看黄色的网站 | 久久久精品国产免费观看一区二区 | 日产乱码一二三区别在线 | 国产午夜精品久久久久久久久久 | 黄色成人在线网站 | 国产在线观看国语版免费 | www最近高清中文国语在线观看 | 久久久久观看 | 欧美天堂影院 | 欧洲精品一区二区 | 99这里有精品 | 伊甸园永久入口www 99热 精品在线 | 天天干天天干天天 | 成人在线视 | 欧美一级片 | 久久久久久久av | 四虎最新入口 | 国产又粗又猛又色又黄网站 | 国产生活一级片 | 亚洲天堂网站视频 | av中文字幕在线观看网站 | 毛片在线网| 麻豆视频在线免费看 | 国产在线探花 | 色在线国产 | 玖玖爱在线观看 | 欧美日韩国产二区三区 | av片子在线观看 | 激情综合网五月婷婷 | 91麻豆精品国产自产在线游戏 | 麻豆精品传媒视频 | 国产日韩欧美综合在线 | 国产精品久久久毛片 | 国产精品爽爽爽 | 成人小视频在线观看免费 | 午夜视频免费在线观看 | 欧美在线视频免费 | 亚洲美女视频在线观看 | 亚洲国产成人久久综合 | 久久艹99| 在线免费观看欧美日韩 | 亚洲高清网站 | 久久久久亚洲精品中文字幕 | 久久免费国产视频 | 97电影在线观看 | 综合在线亚洲 | 免费高清看电视网站 | 97超碰人 | 绯色av一区| 国产麻豆精品传媒av国产下载 | av中文字幕日韩 | 天天操狠狠操网站 | 欧美成人精品在线 | wwwwww黄| 狠狠操狠狠干2017 | 91激情视频在线 | 国产精品99精品久久免费 | av电影中文字幕 | 久久国产片 | 婷婷六月中文字幕 | 国产玖玖精品视频 | 国产精品成人免费精品自在线观看 | 欧美日韩成人 | 久草视频在线播放 | 开心丁香婷婷深爱五月 | 麻豆免费观看视频 | 国产成人精品免费在线观看 | 久久国产精品久久久久 | 日韩欧美在线观看一区二区三区 | 国产黄色精品网站 | 国精产品999国精产 久久久久 | 激情图片区 | 99视频一区二区 | 日产中文字幕 | 91.精品高清在线观看 | 国产午夜一区二区 | 最新av在线免费观看 | 国产99久久九九精品免费 | 国产91精品高清一区二区三区 | 国产午夜精品一区二区三区 | 一区二区三区在线免费播放 | 久久人人爽人人爽 | 天天射天天色天天干 | 日韩最新中文字幕 | 日本中文字幕在线电影 | 在线观看成人国产 | 国产精品videossex国产高清 | 人九九精品 | 亚洲国产美女精品久久久久∴ | 丁香激情婷婷 | 国产成人av网址 | 色网站国产精品 | 国产在线精品福利 | 天天射天天拍 | 五月天婷婷在线观看视频 | 色五月成人 | 久久久久久久国产精品 | 日日摸日日添夜夜爽97 | 天天玩天天干天天操 | 日本三级久久久 | 日本狠狠干 | 亚洲婷久久 | 精品久久网站 | 国产精品免费久久久久 | 色七七亚洲影院 | 国产剧在线观看片 | 黄色三级在线观看 | 91精品啪在线观看国产 | 日韩精品免费一区二区在线观看 | 国产日产精品一区二区三区四区的观看方式 | 欧美日韩亚洲一 | 久久久久久麻豆 | 国产啊v在线观看 | 国产手机av在线 | 亚洲欧洲一级 | 日韩av影视在线 | 国产亚洲精品bv在线观看 | 一本一本久久a久久精品综合小说 | 黄色成人影视 | 国产69久久| 久久视频中文字幕 | 日韩一区二区三区免费电影 | 欧美黑人xxxx猛性大交 | 9ⅰ精品久久久久久久久中文字幕 | 在线一区av| 亚洲综合激情网 | 欧美乱淫视频 | 天天操天天添 | 国产福利午夜 | 久草在线官网 | 亚洲一级免费观看 | www.色com| av中文字幕在线电影 | 天堂av免费看| 一区二区中文字幕在线观看 | 久久视频在线观看中文字幕 | 91桃色在线观看视频 | 日韩精品视频在线免费观看 | 西西4444www大胆无视频 | 超碰人人99| 免费国产一区二区 | 国内精品一区二区 | 亚洲精品久久在线 | 中文字幕永久在线 | 在线a人片免费观看视频 | 国产成人专区 | 免费日韩视频 | 国产一区二区在线免费 | 日韩免费观看一区二区三区 | 亚洲视频一区二区三区在线观看 | 免费精品视频在线观看 | 久久呀 | 欧洲色吧 | 久久久久亚洲精品成人网小说 | 欧美日韩一区二区三区免费视频 | 17婷婷久久www| 97福利社| 人人干狠狠干 | 国产精品免费高清 | 国产青春久久久国产毛片 | 亚洲午夜精品久久久久久久久 | 久久亚洲国产精品 | 免费99精品国产自在在线 | 亚洲综合色婷婷 | 91视频 - 88av| 国产一级片网站 | 天天躁天天躁天天躁婷 | 国产精品99免视看9 国产精品毛片一区视频 | 香蕉视频在线免费看 | 国产精品99久久久久久武松影视 | 亚洲激精日韩激精欧美精品 | 黄色最新网址 | 亚洲人久久 | 国产精品国产三级国产 | 亚洲激情在线播放 | 手机看国产毛片 | 一区二区三区免费 | 日韩资源在线播放 | 中文字幕三区 | 黄色一级大片在线免费看产 | av黄色免费看 | 国产无套精品久久久久久 | 亚洲精品久久在线 | 色婷婷av国产精品 | 国产午夜精品一区二区三区四区 | 国产h在线观看 | 五月激情丁香图片 | 中文字幕国产 | 日韩特级黄色片 | 中文字幕免费不卡视频 | 一级黄色免费 | 九九久久久 | adc在线观看| 特级大胆西西4444www | 美女视频久久 | 丝袜一区在线 | 伊人va| 亚州人成在线播放 | 国产亚洲成人精品 | 精品视频在线免费 | 黄色网在线播放 | 91在线精品一区二区 | 激情五月婷婷丁香 | 久色网 | 国产亚洲小视频 | 国产精品免费在线观看视频 | 日本久久免费视频 | 午夜视频不卡 | 免费久久片 | 中国精品少妇 | av资源免费观看 | 午夜精品电影 | 久久影院午夜论 | 国产精品成人在线观看 | 超级碰碰免费视频 | 久草在线资源观看 | 99精品免费网 | 久草视频看看 | 久草在线最新视频 | 中文字幕色综合网 | av在线亚洲天堂 | 天天色天天操天天爽 | 91麻豆精品国产自产 | 黄色av一区二区 | 色片网站在线观看 | 国产精品免费在线 | 九九免费观看全部免费视频 | 97碰碰碰| 免费成人黄色 | 在线黄网站| 91在线看网站 | 国产又粗又猛又爽 | 高清av中文在线字幕观看1 | 国产精品日韩欧美一区二区 | 日日夜夜狠狠干 | 天天爱天天操天天爽 | 免费视频18| 综合久久精品 | 亚洲人成网站精品片在线观看 | 国产精品久久视频 | 午夜久久久影院 | 国产永久免费高清在线观看视频 | 丁香花在线观看视频在线 | 国产精品入口久久 | 精品久久久成人 | 免费看污在线观看 | 久久99精品久久久久婷婷 | 综合久久久久 | 日韩免费网址 | 波多野结衣久久资源 | 中文一区二区三区在线观看 | 亚洲专区免费观看 | 99久久精品国 | 在线天堂中文在线资源网 | 一级全黄毛片 | 五月天色综合 | 国产成人福利在线观看 | 欧美成人精品在线 | 国产无遮挡猛进猛出免费软件 | 99久久激情视频 | 亚洲人成人在线 | 亚洲成人av影片 | 久久人网 | 国产一区成人在线 | 2021国产视频 | 久久艹国产 | 超碰公开在线观看 | 成人午夜网 | 91大神一区二区三区 | 最近中文字幕完整高清 | 999成人精品 | 国产又粗又猛又色又黄视频 | 精品国产乱码久久久久 | 国产精品一区在线观看 | 色噜噜狠狠狠狠色综合 | 婷婷5月激情5月 | 日韩欧美黄色网址 | 中文字幕高清视频 | 成人 亚洲 欧美 | 国产精品久久久久四虎 | 成人精品一区二区三区电影免费 | 欧美另类高清 | 国产精品免费观看在线 | 欧美性生活免费 | 一二三区高清 | 国产精品一区二区精品视频免费看 | 在线免费观看视频 | 五月婷婷激情综合 | av中文在线播放 | 99色99| 日日麻批40分钟视频免费观看 | 9999在线视频 | 天堂av在线网址 | 最近久乱中文字幕 | 久久久伊人网 | 午夜久久美女 | 亚洲精品999| 国产午夜亚洲精品 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 日韩a级免费视频 | 国产不卡精品 | 91在线看黄 | 高潮久久久久久 | 久久精品国产免费看久久精品 | 最近2019年日本中文免费字幕 | 婷婷色婷婷 | 日日夜精品 | 久久超级碰视频 | 久久久久国产精品厨房 | 狠狠干狠狠久久 | av在线激情| 五月婷婷视频 | www色片| 亚洲精品国产高清 | 久久精品99国产精品 | 国产成人高清av | 欧美精品久久久久久久 | 又黄又刺激又爽的视频 | 欧美日韩一区久久 | 成人a级免费视频 | 欧美黑人xxxx猛性大交 | 日韩特黄一级欧美毛片特黄 | 91精彩视频在线观看 | 五月天亚洲婷婷 | 人人看97 | 在线中文字幕一区二区 | 亚洲国产视频a | 久久桃花网 | 日韩天堂网 | 天天射网 | 日韩在线观看电影 | 人人草在线视频 | 亚洲四虎在线 | 五月情婷婷 | 日韩在线视频在线观看 | 国产69精品久久久久久久久久 | 国产福利精品一区二区 | 成人蜜桃视频 | 国产精品国产三级国产aⅴ入口 | 粉嫩一区二区三区粉嫩91 | 日韩欧美中文 | 九九三级毛片 | 亚洲国产精品成人va在线观看 | 亚洲黄色免费在线看 | 欧美色精品天天在线观看视频 | 丁香 婷婷 激情 | 911久久香蕉国产线看观看 | 日本三级中文字幕在线观看 | 91九色最新地址 | 亚洲午夜精 | 色狠狠久久av五月综合 | 成人免费在线观看入口 | 一本一本久久aa综合精品 | 欧美成人影音 | 中文字幕成人在线观看 | 一区二区三区四区五区在线视频 | 欧美日韩高清在线观看 | 亚洲在线精品视频 | 精品国产伦一区二区三区 | 久久久国产精品免费 | 五月天最新网址 | 黄色资源网站 | 国产91精品欧美 | 国产毛片在线 | 久久少妇免费视频 | 亚洲人在线视频 | 超碰公开97 | 在线看黄色av | 亚洲精品午夜久久久 | 日韩69视频 | 欧美性生交大片免网 | 九九99 | 日日爱网址 | 激情丁香久久 | www.久久免费视频 | 亚洲视频 中文字幕 | av免费观看网站 | 精品国产一区在线观看 | 精精国产xxxx视频在线播放 | 四虎影视久久久 | 久草精品在线播放 | 国产在线观看午夜 | 欧美一区免费在线观看 | 久久精品视频在线 | 婷婷av色综合 | 亚洲国产午夜 | 福利视频第一页 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 在线免费高清视频 | 精品视频久久 | 97碰碰精品嫩模在线播放 | 97成人在线视频 | 欧美久久久久 | 91九色在线观看视频 | 一本一本久久a久久精品综合妖精 | 天天爽天天碰狠狠添 | 亚洲国产精品500在线观看 | 婷婷激情五月 | 天天色婷婷 | 在线观看一区二区视频 | 国产在线一线 | 国产美女视频一区 | 91成人亚洲 | 69av国产| 日韩经典一区二区三区 | 亚洲激情在线视频 | 五月婷婷另类国产 | 成人性生交大片免费观看网站 | 最新久久久 | 在线涩涩| 久久字幕 | 国产小视频免费观看 | 2022久久国产露脸精品国产 | 在线观看www91 | 午夜国产一区二区 | 久久午夜免费视频 | 日日干美女 | 精品亚洲欧美一区 | 国产精品国产三级国产不产一地 | 久久免费99| 伊人久操 | 日韩欧美视频在线免费观看 | 国内成人精品视频 | 丁香网五月天 | 国产精品手机在线播放 | 2021国产在线视频 | 永久免费视频国产 | 看片一区二区三区 | 色婷婷综合成人av | 久久久精品国产免费观看一区二区 | 永久免费毛片在线观看 | 日韩电影中文字幕 | av免费网站在线观看 | 91精品视频一区二区三区 | 亚洲精品欧美视频 | 中文字幕999 | 欧美日韩视频一区二区 | 国产视频第二页 | 夜夜操网 | 日韩亚洲在线观看 | 99精品视频网站 | 国产成人三级三级三级97 | 麻豆国产精品永久免费视频 | 亚洲精品在线观看网站 | 久久免费看视频 | 久久综合婷婷国产二区高清 | 婷婷色网视频在线播放 | 国产精品一区二区三区视频免费 | 狠狠躁夜夜a产精品视频 | 日韩两性视频 | 久久国产精品99久久久久久老狼 | 九九久久免费 | 日韩va欧美va亚洲va久久 | 精品黄色在线观看 | 国产精品久久久久久久久婷婷 | av大全在线观看 | 超级碰99| 99久久精品国产欧美主题曲 | 日韩电影在线看 | 国产精品免费在线播放 | 天天操天天操天天操天天操天天操 | 亚洲黄色av网址 | 亚州精品天堂中文字幕 | 国产精品人成电影在线观看 | 久久久久美女 | 97国产小视频 | 久久精品国产亚洲精品 | 国产高清在线观看 | 亚洲精品视频在线观看视频 | 少妇按摩av| 亚洲伦理一区 | 中文字幕免费不卡视频 | 97视频在线免费播放 | 亚洲高清久久久 | 免费看wwwwwwwwwww的视频 久久久久久99精品 91中文字幕视频 | 成人禁用看黄a在线 | 久色婷婷 | 国产视频一区精品 | 日日夜夜操操 | 欧美另类xxxx | 国产高清视频免费观看 | 狠狠色丁香久久综合网 | 日韩精品综合在线 | 激情影音先锋 | 亚洲精选99 | 色五月激情五月 | 色网站免费在线看 | 天天激情天天干 | 中文字幕美女免费在线 | av高清网站在线观看 | 免费日韩视频 | 国产精品成久久久久 | 欧美精品在线观看免费 | 欧美日韩电影在线播放 | 午夜精品久久久久久久久久久久 | 国产精品欧美久久 | 欧美一级视频免费 | 欧美aaa视频 | 欧美激情视频一区 | 特级黄色一级 | 夜夜澡人模人人添人人看 | 天天干天天天天 | 91色欧美 | 午夜精品福利在线 | 国产精品久久久久久av | 碰超在线| 欧美综合久久久 | 成人a在线观看 | 日韩精品一区二区三区丰满 | 国产日韩在线一区 | 黄色在线小网站 | 日韩精品 在线视频 | 丁香六月婷婷开心婷婷网 | 在线av资源 | 中文资源在线观看 | 手机在线看a | 久久精品之 | 久久电影国产免费久久电影 | 日本护士撒尿xxxx18 | 中文字幕av免费在线观看 | 91在线免费视频 | 国产精品久久久久久久久久99 | 97电影在线看视频 | 日韩另类在线 | 少妇bbbb搡bbbb桶 | 亚洲做受高潮欧美裸体 | 欧美夫妻性生活电影 | 国产免费高清视频 | a黄色 | 国产99在线免费 | 亚洲情影院 | 欧美精品国产综合久久 | 国产亚洲欧美在线视频 | 九九热免费精品视频 | 91亚洲精品国偷拍 | 99999精品| 韩日视频在线 | 在线观看免费日韩 | 国产69精品久久99的直播节目 | 草樱av | 国产夫妻性生活自拍 | 久久avav| 久久精品免费播放 | 亚洲精品国精品久久99热一 | 成人小视频在线 | 欧美色综合 | 国产在线观看午夜 | 亚洲在线高清 | 久久国产精品免费 | 天天干天天拍天天操天天拍 | 天天干人人干 | 玖玖视频精品 | 天天天色综合a | 三级黄色在线观看 | 中文字幕网站 | 日本久久精品视频 | 在线精品视频在线观看高清 | 六月丁香婷| 成人久久亚洲 | 97av免费视频 | 国产综合片 | 亚洲情婷婷 | 在线观看色网 | 久久视频国产精品免费视频在线 | 日韩网站在线观看 | 黄色av一区 | 国产高清区 | 99精品一区二区 | 五月婷婷伊人网 | 色免费在线 | 欧美日韩亚洲在线观看 | 一级黄色片在线播放 | 91看片看淫黄大片 | 国产午夜精品视频 | 精品国产午夜 | 探花视频在线版播放免费观看 | 最近中文字幕免费观看 | 国产女人40精品一区毛片视频 | 久久99网| 国产精品一区二区三区在线看 | 午夜在线看片 | 日韩免费在线视频 | 中文av在线播放 | 国产第一福利 | 亚洲丁香久久久 | 操一草| 日韩在线视频网站 | 在线日韩中文字幕 | 91视频 - 88av| 国产一区二三区好的 | 人人干干人人 | 久久99深爱久久99精品 | 九九热有精品 | 午夜精品一区二区三区免费视频 | 美女视频黄频大全免费 | 在线免费观看黄色大片 | 亚洲精品视频在线观看免费视频 | 91精品国产入口 | 久久久久免费精品国产小说色大师 | 在线免费国产视频 | 97操操 | 成人在线播放av | 亚洲精品麻豆视频 | 操夜夜操| 成人黄大片 | 草在线视频 | wwwwww国产 | 97成人精品视频在线播放 | 夜夜爱av| 日b视频国产 | 天天爱天天 | 国产成人av免费在线观看 | 国产一区二区久久久久 | 亚洲精品9| 日韩精品久久一区二区 | 99精品欧美一区二区三区黑人哦 | 成人黄色免费在线观看 | 精品视频不卡 | 五月综合婷 | 日韩有码在线观看视频 | 九九九毛片 | 嫩草伊人久久精品少妇av | 中文字幕永久在线 | 在线播放国产精品 | 亚洲精品www久久久久久 | 国产麻豆精品95视频 | 国语久久| 欧美日韩国产在线 | 毛片网站在线观看 | 亚洲一级性 | 91大神精品视频在线观看 | 国产九色在线播放九色 | 探花视频在线版播放免费观看 | 婷婷深爱网 | 国产精品美女在线 | 免费在线观看不卡av | 丁香av| 成人av久久| 精品久久久久久久久亚洲 | 免费一级日韩欧美性大片 | 亚洲午夜精品久久久久久久久久久久 | 久久精品麻豆 | 精品国产一区二区三区四区vr | 亚洲最快最全在线视频 | 国产亚洲精品久久久久久久久久久久 | 黄色在线观看免费 | 亚洲欧美精品一区二区 | 久久av免费| 狠狠狠狠狠狠干 | 一区二区三区观看 | 一级片免费在线 | 欧美俄罗斯性视频 | 免费欧美| 在线观看日本高清mv视频 | 免费看成年人 | 国产精品成人在线观看 | 91av视频在线观看免费 | 免费精品久久久 | 亚洲在线网址 | 一级精品视频在线观看宜春院 | 国产成a人亚洲精v品在线观看 | 91大片网站| 国产精品免费观看视频 | 欧美一级性视频 | 日本在线视频网址 | 成全在线视频免费观看 | 蜜桃av久久久亚洲精品 | 亚洲国产成人精品电影在线观看 | 久久激情视频 久久 | 天天摸日日操 | 久久精品女人毛片国产 | 成人一级免费电影 | 有码视频在线观看 | 日日狠狠| 国产精品一区二区久久精品爱微奶 | 日韩欧在线 | 久久久首页 | 免费精品在线观看 | 中文字幕网址 | 天天拍天天色 | 日韩动态视频 | 国产黄色精品网站 | 一区电影 | 成人一级电影在线观看 | 免费国产一区二区 | 一本一道久久a久久精品 | 久草综合在线观看 | 亚洲国产免费看 | 精品亚洲va在线va天堂资源站 | 国产资源av| 欧美贵妇性狂欢 | 偷拍福利视频一区二区三区 | 国产一级视频 | 98福利在线 | 黄色片免费看 | 欧美美女视频在线观看 | 天天爽网站 | 亚洲电影图片小说 | 夜夜躁日日躁狠狠久久av | a天堂中文在线 | 欧美精品久久久久久久久老牛影院 | 在线观看免费成人 | 亚洲另类久久 | 国产精品99精品久久免费 | 97超碰伊人 | 免费亚洲黄色 | 国产精品一区二区久久久 | 国产在线999 | 久久久人| 三级av片 | 日韩在线观看中文字幕 | 97综合网 | 一级一级一片免费 | 天天操综合 | 色综合久久久久综合 | 久久久资源 | 91丨九色丨国产在线观看 | 国产成人久久精品亚洲 | 成人国产网站 | 在线成人av | 天天插伊人 | 亚洲免费在线观看视频 | 久久久国产一区二区三区 | 欧美另类巨大 | www.久久久.cum| 亚洲精品国产综合99久久夜夜嗨 | 字幕网在线观看 | 91视频88av| 免费看黄色小说的网站 | 国产精品麻豆三级一区视频 | 中文字幕高清有码 | 日韩欧美v | 91视频在线观看大全 | 色综合久久综合网 | 亚洲免费观看视频 | 97在线免费视频 | 久久精品婷婷 | 黄色亚洲大片免费在线观看 | 欧美视频18 | 久久91久久久久麻豆精品 | 久久成人国产精品一区二区 | 精品一区二区三区香蕉蜜桃 | 91成人精品 | 93久久精品日日躁夜夜躁欧美 | 欧美一区二区视频97 | 亚洲成av人片在线观看www | 麻豆视频免费观看 | 99久久99久久精品国产片果冰 | 激情五月婷婷激情 | 黄色免费av | 久久久精品免费看 | 在线观看精品国产 | 中文字幕日韩精品有码视频 | 国产精品自拍av | 精品无人国产偷自产在线 | 国产成人中文字幕 | 国产精品破处视频 | 久久久久免费电影 | 欧美日本高清视频 | www.91成人 | 午夜视频免费在线观看 | 日韩成人免费电影 | 久久精品www人人爽人人 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产操在线 | 国产成人精品av在线观 | 久久激五月天综合精品 | 在线观看av网 | 免费看在线看www777 | 一区二区三区手机在线观看 | 亚洲成av人片 | 国产黄网站在线观看 | 97av在线视频| 国产精品va | 亚洲午夜久久久久久久久电影网 | 国产中文自拍 | 美女在线观看网站 | 色婷婷亚洲| 亚洲精品字幕 | 91网址在线看 | 国产日韩精品一区二区在线观看播放 | 四川妇女搡bbbb搡bbbb搡 | 亚洲激情六月 | 91精品视频一区 | 国产中文欧美日韩在线 | 免费毛片一区二区三区久久久 | 亚洲一区二区三区在线看 | 亚洲欧美激情插 | 亚洲日本在线视频观看 | 国产精品一区二区免费 | 国产精品久久久久久久久久久久久 | 国内精品在线看 | 四虎永久免费网站 | 在线观看日本高清mv视频 | 欧美在线一级片 | 久久国产精品一区二区三区四区 | 天天综合网久久 | 国产精品乱码久久久久久1区2区 | 狠狠狠色丁香婷婷综合激情 | 国产在线专区 | 国产中文在线视频 | 精品成人免费 | 激情一区二区三区欧美 | 999在线观看视频 | 香蕉视频国产在线观看 | 亚洲视频电影在线 | 天天鲁一鲁摸一摸爽一爽 | av资源在线观看 | 西西4444www大胆视频 | 久久精品99国产 | 国产精品入口a级 | 五月婷婷操 | 91麻豆国产福利在线观看 | 欧美激情第一区 | 免费观看成人av | 成人网色| 日韩在线免费高清视频 | 久久www免费视频 | 婷婷激情5月天 | 亚洲精品视频一 | 69久久久久久久 | 成人激情开心网 | 国产不卡在线观看视频 | 黄色一级在线观看 | 毛片网站观看 | 国产999视频 | 国产字幕在线观看 | 久久久黄色免费网站 | 国产精品第 | 亚洲国产精品999 | 五月婷婷在线观看视频 | 色综合天 | 国产成人精品三级 | 亚洲永久精品视频 | 久久黄色免费观看 | 国产日韩精品在线观看 | 亚洲乱码在线观看 | 91在线永久 | 九九免费精品视频在线观看 | 免费情缘| 成人资源在线播放 | 欧美极品裸体 | 首页国产精品 | 午夜国产福利在线观看 | 欧美a级免费视频 | 超碰个人在线 | 色五月成人 | 精品久久久久久久久久久院品网 | 91av视频| 国产99免费 | 美女黄频视频大全 | 91国内在线视频 | 亚洲一区尤物 | 亚洲资源一区 | 亚洲精品在线免费 | 看国产黄色片 | 狠狠色婷婷丁香六月 | 久久精品5 | 国产 av 日韩 | 97在线视频免费观看 | 欧美日产在线观看 | 91社区国产高清 | 99精品一区二区三区 | 亚洲精品高清一区二区三区四区 | 精品成人网 | 欧美analxxxx| 黄色大片入口 | 久草视频视频在线播放 | 在线免费观看黄色 | 国产99久久久精品视频 | 国产96在线 | 国产精品美女久久久久久久网站 | 91中文字幕在线 | 精品视频资源站 | 99久久精品国产一区二区三区 | 亚洲精选视频免费看 | 色综合天天综合 | 五月婷婷综合在线观看 | 天天干天天弄 | 午夜三级毛片 | 国产又粗又硬又爽视频 | 99re国产| 欧美 日韩 性 | 青青看片 | 亚洲精品乱码久久久久久蜜桃91 | 久久99精品久久只有精品 | 亚洲好视频| 中文字幕区 | 亚洲欧美日韩一区二区三区在线观看 | 欧美精品乱码久久久久久按摩 | 国产精品2018 | 婷婷国产视频 | 美女露久久 | 国产精品一区二区在线观看免费 | 国产青草视频在线观看 | 国产3p视频| 九七视频在线观看 | 亚洲成人av片在线观看 | 精品国产免费一区二区三区五区 | 91亚洲精品乱码久久久久久蜜桃 | 五月激情av | 伊人资源视频在线 | 国产高清视频网 | 日韩中文字幕免费在线观看 | 国产成人精品电影久久久 | 日韩高清一二三区 | 91精品少妇偷拍99 | 五月婷婷激情五月 | 又黄又刺激视频 | 麻豆久久久久 | 五月激情姐姐 | 久久精品人人做人人综合老师 | 国产高清成人av | 99九九免费视频 | 久草网首页 | 日操干| 夜夜狠狠| 福利片免费看 | 日韩av女优视频 | 国产69熟 | 国产天天综合 | 九九精品久久 | av导航福利 | 日韩手机视频 | 欧美一级片在线观看视频 | 精品 激情 | 亚洲国产激情 | 在线成人中文字幕 | av在线网站观看 | 国产小视频网站 | 在线99热 | 96精品高清视频在线观看软件特色 | 黄色网www| 色婷婷国产精品 | 最新av电影网站 | 欧美激情精品久久久久久 | 丁香六月综合网 | 亚洲视频1区2区 | 久草资源在线观看 | 国产精品精品国产婷婷这里av | 黄色福利网站 | 欧美a级免费视频 | 国产99久久久国产 | 91网在线| 亚洲精品国偷自产在线91正片 | 91亚洲精品在线 | 韩国精品一区二区三区六区色诱 | 亚洲视频资源在线 | 91福利试看 | 亚洲另类视频 | 97国产精品亚洲精品 | 日韩精品一区二区三区高清免费 | 99久久夜色精品国产亚洲96 | 成人午夜网址 | 亚洲国产偷 | 伊人网av| 欧美日韩国产一区二 | 操操操av | 国产精品mm| 福利网在线 | 丁香五香天综合情 | 夜夜爱av | 91日本在线播放 | 激情综合电影网 | 国产美女视频网站 | 国产999视频 | 日日摸日日添夜夜爽97 | 五月综合网 | 黄色片网站大全 | 欧美午夜精品久久久久 | 亚洲在线成人精品 | 久久久免费精品 | 五月开心色 | 亚洲黄色成人网 | 天无日天天操天天干 | 热re99久久精品国产99热 | 欧美不卡视频在线 | 久久久亚洲网站 | 色插综合| 亚洲综合国产精品 | 中文字幕第一页在线vr | 中文网丁香综合网 | 国产精品一区二区av影院萌芽 | 国产免费高清视频 | 伊人电影在线观看 | 色人久久 | 黄色在线视频网址 | 在线免费观看亚洲视频 | 91av在线免费| 国产在线一卡 | 激情视频久久 | 国内精品久久久 | 国产一区二区在线免费播放 | 最近日本中文字幕 | 97视频免费观看 | 久草资源在线观看 | 国产精品久久久久av免费 |