久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

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

编程问答

[转]AsyncDisplayKit 教程:达到 60 FPS 的滚动帧率

發(fā)布時間:2024/8/24 编程问答 36 如意码农
生活随笔 收集整理的這篇文章主要介紹了 [转]AsyncDisplayKit 教程:达到 60 FPS 的滚动帧率 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

[原文:https://github.com/nixzhu/dev-blog/blob/master/2014-11-22-asyncdisplaykit-tutorial-achieving-60-fps-scrolling.md]

Facebook 的 Paper 團隊給我們帶來另一個很棒的庫:AsyncDisplayKit。這個庫能讓你通過將圖像解碼、布局以及渲染操作放在后臺線程,從而帶來超級響應(yīng)的用戶界面,也就是說不再會因界面卡頓而阻斷用戶交互。既然這么厲害,那就在本教程里學一下它吧。

例如,對于非常復(fù)雜的界面,你可以使用 AsyncDisplayKit 構(gòu)建它而得到一種如絲般順滑的,60幀每秒的滑動體驗。而平常的 UIKit 優(yōu)化就不太可能克服這樣的性能挑戰(zhàn)。

在本教程中,你將從一個初始項目開始,它主要有一個 UICollectionView 的滑動問題,而使用 AsyncDisplayKit 將大大提高其滑動性能。一路上,你將學會如何在舊項目中使用 AsyncDisplayKit。

注意:在開始本教程之前,你應(yīng)該已熟悉 Swift、Core Animation 以及 Core Graphics。

開始

開始之前,先看看 AsyncDisplayKit 的介紹。以對它有個簡要的概念,知道它是要解決什么問題。

準備好了后就下載初始項目吧。你需要使用 Xcode 6.1 和 iOS 8.1 SDK 來編譯它。

注意:本教程的代碼使用 AsyncDisplayKit 1.0 來編寫。這個版本已經(jīng)被包含在初始項目中了。

你要研究的項目是由 UICollectionView 制作的卡片式界面來描述不同的雨林動物。每張信息卡包括一個圖片、名字以及一個對雨林動物的描述。卡片的背景圖是主圖片的模糊版。視覺設(shè)計的細節(jié)保證了文字的清晰易讀。

在 Xcode 中,打開初始項目里的 Layers.xcworkspace 。

在本教程里,請遵循以下原則以體會 AsyncDisplayKit 的那些十分吸引人的好處。

將應(yīng)用運行在真機上。在模擬器里運行很難看出性能改善。

應(yīng)用是通用的,但在 iPad 上看起來最好。

最后,要真正感激這個庫能為你所做的事情,請盡量在最舊的能運行 iOS 8.1 的設(shè)備上運行本應(yīng)用。第三代的 iPad 最好,因為它雖有視網(wǎng)膜屏幕,但運行得不是很快。

一旦你選定了設(shè)備,那就編譯并運行本項目。你會看到如下界面:

試著滑動 Collection View 并注意那可憐的幀率。在第三代 iPad 上,幀率大概只有 15-20 FPS,實在丟掉太多幀了。在本教程的最后,你能在 60 FPS (或非常接近)的幀率上滑動它。

注意:你所看到的圖像都在 App 的 asset 目錄里,并不是從網(wǎng)絡(luò)上獲取的。

測量響應(yīng)速度

在一個舊項目中使用 AsyncDisplayKit 前,你應(yīng)該通過 Instruments 測量你的 UI 的性能,這樣才有一個基準線以便對比改動的效果。

最重要的是,你要知道是 CPU-綁定 還是 GPU-綁定。也就是說,是 CPU 還是 GPU 拉低了應(yīng)用的幀率。這個信息會告訴你該充分利用 AsyncDisplayKit 的哪個特性以優(yōu)化應(yīng)用的性能。

如果你有時間,看看之前提到的 WWDC 2012 session 和/或在真實設(shè)備上使用 Instruments 來評估初始項目的時間曲線。滑動性能是 CPU-綁定 的。你能猜到是什么原因?qū)е铝?Collection View 丟掉這么多幀嗎?

丟幀是因為模糊 cell 的背景圖像時阻塞了主線程。

為項目準備好使用 AsyncDisplayKit

在舊項目里使用 AsyncDisplayKit,歸結(jié)起來就是使用 Display Node 層次結(jié)構(gòu)替換視圖層次結(jié)構(gòu)和/或 Layer 樹。各種 Display Node 是 AsyncDisplayKit 的關(guān)鍵所在。它們位于視圖之上,而且是線程安全的,也就是說之前在主線程才能執(zhí)行的任務(wù)現(xiàn)在也可以在非主線程執(zhí)行。這就能減輕主線程的工作量以執(zhí)行其他操 作,例如處理觸摸事件,或如在本應(yīng)用的情況里,處理 Collection View 的滑動。

這就意味著在本教程里,你的第一步是移除視圖層次結(jié)構(gòu)。

移除視圖層次結(jié)構(gòu)

打開 RainforestCardCell.swift 并刪除 awakeFromNib() 中所有的 addSubview(...) 調(diào)用,然后得到如下:

1
2
3
4
5
6
override func awakeFromNib() {
  super.awakeFromNib()
  contentView.layer.borderColor =
    UIColor(hue: 0, saturation: 0, brightness: 0.85, alpha: 0.2).CGColor
  contentView.layer.borderWidth = 1
}

接下來,替換 layoutSubviews() 的內(nèi)容如下:

1
2
3
override func layoutSubviews() {
  super.layoutSubviews()
}

再將 configureCellDisplayWithCardInfo(cardInfo:) 的內(nèi)容替換如下:

1
2
3
4
5
func configureCellDisplayWithCardInfo(cardInfo: RainforestCardInfo) {
  //MARK: Image Size Section
  let image = UIImage(named: cardInfo.imageName)!
  featureImageSizeOptional = image.size
}

刪除 RainforestCardCell 的所有視圖屬性,只留一個如下:

1
2
3
4
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  ...
}

最后,編譯并運行,你看到的就全是空空如也的卡片:

現(xiàn)在所有的 cell 都空了,滑動起來超級順滑。你的目標是保證之后添加回取代各視圖的 node 后,滑動依然順滑。

你可用 Instruments 的  Core Animation 模版在真機上檢測應(yīng)用的性能,看看你的改動如何影響幀率。

添加一個占位圖

打開 RainforestCardCell.swift ,給 RainforestCardCell 添加一個可選的 CALayer 變量,名為 placeholderLayer:

1
2
3
4
5
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  var placeholderLayer: CALayer!
  ...
}

你之所以需要一個占位圖是因為顯示會異步完成,如果這個過程需要些時間,那用戶就會看到空的 cell —— 這并不愉快。就如同如果你要從網(wǎng)絡(luò)上獲取圖像,那么就需要用占位圖來填充 cell,這能讓你的用戶知道內(nèi)容還沒有準備好。雖然在我們這種情況里,你是在后臺線程繪制而不是從網(wǎng)絡(luò)下載。

在 awakeFromNib() 里,刪除 contentView 的 border 設(shè)置再創(chuàng)建并配置一個 placeholderLayer。將其添加到 cell 的 contentView 的 Layer 上。現(xiàn)在這個方法如下:

1
2
3
4
5
6
7
8
9
10
override func awakeFromNib() {
  super.awakeFromNib()
 
  placeholderLayer = CALayer()
  placeholderLayer.contents = UIImage(named: "cardPlaceholder")!.CGImage
  placeholderLayer.contentsGravity = kCAGravityCenter
  placeholderLayer.contentsScale = UIScreen.mainScreen().scale
  placeholderLayer.backgroundColor = UIColor(hue: 0, saturation: 0, brightness: 0.85, alpha: 1).CGColor
  contentView.layer.addSublayer(placeholderLayer)
}

在 layoutSubviews() 里,你需要布局 placeholderLayer。替換這個方法為:

1
2
3
4
5
override func layoutSubviews() {
  super.layoutSubviews()
 
  placeholderLayer?.frame = bounds
}

編譯并運行,你從虛無的邊緣回來了:

樸素的 CALayer 不是由 UIView 支持的,當它們改變 frame 時,默認會有隱式動畫。這就是為何你看到 layer 在布局時放大。要修復(fù)這個問題,改動 layoutSubviews 如下:

1
2
3
4
5
6
7
8
override func layoutSubviews() {
  super.layoutSubviews()
 
  CATransaction.begin()
  CATransaction.setValue(kCFBooleanTrue, forKey: kCATransactionDisableActions)
  placeholderLayer?.frame = bounds
  CATransaction.commit()
}

編譯并運行,問題解決了。

現(xiàn)在占位圖不會亂動,不再動畫它們的 frame 了。

第一個 Node

重建 App 的第一步是給每一個 UICollectionView cell 添加一個背景圖片 Node,步驟如下:

1. 創(chuàng)建、布局并添加一個圖像 Node 到 UICollectionView cell;

2. 處理 cell 重用 Node 和它們的 layer;以及

3. 模糊圖像 Node

但在做之前,打開 Layers-Bridging-Header.h 并導(dǎo)入 AsyncDisplayKit :

1
#import

這會讓所有的 Swift 文件都能訪問 AsyncDisplayKit 的各種類。

編譯一下,確保沒有錯誤。

方向:雨林 Collection View 結(jié)構(gòu)

現(xiàn)在,我們來看看 Collection View 的組成:

· View Controller :RainforestViewController 沒有什么花哨的東西。它只是為所有的雨林卡片獲取一個數(shù)據(jù)數(shù)組,并為 UICollectionView 實現(xiàn) Data Source。事實上,你不需要花太多時間到 View Controller 上。

· Data Source :大部分時間都將花在 cell 類 RainforestCardCell 上。View Controller 出隊每個 cell 并將雨林卡片的數(shù)據(jù)用 configureCellDisplayWithCardInfo(cardInfo:) 傳給它。cell 就使用這個數(shù)據(jù)來配置自身。

· Cell :在 configureCellDisplayWithCardInfo(cardInfo:) 里,cell 創(chuàng)建、配置、布局以及添加 Node 到它自己身上。這就意味著每次 View Controller 出隊一個 cell,這個 cell 就會創(chuàng)建并添加給它自己一個新的 Node 層次結(jié)構(gòu)。

如果你使用 View 而不是 Node,那么這樣做對于性能來說就不是最佳策略。但因為你可以異步地創(chuàng)建、配置以及布局,而且 Node 也是異步地繪制的,所以這不會是一個問題。真正的難點是在 cell 準備重用時取消任何在進行的異步操作并移除舊 Node 。

注意 :本教程的這個策略來添加 Node 到 cell 還算 OK。對于精通 AsyncDisplayKit 來說,這是很好的第一步。

然而,在實際生產(chǎn)中,你最好使用 ASRangeController 來緩存你的 Node,這樣你就不用每次在 cell 重用時重建它的 Node 層次結(jié)構(gòu)。ASRangeController 超出了本教程的范圍,但若你想了解更多的信息,看看頭文件 ASRangeController.h 的注釋吧。

再注意一下:1.1 版的 AsyncDisplayKit (本教程編寫時還未放出,但會在此后不久放出)包含有 ASCollectionView。使用 ASCollectionView 會讓本 App 的整個 Collection View 都由 Display Node 控制。而在本教程中,每個 cell 會包含一個 Display Node 層次結(jié)構(gòu)。如上面所解釋的,這能工作,但如果使用 ASCollectionView 可能會更好。給力的 ASCollectionView!

OK,該動手了。

添加背景圖片 Node

現(xiàn)在你要走一遍用 Node 配置 cell 的過程,一次一步:

打開 RainforestCardCell.swift 并替換 configureCellDisplayWithCardInfo(cardInfo:) 為:

1
2
3
4
5
6
7
8
9
10
func configureCellDisplayWithCardInfo(cardInfo: RainforestCardInfo) {
  //MARK: Image Size Section
  let image = UIImage(named: cardInfo.imageName)!
  featureImageSizeOptional = image.size
 
  //MARK: Node Creation Section
  let backgroundImageNode = ASImageNode()
  backgroundImageNode.image = image
  backgroundImageNode.contentMode = .ScaleAspectFill
}

這就創(chuàng)建并配置了一個 ASImageNode 常量,叫做 backgroundImageNode。

注意:確保包含 //MARK: 注釋,這樣更容易看清代碼位置。

AsyncDisplayKit 帶有好幾種 Node 類型,包括 ASImageNode,用于顯示圖片。它相當于 UIImageView,除了 ASImageNode 是默認異步地解碼圖片。

添加如下代碼到 configureCellDisplayWithCardInfo(cardInfo:) 底部:

1
backgroundImageNode.layerBacked = true

這讓 backgroundImageNode 變?yōu)?Layer 支持的 Node。

Node 可由 UIView 支持或 CALayer 支持。當 Node 需要處理事件時(例如觸摸事件),你就要使用  UIView 支持的 Node。如果你不需要處理事件,只需要顯示一下內(nèi)容,那使用 Layer 支持的 Node 會更加輕量,因此可以獲得一個小的性能提升。

因為本教程的 App 不需要處理事件,所以你可讓所有的 Node 都設(shè)置為 Layer 支持的。在上面的代碼中,由于 backgroundImageNode 為 Layer 支持的,AsyncDisplayKit 會創(chuàng)建一個 CALayer 用于雨林動物圖像內(nèi)容的顯示。

繼續(xù) configureCellDisplayWithCardInfo(cardInfo:) 并添加如下代碼:

1
2
//MARK: Node Layout Section
backgroundImageNode.frame = FrameCalculator.frameForContainer(featureImageSize: image.size)

這里使用 FrameCalculator 為 backgroundImageNode 布局。

FrameCalculator  是一個幫助類,它包裝了cell 的布局,為每個 Node 返回 frame。注意所有的東西都是手動布局的, 沒有使用 Auto Layout 約束 。如果你需要構(gòu)建自適應(yīng)布局或者本地化驅(qū)動的布局,那就要注意,因為你不能給 Node 添加約束。

接下來,添加如下代碼到 configureCellDisplayWithCardInfo(cardInfo:) 底部:

1
2
//MARK: Node Layer and Wrap Up Section
self.contentView.layer.addSublayer(backgroundImageNode.layer)

這句將 backgroundImageNode 的 Layer 添加到 cell contentView 的 Layer 上。

注意,AsyncDisplayKit 會為 backgroundImageNode 創(chuàng)建一個 Layer。然而,你必須要將 Node 放到某個 Layer 樹中才能在屏幕上顯示。這個 Node 會異步地繪制,所以直到繪制完成,它的內(nèi)容都不會顯示,盡管它的 Layer 已經(jīng)在一個 Layer 樹中。

從技術(shù)角度來說, Layer 一直都存在。但渲染圖像是異步進行的。Layer 初始化時沒有內(nèi)容(例如是透明的)。一旦渲染完成,Layer 的 contents 就會更新為包含圖像內(nèi)容。

在這個點,cell 的 contentView 的 Layer 將會包含兩個 Sublayer:一個占位圖和 Node 的 Layer。在 Node 完成繪制前,只有占位圖會顯示。

注意到 configureCellDisplayWithCardInfo(cardInfo:) 會在每次 cell 出隊時被調(diào)用。每次 cell 被回收,這個邏輯會添加一個新的 Sublayer 到 cell 的 contentView Layer 上。不要擔心,你很快會解決這個問題。

回到 RainforestCardCell.swift 開頭,給 RainforestCardCell 添加一個 ASImageNode 變量存為屬性 backgroundImageNode,如下:

1
2
3
4
5
6
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  var placeholderLayer: CALayer!
  var backgroundImageNode: ASImageNode? ///< ADD THIS LINE
  ...
}

你之所以需要這個屬性是因為必須要有某個東西將 backgroundImageNode 的引用保留住,否則 ARC 就會將其釋放,也就不會有任何東西顯示出來——即使 Node 的 Layer 在一個 Layer 樹中,你依然需要保留 Node。

在 configureCellDisplayWithCardInfo(cardInfo:) 底部的 Node Layer and Wrap Up Section ,設(shè)置 cell 新的 backgroundImageNode  為之前的 backgroundImageNode:

1
self.backgroundImageNode = backgroundImageNode

下面是完整的 configureCellDisplayWithCardInfo(cardInfo:) 方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
func configureCellDisplayWithCardInfo(cardInfo: RainforestCardInfo) {
  //MARK: Image Size Section
  let image = UIImage(named: cardInfo.imageName)!
  featureImageSizeOptional = image.size
 
  //MARK: Node Creation Section
  let backgroundImageNode = ASImageNode()
  backgroundImageNode.image = image
  backgroundImageNode.contentMode = .ScaleAspectFill
  backgroundImageNode.layerBacked = true
 
  //MARK: Node Layout Section
  backgroundImageNode.frame = FrameCalculator.frameForContainer(featureImageSize: image.size)
 
  //MARK: Node Layer and Wrap Up Section
  self.contentView.layer.addSublayer(backgroundImageNode.layer)
  self.backgroundImageNode = backgroundImageNode
}

編譯并運行,觀察 AsyncDisplayKit 是如何異步地使用圖像設(shè)置 Layer 的 contents 的。這能讓你在 CPU 還在繪制 Layer 的內(nèi)容的同時上下滑動界面。

如果你運行在舊設(shè)備上,注意圖像是如何彈出到位置——這是爆米花特效,但不總是讓人喜歡!本教程的最后一節(jié)會搞定這個不令人愉快的彈出效果,給你展示如何讓圖像自然地淡入,如同搖滾巨星。

如之前所討論的,新的 Node 會在每次 cell 被重用時創(chuàng)建。這并不很理想,因為這意味著新的 Layer 會在每次 cell 被重用時加入。

如果你想看看 Sublayer 堆積太多的影響,那就不停的滑上滑下多次,然后加斷點打印出 cell 的 contentView 的 Layer 的 sublayers 屬性。你會看到很多 Layer,這并不好。

處理 Cell 重用

繼續(xù) RainforestCardCell.swift ,給 RainforestCardCell 添加一個叫做 contentLayer 的 CALayer 屬性。這個屬性也是一個可選類型:

1
2
3
4
5
6
7
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  var placeholderLayer: CALayer!
  var backgroundImageNode: ASImageNode?
  var contentLayer: CALayer? ///< ADD THIS LINE
  ...
}

你將使用此屬性去移除 cell 的 contentView 的 Layer 樹中舊的 Node Layer。雖然你可以簡單地保留 Node 并訪問其 Layer 屬性,但上面的寫法更加明確。

添加如下代碼到 configureCellDisplayWithCardInfo(cardInfo:) 結(jié)尾:

1
self.contentLayer = backgroundImageNode.layer

這句讓  backgroundImageNode 的 Layer 保留到 contentLayer 屬性。

替換 prepareForReuse() 的實現(xiàn)如下:

1
2
3
4
override func prepareForReuse() {
  super.prepareForReuse()
  backgroundImageNode?.preventOrCancelDisplay = true
}

因為 AsyncDisplayKit 能夠異步地繪制 Node,所以 Node 讓你能預(yù)防從頭繪制或取消任何在進行的繪制。無論是你需要預(yù)防或取消繪制,都可將 preventOrCancelDisplay 設(shè)置為 true,如上面代碼所示。在本例中,你要在 cell 被重用前取消任何正在進行的繪制活動。

接下來,添加如下代碼到 prepareForReuse() 尾部:

1
contentLayer?.removeFromSuperlayer()

這將  contentLayer 從其 Superlayer (也就是 contentView 的 Layer)中移除。

每次一個 cell 被回收時,這個代碼就移除 Node 的舊 Layer ,因而解決了堆積問題。所以在任何時間,你的 Node 最多只有兩個 Sublayer:占位圖和 Node 的 Layer。

接下來添加如下代碼到 prepareForReuse() 尾部:

1
2
contentLayer = nil
backgroundImageNode = nil

這確保 cell 釋放它們的引用,這樣如有必要,ARC 才好做清理工作。

編譯并運行。這次,沒有 Sublayer 會堆積的問題,且所有不必要的繪制都會被取消。

是時候來點兒模糊效果了,Baby,模糊哦。

模糊圖像

要模糊圖像,你要添加一個額外的步驟到圖像 Node 的顯示過程里。

繼續(xù) RainforestCardCell.swift ,在 configureCellDisplayWithCardInfo(cardInfo:) 的設(shè)置  backgroundImageNode.layerBacked 的后面,添加如下代碼:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
backgroundImageNode.imageModificationBlock = { input in
  if input == nil {
    return input
  }
  if let blurredImage = input.applyBlurWithRadius(
    30,
    tintColor: UIColor(white: 0.5, alpha: 0.3),
    saturationDeltaFactor: 1.8,
    maskImage: nil, 
    didCancel:{ return false }) {
      return blurredImage
  else {
    return image
  }
}

ASImageNode 的 imageModificationBlock 給你一個機會在顯示之前去處理底層的圖像。這是非常實用的功能,它讓你能對圖像 Node 做一些操作,例如添加濾鏡等。

在上面的代碼里,你使用 imageModificationBlock 來為 cell 的背景圖像應(yīng)用模糊效果。關(guān)鍵點就是圖像 Node 將會繪制它的內(nèi)容并在后臺執(zhí)行這個閉包,而主線程依然順滑流暢。這個閉包接受原始的  UIImage 并返回一個修改過的  UIImage。

上面的代碼使用了  UIImage 的模糊 category,它由 Apple 在 WWDC 2013 提供,使用了 Accelerate framework 在 CPU 上模糊圖像。因為模糊會消耗很多時間和內(nèi)存,這個版本的 category 被修改為包含了取消機制。這個模糊方法將定期調(diào)用 didCancel 閉包來決定是否應(yīng)該要停止模糊。

現(xiàn)在,上面的代碼給  didCancel 簡單地返回 false。之后你會重寫 didCancel 閉包。

注意:還記得第一次運行 App 時 Collection View 那可憐的滑動效果嗎?模糊方法阻塞了主線程。通過使用 AsyncDisplayKit 將模糊放入后臺,你就大幅度地提高了 Collection View 的滑動性能。簡直天壤之別。

編譯并運行,觀察模糊效果:

注意你可以如何非常流暢地滑動 Collection View。

當 Collection View 出隊一個 cell 時,一個模糊操作將開始于后臺線程。當用戶快速滑動時,Collection View 會重用每個 cell 多次,并開始許多模糊操作。我們的目標是在 cell 準備被重用時取消正在進行中的模糊操作。

你已經(jīng)在 prepareForReuse() 里取消了 Node 的繪制操作 ,但一旦控制被移交給處理你圖像修改的閉包,那就是你的責任來處理 Node 的 preventOrCancelDisplay 設(shè)置,你現(xiàn)在就要做。

取消模糊操作

要取消進行中的模糊操作,你需要實現(xiàn)模糊方法的 didCancel 閉包。

添加一個捕捉列表到 imageModificationBlock 以捕捉一個 backgroundImageNode 的 weak 引用:

1
2
3
backgroundImageNode.imageModificationBlock = { [weak backgroundImageNode] input in
   ...
}

你需要 weak 引用來避免閉包和圖像 Node 之間的保留環(huán)問題。你將使用這個 weak  backgroundImageNode 來確定是否要取消模糊操作。

是時候構(gòu)建模糊取消閉包了。添加下面代碼到 imageModificationBlock:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
backgroundImageNode.imageModificationBlock = { [weak backgroundImageNode] input in
  if input == nil {
    return input
  }
 
  // ADD FROM HERE...
  let didCancelBlur: () -> Bool = {
    var isCancelled = true
    // 1
    if let strongBackgroundImageNode = backgroundImageNode {
      // 2
      let isCancelledClosure = {
        isCancelled = strongBackgroundImageNode.preventOrCancelDisplay
      }
 
      // 3
      if NSThread.isMainThread() {
        isCancelledClosure()
      else {
        dispatch_sync(dispatch_get_main_queue(), isCancelledClosure)
      }
    }
    return isCancelled
  }
  // ...TO HERE
 
  ...
}

下面解釋一下這些代碼:

1. 得到 backgroundImageNode 的 strong 引用,準備用其干活。如果 backgroundImageNode 在本次運行時消失,那么 isCancelled 將保持為 true,然后模糊操作會被取消。如果沒有 Node 需要顯示,自然沒有必要繼續(xù)模糊操作。

2. 在此你將操作取消檢查包在閉包里,因為一旦 Node 創(chuàng)建它的 Layer 或 View,那就只能在主線程訪問 Node 的屬性。由于你需要訪問 preventOrCancelDisplay,所以你必須在主線程檢查。

3. 最后,確保 isCancelledClosure 是在主線程運行,無論是已在主線程而直接運行,還是不在主線程而通過  dispatch_sync 來調(diào)度。它必須是一個同步的調(diào)度,因為我們需要閉包完成,并在 didCancelBlur 閉包返回之前設(shè)置 isCancelled。

在調(diào)用 applyBlurWithRadius(...) 中,修改傳遞給 didCancel 的參數(shù),替換一直返回  false 的閉包為你剛才定義并保留在 didCancelBlur 的閉包。

1
2
3
4
5
6
7
8
if let blurredImage = input.applyBlurWithRadius(
  30,
  tintColor: UIColor(white: 0.5, alpha: 0.3),
  saturationDeltaFactor: 1.8,
  maskImage: nil,
  didCancel: didCancelBlur) {
  ...
}

編譯并運行。你看你不會注意到太多差別,但現(xiàn)在任何在 cell 離開屏幕時還未完成的模糊都會被取消了。這就意味著設(shè)備比之前做得更少。你可能觀察到輕微的性能提升,特別是在較慢的設(shè)備如第三代 iPad 上運行時。

當然,若沒有東西在前面,背景就不是真正的背景!你的卡片需要內(nèi)容。通過下面四個小節(jié),你將學會:

· 創(chuàng)建一個容器 Node,它將所有的 Subnode 繪制到一個單獨的 CALayer 里;

· 構(gòu)建一個 Node 層次結(jié)構(gòu);

· 創(chuàng)建一個自定義的 ASDisplayNode  子類;并

· 在后臺構(gòu)建并布局 Node 層次結(jié)構(gòu);

做完這些,你就會得到一個看起來和添加 AsyncDisplayKit 之前一樣的 App,但有著黃油般順滑的滑動體驗。

柵格化的容器 Node

直到現(xiàn)在,你一直在操作 cell 內(nèi)的一個單獨的 Node。接下來,你將創(chuàng)建一個容器 Node,它會包含所有的卡片內(nèi)容。

添加一個容器 Node

繼續(xù) RainforestCardCell.swift ,在 configureCellDisplayWithCardInfo(cardInfo:) 的  backgroundImageNode.imageModificationBlock 后面以及 Node Layout Section 前面添加如下代碼:

1
2
3
4
5
6
//MARK: Container Node Creation Section
let containerNode = ASDisplayNode()
containerNode.layerBacked = true
containerNode.shouldRasterizeDescendants = true
containerNode.borderColor = UIColor(hue: 0, saturation: 0, brightness: 0.85, alpha: 0.2).CGColor
containerNode.borderWidth = 1

這就創(chuàng)建并配置了一個叫做 containerNode 的 ASDisplayNode 常量。注意這個容器的 shouldRasterizeDescendants,這是一個關(guān)于節(jié)點如何工作的提示以及一個如何讓它們工作得更好地機會。

如單詞 “descendants(子孫)” 所暗示的,你可以創(chuàng)建 AsyncDisplayKit Node 的層次結(jié)構(gòu)或樹,就如你可以創(chuàng)建 Core Animation Layer 的層次結(jié)構(gòu)一樣。例如,如果你有一個都是 Layer 支持的 Node 層次結(jié)構(gòu),那么 AsyncDisplayKit 將會為每個 Node 創(chuàng)建一個分離的 CALayer,Layer 層次結(jié)構(gòu)將會和 Node 層次結(jié)構(gòu)一樣,如同鏡像。

這聽起來很熟悉:它類似于當你使用普通的 UIKit 時,Layer 層次結(jié)構(gòu)鏡像于 View 層次結(jié)構(gòu)。然而,這個 Layer 的棧有一些不同的效果:

首先,因為是異步渲染,你就不會看到每個 Layer 一個接一個地顯示。當 AsyncDisplayKit 繪制完成每個 Layer,它馬上制作 Layer 的顯示內(nèi)容。所以如果你有一個 Layer 的繪制比其他 Layer 耗時更長,那么它將會在它們之后顯示。用戶會看到零碎的 Layer 組件,這個過程通常是不可見的,因為 Core Animation 會在顯示任何東西之前重繪所有必須的 Layer 。

第二,有許多 Layer 能夠引起性能問題。每個 CALayer 都需要一個支持存儲來保存它的像素位圖和內(nèi)容。同樣,Core Animation 必須將每個 Layer 通過 XPC 發(fā)給渲染服務(wù)器。最后,渲染服務(wù)器可能需要重繪一些 Layer 以復(fù)合它們,例如在混合 Layer 時。總的來說,更多的 Layer 意味著 Core Animation 更多的工作。所以限制 Layer 使用的數(shù)量有許多不同的好處。

為了解決這個問題,AsyncDisplayKit 有一個方便的特性:它允許你繪制一個 Node 層次結(jié)構(gòu)到一個單獨的 Layer 容器里。這就是 shouldRasterizeDescendants 所做的。當你設(shè)置它,那在完成所有的 Subnode 的繪制之前,ASDisplayNode 將不會設(shè)置 Layer 的 contents。

所以在之前的步驟里,設(shè)置容器 Node 的 shouldRasterizeDescendants 為 true 有兩個好處:

1. 它確保卡片一次顯示所有的 Node,如同舊的同步繪制;

2. 而且它通過柵格化 Layer 棧為單個 Layer 并較少未來的合成而提高了效率。

不足之處是,由于你將所有的 Layer 放入一個位圖,你就不能在之后單獨動畫某個 Node 了。

要獲得更多信息,請看 shouldRasterizeDescendants 在頭文件 ASDisplayNode.h 里的注釋。

接下來,在 Container Node Creation Section 后,添加 backgroundImageNode 為 containerNode 的 Subnode:

1
2
//MARK: Node Hierarchy Section
containerNode.addSubnode(backgroundImageNode)

注意:添加 Node 的順序很重要,就如同 subview 和 sublayer。最先添加的 Node 會被之后添加的阻擋顯示。

替換 Node Layout Section 的第一行為:

1
2
//MARK: Node Layout Section
containerNode.frame = FrameCalculator.frameForContainer(featureImageSize: image.size)

最后,使用 FrameCalculator 布局 backgroundImageNode:

1
2
backgroundImageNode.frame = FrameCalculator.frameForBackgroundImage(
  containerBounds: containerNode.bounds)

這設(shè)置 backgroundImageNode 填滿整個 containerNode。

你幾乎完成了新的 Node 層次結(jié)構(gòu),但首先你需要正確地設(shè)置 Layer 層次結(jié)構(gòu),因為容器 Node 現(xiàn)在是根。

管理容器 Node 的 Layer

在  Node Layer and Wrap Up Section ,將 backgroundImageNode 的 Layer 添加到 containerNode 的 Layer 上而不是 contentView 的 Layer 上:

1
2
3
4
// Replace the following line...
// self.contentView.layer.addSublayer(backgroundImageNode.layer)
// ...with this line:
self.contentView.layer.addSublayer(containerNode.layer)

刪除下面的  backgroundImageNode 保留:

1
self.backgroundImageNode = backgroundImageNode

因為 cell 只需要單獨保留容器 Node ,所以你要移除 backgroundImageNode 屬性。

不再設(shè)置 cell 的 contentLayer 屬性為  backgroundImageNode 的 Layer,現(xiàn)在將其設(shè)置為 containerNode 的 Layer:

1
2
3
4
// Replace the following line...
// self.contentLayer = backgroundImageNode.layer
// ...with this line:
self.contentLayer = containerNode.layer

給 RainforestCardCell 添加一個可選的 ASDisplayNode 實例存儲為屬性 containerNode:

1
2
3
4
5
6
7
8
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  var placeholderLayer: CALayer!
  var backgroundImageNode: ASImageNode?
  var contentLayer: CALayer?
  var containerNode: ASDisplayNode? ///< ADD THIS LINE
  ...
}

記住你需要保留你自己的 Node ,如果你不這么做它們就會被立即釋放。

回到 configureCellDisplayWithCardInfo(cardInfo:),在 Node Layer and Wrap Up Section 最后,設(shè)置 containerNode 屬性為 containerNode  常量:

1
self.containerNode = containerNode

編譯并運行。模糊的圖像將會再此顯示!但還有最后一件事要去改變,因為現(xiàn)在有了新的 Node 層次結(jié)構(gòu)。回憶之前 cell 重用時你將圖像停止顯示。現(xiàn)在你需要讓整個 Node 層次結(jié)構(gòu)停止顯示。

在新的 Node 層次結(jié)構(gòu)上處理 Cell 重用

繼續(xù) RainforestCardCell.swift ,在 prepareForReuse() 里,替換設(shè)置 backgroundImageNode.preventOrCancelDisplay 為在 containerNode 上調(diào)用 recursiveSetPreventOrCancelDisplay(...) 并傳遞 true:

1
2
3
4
5
6
7
8
9
10
11
override func prepareForReuse() {
  super.prepareForReuse()
 
  // Replace this line...
  // backgroundImageNode?.preventOrCancelDisplay = true
  // ...with this line:
  containerNode?.recursiveSetPreventOrCancelDisplay(true)
 
  contentLayer?.removeFromSuperlayer()
  ...
}

當你要取消整個 Node 層次結(jié)構(gòu)的繪制,就使用 recursiveSetPreventOrCancelDisplay()。這個方法將會設(shè)置這個 Node 以及其所有子 Node 的 preventOrCancelDisplay 屬性,無論 true 或 false。

接下來,依然在 prepareForReuse(),用設(shè)置  containerNode 為 nil 替換設(shè)置 backgroundImageNode 為 nil:

1
2
3
4
5
6
7
8
9
override func prepareForReuse() {
  ...
  contentLayer = nil
 
  // Replace this line...
  // backgroundImageNode = nil
  // ...with this line:
  containerNode = nil
}

移除 RainforestCardCell 的 backgroundImageNode 屬性:

1
2
3
4
5
6
7
8
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  var placeholderLayer: CALayer!
  // var backgroundImageNode: ASImageNode? ///< REMOVE THIS LINE
  var contentLayer: CALayer?
  var containerNode: ASDisplayNode?
  ...
}

編譯并運行。這個 App 就如之前一樣,但現(xiàn)在你的圖像 Node 在容器 Node 內(nèi),而重用依然和它應(yīng)有的方式一樣。

Cell 內(nèi)容

目前為止你有了一個 Node 層次結(jié)構(gòu),但容器內(nèi)還只有一個 Node——圖像 Node。現(xiàn)在是時候設(shè)置 Node 層次結(jié)構(gòu)去復(fù)制在添加 AsyncDisplayKit 之前時應(yīng)用的視圖層次結(jié)構(gòu)了。這意味著添加 text 和一個未模糊的特征圖像。

添加特征圖像

我們要添加特征圖像了,它是一個未模糊的圖像,顯示在卡片的頂部。

打開 RainforestCardCell.swift  并找到 configureCellDisplayWithCardInfo(cardInfo:)。在 Node Creation Section 的底部,添加如下代碼:

1
2
3
4
let featureImageNode = ASImageNode()
featureImageNode.layerBacked = true
featureImageNode.contentMode = .ScaleAspectFit
featureImageNode.image = image

這會創(chuàng)建并配置一個叫做 featureImageNode 的 ASImageNode 常量。它被設(shè)置為 Layer 支持的,放大以適用,并設(shè)置顯示圖像,這次不需要模糊。

在 Node Hierarchy Section 的最后,添加 featureImageNode 為 containerNode 的 Subnode:

1
containerNode.addSubnode(featureImageNode)

你正在用更多 Node 填充容器哦!

在 Node Layout Section ,使用 FrameCalculator 布局  featureImageNode:

1
2
3
featureImageNode.frame = FrameCalculator.frameForFeatureImage(
  featureImageSize: image.size,
  containerFrameWidth: containerNode.frame.size.width)

編譯并運行。你就會看到特征圖像在卡片的頂部出現(xiàn),位于模糊圖像的上方。注意特征圖像和模糊圖像是如何在同一時間跳出。這是你之前添加的 shouldRasterizeDescendants 在起作用。

添加 Title 文本

接下來添加文字 Label,以顯示動物的名字和描述。首先來動物名字吧。

繼續(xù) configureCellDisplayWithCardInfo(cardInfo:),找到 Node Creation Section 。添加下列代碼到這節(jié)尾部,就在創(chuàng)建 featureImageNode 之后:

1
2
3
4
let titleTextNode = ASTextNode()
titleTextNode.layerBacked = true
titleTextNode.backgroundColor = UIColor.clearColor()
titleTextNode.attributedString = NSAttributedString.attributedStringForTitleText(cardInfo.name)

這就創(chuàng)建了一個叫做 titleTextNode 的 ASTextNode 常量。

ASTextNode 是另一個 AsyncDisplayKit 提供的 Node 子類,其用于顯示文本。它是一個具有 UILabel 效果的 Node。它接受一個 attributedString,由 TextKit 支持,有許多特性如文本鏈接。要學到更多關(guān)于這個 Node 的功能,去看 ASTextNode.h 吧。

初始項目包含有一個 NSAttributedString 的擴展,它提供了一個工廠方法去生成一個屬性字符串用于 Title 和 Description 文本以顯示在雨林卡片上。上面的代碼使用了這個擴展的 attributedStringForTitleText(...) 方法。

現(xiàn)在,在 Node Hierarchy Section 底部,添加如下代碼:

1
containerNode.addSubnode(titleTextNode)

這就添加了 titleTextNode 到 Node 層次結(jié)構(gòu)里。它將位于特征圖像和背景圖像之上,因為它在它們之后添加。

在 Node Layout Section 底部添加如下代碼:

1
2
3
titleTextNode.frame = FrameCalculator.frameForTitleText(
  containerBounds: containerNode.bounds,
  featureImageFrame: featureImageNode.frame)

一樣使用 FrameCalculator 布局 titleTextNode,就像 backgroundImageNode 和 featureImageNode 那樣。

編譯并運行。你就有了一個 Title 顯示在特征圖像的頂部。再次說明, Label 只會在整個 cell 準備好渲染時才渲染。

添加 Description 文本

添加一個有著 Description 文本的 Node 和添加 Title 文本的 Node 類似。

回到 configureCellDisplayWithCardInfo(cardInfo:) ,在 Node Creation Section 最后,添加如下代碼。就在之前創(chuàng)建 titleTextNode 的語句之后:

1
2
3
4
5
let descriptionTextNode = ASTextNode()
descriptionTextNode.layerBacked = true
descriptionTextNode.backgroundColor = UIColor.clearColor()
descriptionTextNode.attributedString = 
  NSAttributedString.attributedStringForDescriptionText(cardInfo.description)

這就創(chuàng)建并配置了一個叫做 descriptionTextNode 的 ASTextNode 實例。

在  Node Hierarchy Section 最后,添加 descriptionTextNode 到 containerNode:

1
containerNode.addSubnode(descriptionTextNode)

在 Node Layout Section ,一樣使用 FrameCalculator 布局 descriptionTextNode:

1
2
3
descriptionTextNode.frame = FrameCalculator.frameForDescriptionText(
  containerBounds: containerNode.bounds,
  featureImageFrame: featureImageNode.frame)

編譯并運行。現(xiàn)在你能看到 Description 文本了。

Custom Node Subclasses 自定義 Node 子類

目前為止,你使用了 ASImageNode 和 ASTextNode。這會帶你走很遠,但有些時候你需要你自己的 Node,就如同某些時候在傳統(tǒng)的 UIKit 編程里你需要自己的 View 一樣。

創(chuàng)建梯度 Node 類

接下來,你將給 GradientView.swift 添加 Core Graphics 代碼來構(gòu)建一個自定義的梯度 Display Node。這會被用于創(chuàng)建一個繪制梯度的自定義 Node 。梯度圖會顯示在特征圖像的底部以便讓 Title 看起來更加明顯。

打開 Layers-Bridging-Header.h 并添加如下代碼:

1
#import

需這一步是因為這個類沒有包含在庫的主頭文件里。你在子類化任何 ASDisplayNode 或 _ASDisplayLayer 時都需要訪問這個類。

菜單 File\New\File… 。選擇 iOS\Source\Cocoa Touch Class 。命名類為 GradientNode 并使其作為 ASDisplayNode 的子類。選擇 Swift 語言并點擊 Next 。保存文件再打開 GradientNode.swift 。

添加如下方法到這個類:

1
2
3
4
class func drawRect(bounds: CGRect, withParameters parameters: NSObjectProtocol!,
    isCancelled isCancelledBlock: asdisplaynode_iscancelled_block_t!, isRasterizing: Bool) {
 
}

如同 UIView 或 CALayer,你可以子類化 ASDisplayNode 去做自定義繪制。你可以使用如同用于 UIView 的 Layer 或單獨的 CALayer 的繪制代碼,這取決于客戶 Node 如何配置 Node。查看 ASDisplayNode+Subclasses.h 獲取更多關(guān)于子類化 ASDisplayNode 的信息。

進一步,ASDisplayNode 的繪制方法比在 UIView 和 CALayer 里的接受更多參數(shù),給你提供方法少做工作,并更有效率。

要為你的自定義 Display Node 填充內(nèi)容,你需要實現(xiàn)來自 _ASDisplayLayerDelegate 協(xié)議的 drawRect(...) 或 displayWithParameters(...)。在繼續(xù)之前,看看 _ASDisplayLayer.h 得到這個方法和它們參數(shù)的信息。搜索 _ASDisplayLayerDelegate。重點看看頭文件注釋里關(guān)于 drawRect(...) 的描述。

因為梯度圖位于特征圖的上方,使用 Core Graphics 繪制,所以你需要使用 drawRect(...) 。

打開 GradientView.swift 并拷貝 drawRect(...) 的內(nèi)容到 GradientNode.swift 的 drawRect(...),如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class func drawRect(bounds: CGRect, withParameters parameters: NSObjectProtocol!,
    isCancelled isCancelledBlock: asdisplaynode_iscancelled_block_t!, isRasterizing: Bool) {
  let myContext = UIGraphicsGetCurrentContext()
  CGContextSaveGState(myContext)
  CGContextClipToRect(myContext, bounds)
 
  let componentCount: UInt = 2
  let locations: [CGFloat] = [0.0, 1.0]
  let components: [CGFloat] = [0.0, 0.0, 0.0, 1.0,
    0.0, 0.0, 0.0, 0.0]
  let myColorSpace = CGColorSpaceCreateDeviceRGB()
  let myGradient = CGGradientCreateWithColorComponents(myColorSpace, components,
    locations, componentCount)
 
  let myStartPoint = CGPoint(x: bounds.midX, y: bounds.maxY)
  let myEndPoint = CGPoint(x: bounds.midX, y: bounds.midY)
  CGContextDrawLinearGradient(myContext, myGradient, myStartPoint,
    myEndPoint, UInt32(kCGGradientDrawsAfterEndLocation))
 
  CGContextRestoreGState(myContext)
}

然后刪除 GradientView.swift,編譯并確保沒有錯誤。

添加梯度 Node

打開 RainforestCardCell.swift 并找到 configureCellDisplayWithCardInfo(cardInfo:)。在 Node Creation Section 底部,添加如下代碼,就在創(chuàng)建 descriptionTextNode 的代碼之后:

1
2
3
let gradientNode = GradientNode()
gradientNode.opaque = false
gradientNode.layerBacked = true

這就創(chuàng)建了一個叫做 gradientNode 的 GradientNode 常量。

在 Node Hierarchy Section,在添加 featureImageNode 那樣下面,添加 gradientNode 到 containerNode:

1
2
3
4
5
6
//MARK: Node Hierarchy Section
containerNode.addSubnode(backgroundImageNode)
containerNode.addSubnode(featureImageNode)
containerNode.addSubnode(gradientNode) ///< ADD THIS LINE
containerNode.addSubnode(titleTextNode)
containerNode.addSubnode(descriptionTextNode)

梯度 Node 需要這個位置才能在特征圖之上,Title 之下。

然后添加如下代碼到 Node Layout Section 底部:

1
2
gradientNode.frame = FrameCalculator.frameForGradient(
  featureImageFrame: featureImageNode.frame)

編譯并運行。你將看到梯度在特征圖的底部。Title 確實看得更清楚了!

爆米花特效

如之前提到的,cell 的 Node 內(nèi)容會在完成繪制時“彈出”。這不是很理想。所以讓我們繼續(xù),以修復(fù)這個問題。但首先,更加深入 AsyncDisplayKit 以看看它是如何工作的。

在 configureCellDisplayWithCardInfo(cardInfo:) 的 Container Node Creation Section ,關(guān)閉容器 Node 的 shouldRasterizeDescendants:

1
containerNode.shouldRasterizeDescendants = false

編譯并運行。你會注意到現(xiàn)在容器層次結(jié)構(gòu)里不同的 Node 一個接一個的彈出。你會看到文字彈出,然后是特征圖,然后是模糊背景圖。

當 shouldRasterizeDescendants 關(guān)閉后,AsyncDisplayKit 就不是繪制一個容器 Layer 了,它會創(chuàng)建一個鏡像卡片 Node 層次結(jié)構(gòu)的 Layer 樹。記得爆米花特效存在是因為每個 Layer 都在它繪制結(jié)束后立即出現(xiàn),而某些 Layer 比另外一個花費更多時間在繪制上。

這不是我們所需要的,但它描述了 AsyncDisplayKit 的工作方式。我們不想要這個行為,所以還是將 shouldRasterizeDescendants 打開:

1
containerNode.shouldRasterizeDescendants = true

編譯并運行。又回到整個 cell 在其渲染結(jié)束后彈出了。

該重新思考如何擺脫爆米花特效了。但首先,讓我們看看 Node 在后臺如何構(gòu)造。

在后臺構(gòu)造 Node

除了異步地繪制,使用 AsyncDisplayKit,你同樣可以異步地創(chuàng)建、配置以及布局。深呼吸一下,因為這就是你接下來要做的事情。

創(chuàng)建一個 Node 構(gòu)造操作(Operation)

你要將 Node 層次結(jié)構(gòu)的構(gòu)造包裝到一個 NSOperation 中。這樣做很棒,因為這個操作能很容易的在不同的操作隊列上執(zhí)行,包括后臺隊列。

打開  RainforestCardCell.swift 。然后添加如下方法:

1
2
3
4
5
6
7
func nodeConstructionOperationWithCardInfo(cardInfo: RainforestCardInfo, image: UIImage) -> NSOperation {
  let nodeConstructionOperation = NSBlockOperation()
  nodeConstructionOperation.addExecutionBlock { 
    // TODO: Add node hierarchy construction
  }
  return nodeConstructionOperation
}

繪制并不是唯一會拖慢主線程的操作。對于復(fù)雜的屏幕,布局計算也有可能變的昂貴。目前為止,本教程當前狀態(tài)的項目,一個緩慢的 Node 布局會引起  Collection View 丟幀。

60 FPS 意味著你有大約 17ms 的時間讓你的 cell 準備好顯示,否則一個或多個幀就會被丟掉。這在 Table View 和 Collection View 有很復(fù)雜的 cell 時是非常常見的,滑動時丟幀就是這個原因。

AsyncDisplayKit 前來救援!

你將使用上面的 nodeConstructionOperation 將所有 Node 層次結(jié)構(gòu)構(gòu)造以及布局從主線程剝離并放入后臺 NSOperationQueue,進一步確保 Collection View 能盡量以接近 60 FPS 的幀率滑動。

警告:你可以在后臺訪問并設(shè)置 Node 的屬性,但只能在 Node 的 Layer 或 View 被創(chuàng)建之前,也就是當你第一次訪問 Node 的 Layer 或 View 屬性時。

一旦 Node 的 Layer 或 View 被創(chuàng)建,你必須在主線程才能訪問和設(shè)置 Node 的屬性,因為 Node 將會轉(zhuǎn)發(fā)這些調(diào)用到它的 Layer 或 View。如果你得到一個崩潰 log 說“Incorrect display node thread affinity”,那就意味著在創(chuàng)建 Node 的 Layer 或 View 之后,你依然嘗試在后臺訪問或設(shè)置 Node 的屬性。

修改 nodeConstructionOperation 操作 Block 的內(nèi)容如下:

1
2
3
4
5
6
7
8
9
nodeConstructionOperation.addExecutionBlock {
  [weak self, unowned nodeConstructionOperation] in
  if nodeConstructionOperation.cancelled {
    return
  }
  if let strongSelf = self {
    // TODO: Add node hierarchy construction
  }
}

在這個操作運行時,cell 可能已經(jīng)被釋放了。在那種情況下,你不需要做任何工作。類似的,如果操作被取消了,那一樣也沒有工作要做了。

之所以對 nodeConstructionOperation` 使用 unowned  引用是為了避免在操作和執(zhí)行閉包之間產(chǎn)生保留環(huán)。

現(xiàn)在找到 configureCellDisplayWithCardInfo(cardInfo:)。將任何在 Image Size Section 之后的代碼移動到 nodeConstructionOperation 的執(zhí)行閉包里。將代碼放在 strongSelf 的條件語句里,即TODO的位置。之后 configureCellDisplayWithCardInfo(cardInfo:) 將看起來如下:

1
2
3
4
5
func configureCellDisplayWithCardInfo(cardInfo: RainforestCardInfo) {
  //MARK: Image Size Section
  let image = UIImage(named: cardInfo.imageName)!
  featureImageSizeOptional = image.size
}

目前,你會有一些編譯錯誤。這是因為操作 Block 里的 self 是 weak 引用,因此是可選的。但你有一個 self 的 strong 引用,因為代碼在可選綁定語句內(nèi)。所以替換錯誤的幾行成下面的樣子:

1
2
3
strongSelf.contentView.layer.addSublayer(containerNode.layer)
strongSelf.contentLayer = containerNode.layer
strongSelf.containerNode = containerNode

最后,添加如下代碼到你剛改動的三行之下:

1
containerNode.setNeedsDisplay()

編譯確保沒有錯誤。如果你現(xiàn)在運行,那么只有占位圖會顯示,因為 Node 的創(chuàng)建操作還沒有實際使用。讓我們來添加它。

使用 Node 創(chuàng)建操作

打開 RainforestCardCell.swift 并添加如下屬性:

1
2
3
4
5
6
7
8
9
class RainforestCardCell: UICollectionViewCell {
  var featureImageSizeOptional: CGSize?
  var placeholderLayer: CALayer!
  var backgroundImageNode: ASImageNode?
  var contentLayer: CALayer?
  var containerNode: ASDisplayNode?
  var nodeConstructionOperation: NSOperation? ///< ADD THIS LINE
  ...
}

這就添加了一個叫做 nodeConstructionOperation 的可選屬性

當 cell 準備回收時,你會使用這個屬性去取消 Node 的構(gòu)造。這會在用戶非常快速地滑動 Collection View 時發(fā)生,特別是如果布局還需要一些計算時間的話。

在 prepareForReuse() 添加如下指示的代碼:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
override func prepareForReuse() {
  super.prepareForReuse()
 
  // ADD FROM HERE...
  if let operation = nodeConstructionOperation {
    operation.cancel()
  }
  // ...TO HERE
 
  containerNode?.recursiveSetPreventOrCancelDisplay(true)
  contentLayer?.removeFromSuperlayer()
  contentLayer = nil
  containerNode = nil
}

這就在 cell 重用時取消了操作,所以如果 Node 創(chuàng)建還沒完成,它也不會完成。

現(xiàn)在找到 configureCellDisplayWithCardInfo(cardInfo:) 并添加如下指示的代碼:

1
2
3
4
5
6
7
8
9
10
11
func configureCellDisplayWithCardInfo(cardInfo: RainforestCardInfo) {
  // ADD FROM HERE...
  if let oldNodeConstructionOperation = nodeConstructionOperation {
    oldNodeConstructionOperation.cancel()
  }
  // ...TO HERE
 
  //MARK: Image Size Section
  let image = UIImage(named: cardInfo.imageName)!
  featureImageSizeOptional = image.size
}

這個 cell 現(xiàn)在會在它準備重用并開始配置時,取消任何進行中的 Node 構(gòu)造操作。這確保了操作被取消,即使 cell 在準備好重用前就被重新配置。

編譯并確保沒有錯誤。

在主線程運行

AsyncDisplayKit 允許你在非主線程做許多工作。但當它要面對 UIKit 和 CoreAnimation 時,你還是需要在主線程做。目前為止,你從主線程移走了所有的 Node 創(chuàng)建。但還有一件事需要被放在主線程——即設(shè)置 CoreAnimation 的 Layer 層次結(jié)構(gòu)。

在 RainforestCardCell.swift 里,找到 nodeConstructionOperationWithCardInfo(cardInfo:image:) 并替換 Node Layer and Wrap Up Section 為如下代碼:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// 1
dispatch_async(dispatch_get_main_queue()) { [weak nodeConstructionOperation] in
  if let strongNodeConstructionOperation = nodeConstructionOperation {
    // 2
    if strongNodeConstructionOperation.cancelled {
      return
    }
 
    // 3
    if strongSelf.nodeConstructionOperation !== strongNodeConstructionOperation {
      return
    }
 
    // 4
    if containerNode.preventOrCancelDisplay {
      return
    }
 
    // 5
    //MARK: Node Layer and Wrap Up Section
    strongSelf.contentView.layer.addSublayer(containerNode.layer)
    containerNode.setNeedsDisplay()
    strongSelf.contentLayer = containerNode.layer
    strongSelf.containerNode = containerNode
  }
}

下面描述一下:

1. 回憶到當 Node 的 Layer 屬性被第一個訪問時,所有的 Layer 會被創(chuàng)建。這就是為何你必須運行 Node Layer 并在主線程包裝小節(jié),因此代碼訪問 Node 的 Layer。

2. 操作被檢查以確定是否在添加 Layer 之前就已經(jīng)取消了。在操作完成前,cell 被重用或者重新配置,就很可能會出現(xiàn)這樣的情況,那你就不應(yīng)該添加 Layer 了。

3. 作為一個保險,確保 Node 當前的 nodeConstructionOperation 和調(diào)度此閉包的操作是同一個 NSOperation 。

4. 如果 containerNode 的 preventOrCancel 是 true 就立即返回。如果構(gòu)造操作完成,但 Node 的繪制還沒有被取消,你依然不想 Node 的 Layer 顯示在 cell 里。

5. 最后,添加 Node 的 Layer 到層次結(jié)構(gòu)中,如果必要,這將創(chuàng)建 Layer。

編譯確保沒有錯誤。

開始 Node 創(chuàng)建操作

你依然沒有 實際 創(chuàng)建和開始操作。讓我們現(xiàn)在來來吧。

繼續(xù)在 RainforestCardCell.swift 里,改變 configureCellDisplayWithCardInfo(cardInfo:) 的方法簽名為:

1
2
3
func configureCellDisplayWithCardInfo(
  cardInfo: RainforestCardInfo,
  nodeConstructionQueue: NSOperationQueue)

這里添加了一個新的參數(shù) nodeConstructionQueue。它就是一個用于 Node 創(chuàng)建操作的入隊的 NSOperationQueue 。

在 configureCellDisplayWithCardInfo(cardInfo:nodeConstructionQueue:) 底部,添加如下代碼:

1
2
3
let newNodeConstructionOperation = nodeConstructionOperationWithCardInfo(cardInfo, image: image)
nodeConstructionOperation = newNodeConstructionOperation
nodeConstructionQueue.addOperation(newNodeConstructionOperation)

這就創(chuàng)建了一個 Node 構(gòu)造操作,將其保留在 nodeConstructionOperation 屬性,并將其添加到傳入的隊列。

最后,打開 RainforestViewController.swift 。給 RainforestViewController 添加一個叫做 nodeConstructionQueue 的初始化為常量的屬性,如下:

1
2
3
4
5
class RainforestViewController: UICollectionViewController {
  let rainforestCardsInfo = getAllCardInfo()
  let nodeConstructionQueue = NSOperationQueue() ///< ADD THIS LINE
  ...
}

接下來,在 collectionView(collectionView:cellForItemAtIndexPath indexPath:) 里,傳遞 View Controller 的 nodeConstructionQueue 到 configureCellDisplayWithCardInfo(cardInfo:nodeConstructionQueue:) :

1
cell.configureCellDisplayWithCardInfo(cardInfo, nodeConstructionQueue: nodeConstructionQueue)

cell 將會創(chuàng)建一個新的 Node 構(gòu)造操作并將其添加到 View Controller 的操作隊列里并發(fā)運行。記住在 cell 出隊時就會創(chuàng)建一個新 Node 層次結(jié)構(gòu)。這并不理想,但足夠好。如果你要緩存 Node 的重用,看看 ASRangeController 吧。

哦呼,OK,現(xiàn)在編譯并運行!你將看到和之前一樣的效果,但現(xiàn)在布局和渲染都沒在主線程執(zhí)行了。牛!我打賭里你重來沒有想過你會看到這一天你所做的 事情。這就是 AsyncDisplayKit 的威力。你可以將更多更多不需要在主線程的操作從主線程移除,這將給主線程更多機會處理用戶交互,讓你的 App 摸起來如黃油般順滑。

淡入 Cell

現(xiàn)在是有趣的部分。在這個簡短的小節(jié),你將學到:

· 用自定義 Display Layer 子類來支持 Node;

· 觸發(fā) Node Layer 的隱式動畫。

這將會確保你移除爆米花特效并最終帶來良好的淡入動畫。

創(chuàng)建一個新的 Layer 子類。

菜單 File\New\File… ,選擇 iOS\Source\Cocoa Touch Class 并單擊 Next 。命名類為 AnimatedContentsDisplayLayer 并使其作為 _ASDisplayLayer 的子類。選擇 Swift 語言并單擊 Next。最后保存并打開 AnimatedContentsDisplayLayer.swift 。

現(xiàn)在添加如下方法到類:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
override func actionForKey(event: String!) -> CAAction! {
  if let action = super.actionForKey(event) {
    return action
  }
 
  if event == "contents" && contents == nil {
    let transition = CATransition()
    transition.duration = 0.6
    transition.type = kCATransitionFade
    return transition
  }
 
  return nil
}

Layer 有一個 contents 屬性,它告訴系統(tǒng)為這個 Layer 繪制什么。AsyncDisplayKit 通過在后臺渲染 contents 并最后在主線程設(shè)置 contents。

這個代碼將會添加一個過渡動畫,這樣 contents 就會淡如到 View 中。你可以在 Apple 的 Core Animation Programming Guide 找到更多關(guān)于隱式 Layer 動畫以及 CAAction 的信息.。

編譯并確保沒有錯誤。

淡入容器 Node

你已經(jīng)設(shè)置好一個 Layer 會在其 contents 被設(shè)置時淡入,你現(xiàn)在就要使用這個 Layer。

打開 RainforestCardCell.swift 。在 nodeConstructionOperationWithCardInfo(cardInfo:image:) 里,在 Container Node Creation Section 開頭,改動如下行:

1
2
3
4
// REPLACE THIS LINE...
// let containerNode = ASDisplayNode()
// ...WITH THIS LINE:
let containerNode = ASDisplayNode(layerClass: AnimatedContentsDisplayLayer.self)

這會告訴容器 Node 使用 AnimatedContentsDisplayLayer 實例作為其支持 Layer,因此自動帶來淡入的效果。

注意:只有 _ASDisplayLayer 的子類才能被異步地繪制。

編譯并運行。你將看到容器 Node 會在其繪制好之后淡入。

又往何處去?

恭喜!在你需要高性能地滑動你的用戶界面的時候,你有了另外一個工具在手。

在本教程里,你通過替換視圖層次結(jié)構(gòu)為一個柵格化的 AsyncDisplayKit Node 層次結(jié)構(gòu),顯著改善了一個性能很差的 Collection View 的滑動性能。多么令人激動!

這只是一個例子而已。AsyncDisplayKit 保有提高 UI 性能到一定水平的承諾,這通過平常的 UIKit 優(yōu)化往往難以達到。

實際說來,要充分利用 AsyncDisplayKit,你需要對標準 UIKit 的真正性能瓶頸的所在有足夠的了解。AsyncDisplayKit 很棒的一點是它引發(fā)我們探討這些問題并思考我們的 App 能如何在物理的極限上更快以及更具響應(yīng)性。

AsyncDisplayKit 是探討此性能前沿的一個非常強大的工具。明智地使用它,并步步逼近超級響應(yīng)UI的極限。

這僅僅是 AsyncDisplayKit 的一個開始!它作者和貢獻者每天都在構(gòu)建新的特性。請關(guān)注 1.1 版的 ASCollectionView 以及 ASMultiplexImageNode。從頭文件中可看到“ASMultiplexImageNode 是一個圖像 Node,它能加載并顯示一個圖像的多個版本。例如,它可以在高分辨率的圖像還在渲染時先顯示一個低分辨率的圖像。” 非常酷,對吧 :]

你可以在此下載最終的 Xcode 項目。

AsyncDisplayKit 的指導(dǎo)在這里,AsyncDisplayKit 的 Github 倉庫在這里。

這個庫的作者在收集 API 設(shè)計的反饋。你可以在 Facebook 上 的 Paper Engineering Community group 分享你的想法,或者直接參與到 AsyncDisplayKit 的開發(fā)中,通過 GitHub 貢獻你的 pull request。

總結(jié)

以上是生活随笔為你收集整理的[转]AsyncDisplayKit 教程:达到 60 FPS 的滚动帧率的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

无码人妻久久一区二区三区不卡 | 三上悠亚人妻中文字幕在线 | 国产精品美女久久久网av | 国产黑色丝袜在线播放 | 久久人人爽人人爽人人片ⅴ | 熟女俱乐部五十路六十路av | 丁香花在线影院观看在线播放 | 自拍偷自拍亚洲精品10p | 久久视频在线观看精品 | 国产精品成人av在线观看 | av无码不卡在线观看免费 | 一二三四社区在线中文视频 | 亚洲综合另类小说色区 | 久久www免费人成人片 | 国内少妇偷人精品视频 | 婷婷五月综合缴情在线视频 | 丝袜 中出 制服 人妻 美腿 | 亚洲日韩av一区二区三区四区 | 婷婷六月久久综合丁香 | 亚洲区小说区激情区图片区 | 国产高清av在线播放 | 国产精品igao视频网 | 亚洲国产一区二区三区在线观看 | 亚洲热妇无码av在线播放 | 黑人粗大猛烈进出高潮视频 | 日韩精品成人一区二区三区 | 精品久久久久久亚洲精品 | 色综合久久久无码中文字幕 | 亚洲精品国偷拍自产在线麻豆 | 国产日产欧产精品精品app | 国产欧美熟妇另类久久久 | 99国产欧美久久久精品 | 国产做国产爱免费视频 | 在线视频网站www色 | 国产在线精品一区二区高清不卡 | 久久99精品久久久久婷婷 | 欧美性生交xxxxx久久久 | 国产精品无码mv在线观看 | 性欧美疯狂xxxxbbbb | 丰满肥臀大屁股熟妇激情视频 | 亚洲欧美日韩国产精品一区二区 | 国产成人精品久久亚洲高清不卡 | 久久精品一区二区三区四区 | 国产午夜视频在线观看 | 午夜精品久久久内射近拍高清 | 国产一区二区三区日韩精品 | 国内精品人妻无码久久久影院蜜桃 | 国产精品毛多多水多 | 伊在人天堂亚洲香蕉精品区 | 激情五月综合色婷婷一区二区 | 精品无码一区二区三区爱欲 | av无码电影一区二区三区 | 日日碰狠狠躁久久躁蜜桃 | 久久精品人妻少妇一区二区三区 | 亚洲精品美女久久久久久久 | 漂亮人妻洗澡被公强 日日躁 | 丝袜人妻一区二区三区 | 国产97色在线 | 免 | 99re在线播放 | 国产午夜无码精品免费看 | 国产明星裸体无码xxxx视频 | 国产精品18久久久久久麻辣 | a在线观看免费网站大全 | 久久久久久a亚洲欧洲av冫 | 欧美人与物videos另类 | 爆乳一区二区三区无码 | 丰满少妇高潮惨叫视频 | 曰本女人与公拘交酡免费视频 | 中文毛片无遮挡高清免费 | 两性色午夜免费视频 | 国产精品怡红院永久免费 | 中国大陆精品视频xxxx | 波多野结衣乳巨码无在线观看 | 狠狠色噜噜狠狠狠7777奇米 | 丝袜美腿亚洲一区二区 | 久久久中文字幕日本无吗 | 影音先锋中文字幕无码 | 97人妻精品一区二区三区 | 亚洲成a人一区二区三区 | 波多野结衣aⅴ在线 | 国产精品va在线播放 | 色婷婷久久一区二区三区麻豆 | 精品无码一区二区三区爱欲 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲无人区午夜福利码高清完整版 | 国产精品无码一区二区桃花视频 | 亚洲熟悉妇女xxx妇女av | 午夜精品久久久内射近拍高清 | 十八禁真人啪啪免费网站 | 131美女爱做视频 | 久久亚洲日韩精品一区二区三区 | 国产人妻久久精品二区三区老狼 | 欧洲精品码一区二区三区免费看 | 久久久久免费看成人影片 | 亚洲 激情 小说 另类 欧美 | 激情内射亚州一区二区三区爱妻 | 亚洲欧美日韩综合久久久 | √天堂中文官网8在线 | 人妻少妇精品无码专区动漫 | 国产乱人偷精品人妻a片 | 亚洲第一无码av无码专区 | 精品欧美一区二区三区久久久 | 亚洲理论电影在线观看 | 国产乱子伦视频在线播放 | 一个人看的视频www在线 | 久久精品中文闷骚内射 | 日韩成人一区二区三区在线观看 | 精品亚洲成av人在线观看 | 娇妻被黑人粗大高潮白浆 | 国产精品美女久久久久av爽李琼 | 中文字幕无码日韩专区 | 国产精品视频免费播放 | 久久五月精品中文字幕 | 亚洲精品午夜国产va久久成人 | 99国产欧美久久久精品 | aⅴ亚洲 日韩 色 图网站 播放 | 无码国产色欲xxxxx视频 | 亚洲国产欧美国产综合一区 | 亚洲小说图区综合在线 | 性史性农村dvd毛片 | 亚洲国产综合无码一区 | 精品国产青草久久久久福利 | 亚洲精品久久久久中文第一幕 | 国产av久久久久精东av | 人妻插b视频一区二区三区 | 中文字幕乱码中文乱码51精品 | 日日噜噜噜噜夜夜爽亚洲精品 | 99国产欧美久久久精品 | 国产极品美女高潮无套在线观看 | 黑人大群体交免费视频 | 亚洲综合无码久久精品综合 | 少妇高潮一区二区三区99 | 国产乱子伦视频在线播放 | 国产午夜福利100集发布 | 激情爆乳一区二区三区 | 人妻无码αv中文字幕久久琪琪布 | 国产精品18久久久久久麻辣 | 欧美精品无码一区二区三区 | 国产精品嫩草久久久久 | 99久久久无码国产aaa精品 | 久久久精品成人免费观看 | 日韩亚洲欧美精品综合 | 国产人妻精品一区二区三区不卡 | 无码播放一区二区三区 | 日本一区二区三区免费播放 | 国产午夜无码精品免费看 | 亚洲日本在线电影 | 亚洲狠狠婷婷综合久久 | 久久精品国产大片免费观看 | 夜夜躁日日躁狠狠久久av | 最近的中文字幕在线看视频 | 欧美刺激性大交 | 国产午夜视频在线观看 | 在线欧美精品一区二区三区 | 国语精品一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 丰满肥臀大屁股熟妇激情视频 | 美女张开腿让人桶 | 99久久婷婷国产综合精品青草免费 | 亚洲熟妇色xxxxx欧美老妇y | 国产熟妇高潮叫床视频播放 | 色欲人妻aaaaaaa无码 | 无人区乱码一区二区三区 | 野狼第一精品社区 | 青草青草久热国产精品 | 无遮挡国产高潮视频免费观看 | 亚洲熟妇色xxxxx欧美老妇y | 又大又硬又爽免费视频 | 最近免费中文字幕中文高清百度 | 无遮挡啪啪摇乳动态图 | 欧洲美熟女乱又伦 | 中文字幕乱码人妻无码久久 | 丰满护士巨好爽好大乳 | 狠狠亚洲超碰狼人久久 | 国产色视频一区二区三区 | 久久久久99精品国产片 | 青青草原综合久久大伊人精品 | 小sao货水好多真紧h无码视频 | aa片在线观看视频在线播放 | 丝袜人妻一区二区三区 | 东京一本一道一二三区 | 亚洲国产欧美国产综合一区 | 少妇人妻av毛片在线看 | 性色av无码免费一区二区三区 | 色狠狠av一区二区三区 | 草草网站影院白丝内射 | 啦啦啦www在线观看免费视频 | 少妇一晚三次一区二区三区 | 久久久久成人片免费观看蜜芽 | 国产偷国产偷精品高清尤物 | 十八禁真人啪啪免费网站 | 好屌草这里只有精品 | 亚洲日韩中文字幕在线播放 | 亚洲日本在线电影 | 国产精品人人妻人人爽 | 97se亚洲精品一区 | 亚洲狠狠婷婷综合久久 | 国产亚洲欧美在线专区 | 噜噜噜亚洲色成人网站 | 国产口爆吞精在线视频 | 久久精品国产日本波多野结衣 | 日本在线高清不卡免费播放 | √8天堂资源地址中文在线 | 国产人妖乱国产精品人妖 | av香港经典三级级 在线 | 成人一区二区免费视频 | 99久久久国产精品无码免费 | 国产成人无码午夜视频在线观看 | 国产精品va在线观看无码 | 欧美性猛交xxxx富婆 | 国产熟妇高潮叫床视频播放 | 欧美日韩久久久精品a片 | 伦伦影院午夜理论片 | www成人国产高清内射 | 成人无码视频在线观看网站 | 2019nv天堂香蕉在线观看 | 成人精品视频一区二区三区尤物 | 露脸叫床粗话东北少妇 | 亚洲日本一区二区三区在线 | 亚洲熟悉妇女xxx妇女av | 乱人伦人妻中文字幕无码久久网 | 人妻与老人中文字幕 | 国产精品久久久久久亚洲毛片 | 亚洲国产精品美女久久久久 | 亚洲精品一区国产 | 亚洲成a人一区二区三区 | 国产精品久久久久7777 | 永久免费观看美女裸体的网站 | 亚洲欧洲中文日韩av乱码 | 成人av无码一区二区三区 | 十八禁视频网站在线观看 | 99久久亚洲精品无码毛片 | 蜜桃av抽搐高潮一区二区 | 精品 日韩 国产 欧美 视频 | 国产精品亚洲一区二区三区喷水 | 国产精品欧美成人 | 久久视频在线观看精品 | 日本在线高清不卡免费播放 | 亚洲成色www久久网站 | 狠狠综合久久久久综合网 | 在线 国产 欧美 亚洲 天堂 | 日本乱偷人妻中文字幕 | 国产精品久免费的黄网站 | 大肉大捧一进一出好爽视频 | 日韩欧美群交p片內射中文 | 无码一区二区三区在线观看 | 精品久久久无码中文字幕 | 亚洲娇小与黑人巨大交 | 久久精品人妻少妇一区二区三区 | 玩弄人妻少妇500系列视频 | 精品国产aⅴ无码一区二区 | 亚洲中文字幕成人无码 | 精品无人国产偷自产在线 | 欧美性猛交xxxx富婆 | 成人无码视频免费播放 | 国产精品成人av在线观看 | 中文毛片无遮挡高清免费 | 国产人妻精品一区二区三区 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产亚洲精品久久久久久久久动漫 | 5858s亚洲色大成网站www | 天天做天天爱天天爽综合网 | 国产熟女一区二区三区四区五区 | 激情内射亚州一区二区三区爱妻 | 免费网站看v片在线18禁无码 | 少妇邻居内射在线 | 少妇高潮喷潮久久久影院 | 亚洲人成网站色7799 | 国产精品丝袜黑色高跟鞋 | 国产特级毛片aaaaaa高潮流水 | 搡女人真爽免费视频大全 | 99国产欧美久久久精品 | 欧美zoozzooz性欧美 | 欧美日本精品一区二区三区 | 免费看少妇作爱视频 | 久久久婷婷五月亚洲97号色 | 精品国产一区av天美传媒 | 欧洲美熟女乱又伦 | 欧美丰满熟妇xxxx性ppx人交 | 一二三四社区在线中文视频 | 中文精品无码中文字幕无码专区 | 日韩亚洲欧美精品综合 | 久久亚洲日韩精品一区二区三区 | 2020最新国产自产精品 | 99久久久国产精品无码免费 | 国产明星裸体无码xxxx视频 | 无码国产乱人伦偷精品视频 | 国产精品对白交换视频 | 日本乱偷人妻中文字幕 | 色狠狠av一区二区三区 | 樱花草在线社区www | 亚洲综合久久一区二区 | 女高中生第一次破苞av | 国产精品-区区久久久狼 | 精品亚洲成av人在线观看 | 色情久久久av熟女人妻网站 | 国产熟妇另类久久久久 | 国产精品va在线播放 | 99riav国产精品视频 | 日韩成人一区二区三区在线观看 | 亚洲一区二区三区在线观看网站 | 亚洲一区二区三区 | 精品国产av色一区二区深夜久久 | 无码福利日韩神码福利片 | 午夜免费福利小电影 | 中文字幕无码免费久久99 | 国内精品人妻无码久久久影院 | 国产亚洲欧美日韩亚洲中文色 | 窝窝午夜理论片影院 | 国产精品美女久久久网av | 国产又粗又硬又大爽黄老大爷视 | 人妻少妇精品无码专区动漫 | 老子影院午夜精品无码 | 又粗又大又硬毛片免费看 | 男女超爽视频免费播放 | 久久五月精品中文字幕 | 国产又粗又硬又大爽黄老大爷视 | 久激情内射婷内射蜜桃人妖 | 成人无码精品一区二区三区 | 夜夜夜高潮夜夜爽夜夜爰爰 | 少妇人妻大乳在线视频 | 亚洲区小说区激情区图片区 | 久精品国产欧美亚洲色aⅴ大片 | 午夜丰满少妇性开放视频 | 蜜桃av抽搐高潮一区二区 | 亚洲另类伦春色综合小说 | 无码一区二区三区在线 | 国产特级毛片aaaaaa高潮流水 | 爱做久久久久久 | 久久视频在线观看精品 | 日本精品高清一区二区 | 久激情内射婷内射蜜桃人妖 | 夜精品a片一区二区三区无码白浆 | 一本久久a久久精品亚洲 | 国产凸凹视频一区二区 | 欧美放荡的少妇 | 精品国产成人一区二区三区 | 日日天日日夜日日摸 | 西西人体www44rt大胆高清 | 性色欲网站人妻丰满中文久久不卡 | a在线观看免费网站大全 | 亚洲日本在线电影 | 两性色午夜视频免费播放 | 在线观看国产一区二区三区 | 少妇人妻av毛片在线看 | 蜜桃臀无码内射一区二区三区 | 久久久久久av无码免费看大片 | 国产精品理论片在线观看 | 乱码av麻豆丝袜熟女系列 | 最新国产乱人伦偷精品免费网站 | 又大又黄又粗又爽的免费视频 | 鲁一鲁av2019在线 | 无码成人精品区在线观看 | 午夜精品久久久内射近拍高清 | 呦交小u女精品视频 | 双乳奶水饱满少妇呻吟 | 日产精品高潮呻吟av久久 | 在线亚洲高清揄拍自拍一品区 | 丝袜人妻一区二区三区 | 国产女主播喷水视频在线观看 | 免费网站看v片在线18禁无码 | 国产精品免费大片 | 国产精品无码成人午夜电影 | 帮老师解开蕾丝奶罩吸乳网站 | 无码国产乱人伦偷精品视频 | 爆乳一区二区三区无码 | 亚洲阿v天堂在线 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产亚洲人成a在线v网站 | 国产亚洲精品久久久ai换 | 大地资源中文第3页 | 国产精品欧美成人 | 欧美熟妇另类久久久久久多毛 | 亚洲 a v无 码免 费 成 人 a v | 成年女人永久免费看片 | 国内精品人妻无码久久久影院 | 日韩成人一区二区三区在线观看 | 强辱丰满人妻hd中文字幕 | 日本饥渴人妻欲求不满 | 国产成人av免费观看 | 国产九九九九九九九a片 | 久久综合九色综合97网 | 成人一区二区免费视频 | 国产97人人超碰caoprom | 一区二区三区高清视频一 | 亚洲午夜无码久久 | 欧美熟妇另类久久久久久不卡 | 少妇无套内谢久久久久 | 99久久精品无码一区二区毛片 | 久久综合九色综合97网 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产精品无码永久免费888 | 午夜成人1000部免费视频 | 国产成人精品久久亚洲高清不卡 | 妺妺窝人体色www在线小说 | 国产卡一卡二卡三 | 久久综合香蕉国产蜜臀av | 亚洲区小说区激情区图片区 | 免费国产黄网站在线观看 | 国产深夜福利视频在线 | 精品国产一区二区三区四区在线看 | 偷窥村妇洗澡毛毛多 | 亚洲精品成人福利网站 | 亚洲国产欧美在线成人 | 久久久久亚洲精品男人的天堂 | 玩弄人妻少妇500系列视频 | 西西人体www44rt大胆高清 | 双乳奶水饱满少妇呻吟 | 人人妻人人澡人人爽人人精品 | 日本丰满护士爆乳xxxx | 极品尤物被啪到呻吟喷水 | 久久综合九色综合97网 | 四十如虎的丰满熟妇啪啪 | 十八禁视频网站在线观看 | 亚洲人亚洲人成电影网站色 | 亚洲国产精品一区二区第一页 | 国产午夜无码视频在线观看 | 樱花草在线播放免费中文 | 3d动漫精品啪啪一区二区中 | 国产精品高潮呻吟av久久 | 久久综合给久久狠狠97色 | 国产精品二区一区二区aⅴ污介绍 | 国产av无码专区亚洲a∨毛片 | 天堂а√在线中文在线 | 国产亚洲日韩欧美另类第八页 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲 高清 成人 动漫 | 日本爽爽爽爽爽爽在线观看免 | а天堂中文在线官网 | 免费无码的av片在线观看 | 国产无套内射久久久国产 | 色一情一乱一伦一视频免费看 | 麻花豆传媒剧国产免费mv在线 | 丰满肥臀大屁股熟妇激情视频 | 99er热精品视频 | 久久精品人人做人人综合试看 | 亚洲欧美中文字幕5发布 | 欧美人与禽zoz0性伦交 | 福利一区二区三区视频在线观看 | 成人无码视频免费播放 | 亚洲毛片av日韩av无码 | 国产又粗又硬又大爽黄老大爷视 | 精品国产福利一区二区 | 大屁股大乳丰满人妻 | 久久午夜无码鲁丝片 | 天天拍夜夜添久久精品 | 亚洲伊人久久精品影院 | 亚洲成av人片在线观看无码不卡 | 好男人社区资源 | 久久99久久99精品中文字幕 | 欧美老妇交乱视频在线观看 | 99久久99久久免费精品蜜桃 | 国产精品亚洲综合色区韩国 | 欧美老妇交乱视频在线观看 | 欧美freesex黑人又粗又大 | 中文字幕无码日韩专区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产一区二区三区四区五区加勒比 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产黑色丝袜在线播放 | 丰满肥臀大屁股熟妇激情视频 | 亚洲精品一区三区三区在线观看 | 午夜精品久久久久久久 | 装睡被陌生人摸出水好爽 | 国产又爽又黄又刺激的视频 | 奇米影视7777久久精品人人爽 | 一个人看的www免费视频在线观看 | 人妻aⅴ无码一区二区三区 | 亚洲第一无码av无码专区 | 国产免费无码一区二区视频 | 国产又爽又猛又粗的视频a片 | 99国产精品白浆在线观看免费 | 狠狠cao日日穞夜夜穞av | 麻豆av传媒蜜桃天美传媒 | 三级4级全黄60分钟 | 亚洲国产欧美国产综合一区 | 亚洲日韩av一区二区三区中文 | 亚洲成av人综合在线观看 | 国产乱子伦视频在线播放 | 国产激情综合五月久久 | 午夜熟女插插xx免费视频 | 性欧美疯狂xxxxbbbb | 一本色道久久综合狠狠躁 | 人妻体内射精一区二区三四 | 强伦人妻一区二区三区视频18 | 国产69精品久久久久app下载 | 最近的中文字幕在线看视频 | 一本无码人妻在中文字幕免费 | 国产热a欧美热a在线视频 | 麻豆蜜桃av蜜臀av色欲av | 日本高清一区免费中文视频 | 内射白嫩少妇超碰 | 最近中文2019字幕第二页 | 久久久精品456亚洲影院 | 亚洲精品国产a久久久久久 | 久久久亚洲欧洲日产国码αv | 无码免费一区二区三区 | 精品厕所偷拍各类美女tp嘘嘘 | 精品 日韩 国产 欧美 视频 | 草草网站影院白丝内射 | 香蕉久久久久久av成人 | 国产成人精品久久亚洲高清不卡 | 一本无码人妻在中文字幕免费 | 帮老师解开蕾丝奶罩吸乳网站 | 国产色视频一区二区三区 | 偷窥村妇洗澡毛毛多 | 国产在线精品一区二区三区直播 | 久久精品国产大片免费观看 | 六十路熟妇乱子伦 | 欧美变态另类xxxx | 好男人www社区 | 1000部啪啪未满十八勿入下载 | 中文字幕日韩精品一区二区三区 | 76少妇精品导航 | 一个人看的视频www在线 | 无码国内精品人妻少妇 | 国产明星裸体无码xxxx视频 | 国产女主播喷水视频在线观看 | 18无码粉嫩小泬无套在线观看 | 亚洲欧美国产精品专区久久 | 欧美三级a做爰在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 欧美猛少妇色xxxxx | 国产成人精品三级麻豆 | 国产小呦泬泬99精品 | 日日摸夜夜摸狠狠摸婷婷 | 丝袜人妻一区二区三区 | 狠狠噜狠狠狠狠丁香五月 | 黑人巨大精品欧美一区二区 | 国产成人无码一二三区视频 | 日韩精品无码免费一区二区三区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 日本熟妇大屁股人妻 | 成人精品视频一区二区三区尤物 | 亚洲一区二区三区 | 领导边摸边吃奶边做爽在线观看 | 任你躁国产自任一区二区三区 | 99久久人妻精品免费一区 | 99精品视频在线观看免费 | 日本一卡二卡不卡视频查询 | 美女黄网站人色视频免费国产 | 日韩欧美中文字幕公布 | 亚洲综合伊人久久大杳蕉 | 亚洲精品久久久久久久久久久 | 男人和女人高潮免费网站 | √天堂资源地址中文在线 | 无码人妻久久一区二区三区不卡 | 99久久精品午夜一区二区 | 亚洲熟熟妇xxxx | 日韩av激情在线观看 | www国产亚洲精品久久久日本 | 美女极度色诱视频国产 | 又湿又紧又大又爽a视频国产 | 国产乱人伦av在线无码 | 国产99久久精品一区二区 | 欧美丰满少妇xxxx性 | 中文字幕色婷婷在线视频 | 丰满人妻精品国产99aⅴ | 中文字幕 亚洲精品 第1页 | 黑人粗大猛烈进出高潮视频 | 精品亚洲韩国一区二区三区 | 人人超人人超碰超国产 | www国产亚洲精品久久久日本 | 波多野结衣乳巨码无在线观看 | 免费无码午夜福利片69 | 丝袜足控一区二区三区 | 国产凸凹视频一区二区 | 精品无人区无码乱码毛片国产 | 好爽又高潮了毛片免费下载 | 色欲人妻aaaaaaa无码 | 久久无码人妻影院 | 大地资源网第二页免费观看 | 2019午夜福利不卡片在线 | 无码播放一区二区三区 | 蜜桃臀无码内射一区二区三区 | 久久久中文久久久无码 | 欧美怡红院免费全部视频 | 成人无码视频在线观看网站 | 国产亚洲视频中文字幕97精品 | 亚洲高清偷拍一区二区三区 | 2019午夜福利不卡片在线 | 久久午夜无码鲁丝片午夜精品 | 色狠狠av一区二区三区 | www一区二区www免费 | 无码福利日韩神码福利片 | 国产深夜福利视频在线 | 97无码免费人妻超级碰碰夜夜 | 国产一区二区三区精品视频 | 久久久婷婷五月亚洲97号色 | 亚洲人亚洲人成电影网站色 | 九月婷婷人人澡人人添人人爽 | 亚洲熟悉妇女xxx妇女av | 中文精品久久久久人妻不卡 | 欧美熟妇另类久久久久久不卡 | 98国产精品综合一区二区三区 | 国产电影无码午夜在线播放 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲国产欧美在线成人 | 日本大乳高潮视频在线观看 | 成年女人永久免费看片 | 欧美日本免费一区二区三区 | 欧美高清在线精品一区 | 亲嘴扒胸摸屁股激烈网站 | 曰本女人与公拘交酡免费视频 | 国产免费无码一区二区视频 | 97精品国产97久久久久久免费 | 国产成人无码一二三区视频 | 蜜桃视频韩日免费播放 | 欧美日韩综合一区二区三区 | 麻豆蜜桃av蜜臀av色欲av | 人人妻人人澡人人爽人人精品 | 九月婷婷人人澡人人添人人爽 | 色欲人妻aaaaaaa无码 | 国产乱码精品一品二品 | 欧美猛少妇色xxxxx | 日韩人妻无码一区二区三区久久99 | 国产亚洲精品久久久久久国模美 | 亚洲の无码国产の无码影院 | 丰满人妻一区二区三区免费视频 | 日本大乳高潮视频在线观看 | 久久人人爽人人人人片 | 日韩精品无码一区二区中文字幕 | 俺去俺来也在线www色官网 | 无遮挡国产高潮视频免费观看 | 成年美女黄网站色大免费视频 | 男女超爽视频免费播放 | 亚洲区欧美区综合区自拍区 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲精品国产精品乱码不卡 | 一本无码人妻在中文字幕免费 | 2019午夜福利不卡片在线 | 国产97在线 | 亚洲 | 无码人妻丰满熟妇区五十路百度 | 久久99精品国产麻豆 | 免费国产黄网站在线观看 | 中文字幕乱码亚洲无线三区 | 亚洲自偷精品视频自拍 | 欧美老妇与禽交 | 成人女人看片免费视频放人 | www国产亚洲精品久久网站 | 5858s亚洲色大成网站www | 国产精品无码久久av | 亚洲欧洲中文日韩av乱码 | 欧美真人作爱免费视频 | 老熟妇乱子伦牲交视频 | 领导边摸边吃奶边做爽在线观看 | 正在播放老肥熟妇露脸 | 国产精品福利视频导航 | 久久综合九色综合欧美狠狠 | 久久精品中文字幕大胸 | 久久无码中文字幕免费影院蜜桃 | 精品国产一区二区三区四区 | 亚洲小说图区综合在线 | 亚洲午夜久久久影院 | 亚洲成色在线综合网站 | 无码国产激情在线观看 | 男人和女人高潮免费网站 | 亚洲成a人片在线观看无码3d | 丝袜 中出 制服 人妻 美腿 | 美女张开腿让人桶 | 永久免费观看国产裸体美女 | 2019午夜福利不卡片在线 | 午夜成人1000部免费视频 | 精品国产麻豆免费人成网站 | 亚洲小说春色综合另类 | 精品无码av一区二区三区 | 国产免费久久久久久无码 | 香港三级日本三级妇三级 | 国产办公室秘书无码精品99 | 18无码粉嫩小泬无套在线观看 | 国产精品高潮呻吟av久久4虎 | 国产精品久久久久无码av色戒 | 中文字幕 亚洲精品 第1页 | 又紧又大又爽精品一区二区 | a在线观看免费网站大全 | 午夜嘿嘿嘿影院 | 中文字幕乱码中文乱码51精品 | 成人免费视频视频在线观看 免费 | 国产精品美女久久久网av | 亚洲va中文字幕无码久久不卡 | 色老头在线一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | √天堂资源地址中文在线 | 欧美人妻一区二区三区 | 欧美日韩在线亚洲综合国产人 | 无码av免费一区二区三区试看 | 国产乱人偷精品人妻a片 | 蜜桃av抽搐高潮一区二区 | 丝袜 中出 制服 人妻 美腿 | 麻豆成人精品国产免费 | 亚洲人成影院在线无码按摩店 | 少妇人妻偷人精品无码视频 | 一本大道久久东京热无码av | 欧美第一黄网免费网站 | 国产特级毛片aaaaaa高潮流水 | 亚洲欧美日韩综合久久久 | 亚洲精品综合一区二区三区在线 | 亚洲成av人综合在线观看 | 免费国产成人高清在线观看网站 | 天天综合网天天综合色 | 欧美国产亚洲日韩在线二区 | 亚洲欧洲日本综合aⅴ在线 | 77777熟女视频在线观看 а天堂中文在线官网 | 一区二区三区乱码在线 | 欧洲 | 日本大乳高潮视频在线观看 | 性生交大片免费看女人按摩摩 | 精品乱子伦一区二区三区 | 成人片黄网站色大片免费观看 | 国产亚洲精品久久久久久久 | 日本高清一区免费中文视频 | 国产极品美女高潮无套在线观看 | 久久久久久av无码免费看大片 | 精品久久久久香蕉网 | 国产亚洲日韩欧美另类第八页 | 欧美午夜特黄aaaaaa片 | 精品国产一区二区三区四区在线看 | 午夜福利试看120秒体验区 | 亚洲色大成网站www | 中国女人内谢69xxxxxa片 | 国产日产欧产精品精品app | 国产精品久久久久久亚洲影视内衣 | 亚洲阿v天堂在线 | 少妇性荡欲午夜性开放视频剧场 | 午夜福利电影 | 中文字幕无码免费久久99 | 久久精品女人的天堂av | 亚洲娇小与黑人巨大交 | 99riav国产精品视频 | 中文久久乱码一区二区 | 亚洲色无码一区二区三区 | 国产舌乚八伦偷品w中 | 国产猛烈高潮尖叫视频免费 | 又色又爽又黄的美女裸体网站 | 亚洲中文字幕在线观看 | 色婷婷香蕉在线一区二区 | 丰腴饱满的极品熟妇 | 午夜福利一区二区三区在线观看 | 久久精品中文字幕大胸 | 四虎国产精品一区二区 | 亚洲综合无码久久精品综合 | 亚洲 a v无 码免 费 成 人 a v | 亚洲精品成a人在线观看 | 精品一区二区三区波多野结衣 | 色老头在线一区二区三区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 日日摸天天摸爽爽狠狠97 | 久久久精品人妻久久影视 | 四虎影视成人永久免费观看视频 | 中文字幕日韩精品一区二区三区 | 一本色道久久综合亚洲精品不卡 | 日日碰狠狠丁香久燥 | 图片小说视频一区二区 | 狠狠躁日日躁夜夜躁2020 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲成av人片天堂网无码】 | 亚洲国产av美女网站 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲国产日韩a在线播放 | 天堂亚洲免费视频 | 亚洲小说春色综合另类 | 免费国产黄网站在线观看 | 免费中文字幕日韩欧美 | 一区二区三区乱码在线 | 欧洲 | 亚洲熟妇色xxxxx欧美老妇y | 熟妇女人妻丰满少妇中文字幕 | 波多野结衣乳巨码无在线观看 | 亚洲精品成人av在线 | 亚洲精品一区二区三区在线 | 亚洲人成网站在线播放942 | 99久久亚洲精品无码毛片 | 成人精品视频一区二区三区尤物 | 亚洲一区二区观看播放 | 无码福利日韩神码福利片 | 久久久久久亚洲精品a片成人 | 麻豆国产人妻欲求不满谁演的 | 最近免费中文字幕中文高清百度 | 国模大胆一区二区三区 | 亚洲日韩精品欧美一区二区 | 久久国产精品_国产精品 | 国产明星裸体无码xxxx视频 | 欧美xxxxx精品 | 国产成人久久精品流白浆 | 国产无av码在线观看 | 久久无码专区国产精品s | 久久无码中文字幕免费影院蜜桃 | 国产人妻大战黑人第1集 | 国产精品久久久久久久9999 | 久久97精品久久久久久久不卡 | 台湾无码一区二区 | 成人影院yy111111在线观看 | 国产网红无码精品视频 | 四虎4hu永久免费 | 欧美兽交xxxx×视频 | 国产精品对白交换视频 | 国产 精品 自在自线 | 日本成熟视频免费视频 | 亚洲成a人一区二区三区 | 久久精品人人做人人综合 | 无遮挡国产高潮视频免费观看 | 乱人伦人妻中文字幕无码久久网 | 好男人www社区 | 精品一区二区三区无码免费视频 | 亚洲色偷偷男人的天堂 | 在线 国产 欧美 亚洲 天堂 | 色爱情人网站 | 99麻豆久久久国产精品免费 | 日本熟妇人妻xxxxx人hd | 人人妻人人澡人人爽欧美精品 | 99国产欧美久久久精品 | 国产精品久久精品三级 | 亚洲精品综合五月久久小说 | 亚洲欧美日韩国产精品一区二区 | 欧美激情综合亚洲一二区 | 欧美野外疯狂做受xxxx高潮 | 精品久久久久香蕉网 | 成人无码视频免费播放 | 亚洲国产精品无码久久久久高潮 | 久久久久av无码免费网 | 亚洲中文无码av永久不收费 | 丰满少妇女裸体bbw | 久久久精品国产sm最大网站 | 97夜夜澡人人爽人人喊中国片 | 午夜福利试看120秒体验区 | 国产凸凹视频一区二区 | 久久久久久九九精品久 | 日本va欧美va欧美va精品 | 久久久久成人精品免费播放动漫 | 欧美日本精品一区二区三区 | 日本欧美一区二区三区乱码 | 极品尤物被啪到呻吟喷水 | 麻豆蜜桃av蜜臀av色欲av | 成人免费视频视频在线观看 免费 | 奇米影视888欧美在线观看 | 国产在线精品一区二区高清不卡 | 午夜福利电影 | 宝宝好涨水快流出来免费视频 | 久久精品人妻少妇一区二区三区 | 大色综合色综合网站 | 亚洲欧美日韩国产精品一区二区 | 国产深夜福利视频在线 | 久久久婷婷五月亚洲97号色 | 激情内射亚州一区二区三区爱妻 | 中文字幕日韩精品一区二区三区 | 高清无码午夜福利视频 | 国产热a欧美热a在线视频 | 久久亚洲a片com人成 | 波多野结衣乳巨码无在线观看 | 久久午夜无码鲁丝片午夜精品 | 一个人免费观看的www视频 | 久久久www成人免费毛片 | 图片区 小说区 区 亚洲五月 | 一本久久a久久精品亚洲 | 少女韩国电视剧在线观看完整 | 天堂а√在线中文在线 | 精品无人区无码乱码毛片国产 | 久久婷婷五月综合色国产香蕉 | 久久综合香蕉国产蜜臀av | 无码人妻久久一区二区三区不卡 | 性欧美熟妇videofreesex | 东京一本一道一二三区 | 久久精品99久久香蕉国产色戒 | 无码纯肉视频在线观看 | 18禁止看的免费污网站 | 骚片av蜜桃精品一区 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲乱码日产精品bd | 成年女人永久免费看片 | 欧美人与物videos另类 | 性欧美牲交在线视频 | 又色又爽又黄的美女裸体网站 | 亚洲色无码一区二区三区 | 亚洲国产欧美在线成人 | 又大又紧又粉嫩18p少妇 | 国产无遮挡又黄又爽又色 | 精品无码一区二区三区爱欲 | 国产精品国产三级国产专播 | 无码国产乱人伦偷精品视频 | 精品人妻人人做人人爽夜夜爽 | 性色欲情网站iwww九文堂 | 亚洲综合无码一区二区三区 | 日本精品少妇一区二区三区 | 六十路熟妇乱子伦 | 午夜理论片yy44880影院 | 男人的天堂2018无码 | 欧美刺激性大交 | 动漫av一区二区在线观看 | 亚洲色在线无码国产精品不卡 | 国产性生大片免费观看性 | 沈阳熟女露脸对白视频 | 欧美喷潮久久久xxxxx | 国产suv精品一区二区五 | 色一情一乱一伦一视频免费看 | 欧美真人作爱免费视频 | 国产手机在线αⅴ片无码观看 | 欧美 日韩 人妻 高清 中文 | 欧美熟妇另类久久久久久不卡 | 国产精品理论片在线观看 | 香港三级日本三级妇三级 | 亚洲欧洲日本无在线码 | 免费无码的av片在线观看 | www国产亚洲精品久久网站 | 日韩视频 中文字幕 视频一区 | 蜜桃无码一区二区三区 | 成人精品一区二区三区中文字幕 | 亚洲综合无码久久精品综合 | 免费人成在线视频无码 | 网友自拍区视频精品 | 国内综合精品午夜久久资源 | 欧美自拍另类欧美综合图片区 | 亚洲男人av天堂午夜在 | 国产av久久久久精东av | 中文字幕日产无线码一区 | 久久精品国产一区二区三区 | 中文字幕+乱码+中文字幕一区 | 欧美人与物videos另类 | 一区二区传媒有限公司 | 97无码免费人妻超级碰碰夜夜 | 国产内射老熟女aaaa | 久久97精品久久久久久久不卡 | 亚洲国产av美女网站 | 欧美人与善在线com | 日日摸夜夜摸狠狠摸婷婷 | 亚洲欧美国产精品专区久久 | 亚洲精品成a人在线观看 | 丰满肥臀大屁股熟妇激情视频 | 日韩av无码一区二区三区 | 久久国语露脸国产精品电影 | 国产综合色产在线精品 | 免费国产成人高清在线观看网站 | 欧美国产日韩久久mv | 国产在线无码精品电影网 | 国产极品视觉盛宴 | 亚洲色www成人永久网址 | 一二三四在线观看免费视频 | 久久午夜夜伦鲁鲁片无码免费 | 一本大道久久东京热无码av | 少妇厨房愉情理9仑片视频 | 精品午夜福利在线观看 | 成熟妇人a片免费看网站 | 丝袜 中出 制服 人妻 美腿 | 内射后入在线观看一区 | 午夜精品久久久久久久 | 未满成年国产在线观看 | 国产精品自产拍在线观看 | 国产综合色产在线精品 | 国产乱人伦av在线无码 | 扒开双腿疯狂进出爽爽爽视频 | 人妻少妇精品无码专区二区 | 精品国精品国产自在久国产87 | 亚洲日韩中文字幕在线播放 | 国产精品久免费的黄网站 | 国产明星裸体无码xxxx视频 | 国产亚洲精品久久久ai换 | 荫蒂添的好舒服视频囗交 | 国产精品永久免费视频 | 国产精品亚洲五月天高清 | 色五月五月丁香亚洲综合网 | 国产激情综合五月久久 | 国产一区二区三区精品视频 | 荫蒂添的好舒服视频囗交 | 久久久国产一区二区三区 | 欧美人与动性行为视频 | 国内丰满熟女出轨videos | 精品国产青草久久久久福利 | 无码午夜成人1000部免费视频 | 色综合久久久无码中文字幕 | 中国女人内谢69xxxxxa片 | 六月丁香婷婷色狠狠久久 | 国产精品欧美成人 | 无码人妻精品一区二区三区下载 | 中文无码精品a∨在线观看不卡 | 精品欧美一区二区三区久久久 | 亚洲成色www久久网站 | 午夜精品久久久久久久久 | 熟女少妇在线视频播放 | 久久久久成人精品免费播放动漫 | 麻豆md0077饥渴少妇 | 国产亚洲欧美在线专区 | 国产成人精品久久亚洲高清不卡 | 人人妻人人藻人人爽欧美一区 | 国内精品一区二区三区不卡 | 国内少妇偷人精品视频免费 | 国产成人一区二区三区在线观看 | 成人精品视频一区二区 | 日日碰狠狠躁久久躁蜜桃 | 国精品人妻无码一区二区三区蜜柚 | 国产精品第一国产精品 | 中文字幕无码日韩欧毛 | 性生交大片免费看l | 无套内谢的新婚少妇国语播放 | 色综合久久中文娱乐网 | 亚洲成a人片在线观看无码 | 又大又黄又粗又爽的免费视频 | 国产精品-区区久久久狼 | 成人性做爰aaa片免费看不忠 | 午夜福利一区二区三区在线观看 | 精品日本一区二区三区在线观看 | 老熟妇仑乱视频一区二区 | 国内精品九九久久久精品 | 亚洲国产日韩a在线播放 | 免费中文字幕日韩欧美 | 蜜臀av无码人妻精品 | 国产综合在线观看 | 99re在线播放 | 特大黑人娇小亚洲女 | 真人与拘做受免费视频一 | 国产一区二区三区精品视频 | 少妇人妻大乳在线视频 | 亚洲一区二区三区 | 亚洲国产精华液网站w | 日欧一片内射va在线影院 | 亚洲色欲久久久综合网东京热 | 国产成人无码a区在线观看视频app | 毛片内射-百度 | 免费无码一区二区三区蜜桃大 | ass日本丰满熟妇pics | 亚洲 a v无 码免 费 成 人 a v | 国产人妻人伦精品1国产丝袜 | 日本免费一区二区三区最新 | 欧美性生交活xxxxxdddd | 精品一区二区三区波多野结衣 | 曰本女人与公拘交酡免费视频 | 久久亚洲日韩精品一区二区三区 | 夜夜高潮次次欢爽av女 | 丰满护士巨好爽好大乳 | 欧美日韩一区二区三区自拍 | 精品厕所偷拍各类美女tp嘘嘘 | 女人被爽到呻吟gif动态图视看 | 久久国产劲爆∧v内射 | 日本护士毛茸茸高潮 | 99久久婷婷国产综合精品青草免费 | 国产av剧情md精品麻豆 | 国产亚洲精品精品国产亚洲综合 | 1000部夫妻午夜免费 | 两性色午夜免费视频 | 99riav国产精品视频 | 精品国产一区二区三区四区在线看 | 欧美freesex黑人又粗又大 | 麻豆蜜桃av蜜臀av色欲av | 亚洲一区二区三区 | 中文字幕无码视频专区 | 乌克兰少妇xxxx做受 | 一本色道久久综合狠狠躁 | 中文精品无码中文字幕无码专区 | 日本一区二区三区免费高清 | 国产精品久久精品三级 | 亚洲熟妇色xxxxx欧美老妇 | 久久aⅴ免费观看 | 国产黑色丝袜在线播放 | 国产亚洲精品精品国产亚洲综合 | 激情内射日本一区二区三区 | 少妇性l交大片欧洲热妇乱xxx | 一个人看的视频www在线 | 欧美三级不卡在线观看 | 大色综合色综合网站 | 亚洲精品国偷拍自产在线观看蜜桃 | 欧美日韩人成综合在线播放 | 色综合视频一区二区三区 | 香港三级日本三级妇三级 | 99国产欧美久久久精品 | 国产综合色产在线精品 | 强辱丰满人妻hd中文字幕 | 欧美亚洲日韩国产人成在线播放 | 色婷婷综合中文久久一本 | 少妇性l交大片欧洲热妇乱xxx | 人人超人人超碰超国产 | 欧美国产亚洲日韩在线二区 | 日本护士毛茸茸高潮 | 老司机亚洲精品影院 | 亚洲日韩av一区二区三区四区 | 国产精品无码一区二区桃花视频 | 妺妺窝人体色www在线小说 | 日本精品高清一区二区 | 人妻体内射精一区二区三四 | 久久精品人人做人人综合 | 三上悠亚人妻中文字幕在线 | 强伦人妻一区二区三区视频18 | 精品人妻人人做人人爽夜夜爽 | 国产一区二区三区四区五区加勒比 | 色狠狠av一区二区三区 | 色妞www精品免费视频 | 久久这里只有精品视频9 | 欧美日韩一区二区三区自拍 | 国产成人无码a区在线观看视频app | 国产口爆吞精在线视频 | 国产精品久久久久久亚洲毛片 | 性啪啪chinese东北女人 | 十八禁真人啪啪免费网站 | 亚洲精品午夜国产va久久成人 | 强伦人妻一区二区三区视频18 | 无码一区二区三区在线观看 | 日本熟妇乱子伦xxxx | 日产国产精品亚洲系列 | 性色欲情网站iwww九文堂 | 啦啦啦www在线观看免费视频 | 动漫av网站免费观看 | 欧美三级不卡在线观看 | 国产精品丝袜黑色高跟鞋 | 亚洲色成人中文字幕网站 | 亚洲一区二区三区香蕉 | 一本久道久久综合婷婷五月 | 天天躁日日躁狠狠躁免费麻豆 | 男人和女人高潮免费网站 | 熟妇人妻无码xxx视频 | 成 人影片 免费观看 | 一本久道久久综合婷婷五月 | 国产偷国产偷精品高清尤物 | 强伦人妻一区二区三区视频18 | 亚洲综合色区中文字幕 | 亚洲午夜无码久久 | 亚洲成av人影院在线观看 | 影音先锋中文字幕无码 | 免费男性肉肉影院 | 亚洲国产综合无码一区 | 国产深夜福利视频在线 | 女人被爽到呻吟gif动态图视看 | 久久久久免费看成人影片 | 性做久久久久久久免费看 | 亚洲乱码国产乱码精品精 | 亚洲精品久久久久久久久久久 | 日本欧美一区二区三区乱码 | 2020最新国产自产精品 | 色欲久久久天天天综合网精品 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 中文字幕无码av激情不卡 | 亚洲成av人片在线观看无码不卡 | 亚洲精品一区二区三区婷婷月 | 2020最新国产自产精品 | 亚洲码国产精品高潮在线 | 又粗又大又硬毛片免费看 | 欧美黑人巨大xxxxx | 丰满岳乱妇在线观看中字无码 | 免费看男女做好爽好硬视频 | 亚洲精品午夜国产va久久成人 | 国产女主播喷水视频在线观看 | 免费观看激色视频网站 | 亚洲中文字幕在线观看 | 一二三四在线观看免费视频 | 国产九九九九九九九a片 | 国产成人精品一区二区在线小狼 | 天天做天天爱天天爽综合网 | 激情国产av做激情国产爱 | 精品国产青草久久久久福利 | 熟女少妇在线视频播放 | 波多野结衣aⅴ在线 | 国产精品对白交换视频 | 撕开奶罩揉吮奶头视频 | 夜夜躁日日躁狠狠久久av | 久久久久成人精品免费播放动漫 | 国产精品亚洲综合色区韩国 | 六十路熟妇乱子伦 | 日日夜夜撸啊撸 | 国产热a欧美热a在线视频 | 狂野欧美性猛xxxx乱大交 | 老司机亚洲精品影院 | 99久久人妻精品免费二区 | 无码国产乱人伦偷精品视频 | 丰满妇女强制高潮18xxxx | 亚洲精品久久久久avwww潮水 | а√资源新版在线天堂 | 女人色极品影院 | 日本在线高清不卡免费播放 | 色狠狠av一区二区三区 | 色婷婷综合激情综在线播放 | 东京热一精品无码av | 久久综合狠狠综合久久综合88 | 美女扒开屁股让男人桶 | 欧美日本精品一区二区三区 | 亚洲国产欧美日韩精品一区二区三区 | 色偷偷人人澡人人爽人人模 | 久久久精品成人免费观看 | 国产av一区二区三区最新精品 | 国产xxx69麻豆国语对白 | 国内精品人妻无码久久久影院 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 超碰97人人射妻 | 97精品国产97久久久久久免费 | 大乳丰满人妻中文字幕日本 | 国产成人午夜福利在线播放 | 久久综合久久自在自线精品自 | 18精品久久久无码午夜福利 | 97精品人妻一区二区三区香蕉 | 亚洲va欧美va天堂v国产综合 | 日韩少妇白浆无码系列 | 国产精品无码久久av | 天干天干啦夜天干天2017 | 国产精品人妻一区二区三区四 | 人妻夜夜爽天天爽三区 | 香蕉久久久久久av成人 | 午夜时刻免费入口 | 樱花草在线播放免费中文 | 亚洲国产日韩a在线播放 | 国产小呦泬泬99精品 | 国产成人人人97超碰超爽8 | 成人亚洲精品久久久久 | 人妻有码中文字幕在线 | 成人亚洲精品久久久久软件 | 欧美日韩色另类综合 | 狂野欧美性猛交免费视频 | 色综合久久久久综合一本到桃花网 | 精品日本一区二区三区在线观看 | 性欧美videos高清精品 | a国产一区二区免费入口 | 波多野结衣乳巨码无在线观看 | 奇米影视7777久久精品 | 丰满护士巨好爽好大乳 | 国产精品无码成人午夜电影 | 国产精品成人av在线观看 | 97无码免费人妻超级碰碰夜夜 | 久久精品一区二区三区四区 | 午夜福利一区二区三区在线观看 | 国产成人无码专区 | 999久久久国产精品消防器材 | 亚洲国产精品久久久久久 | 国产免费久久久久久无码 | 丰满少妇熟乱xxxxx视频 | 少妇性l交大片欧洲热妇乱xxx | 性色欲网站人妻丰满中文久久不卡 | 内射爽无广熟女亚洲 | 精品无码国产自产拍在线观看蜜 | 好爽又高潮了毛片免费下载 | 亚洲成色www久久网站 | 亚洲成熟女人毛毛耸耸多 | 久久午夜无码鲁丝片 | 精品无码av一区二区三区 | 狂野欧美性猛xxxx乱大交 | 久久久av男人的天堂 | 亚洲日韩av一区二区三区四区 | 欧美激情内射喷水高潮 | 蜜桃av抽搐高潮一区二区 | 激情内射日本一区二区三区 | 狠狠色丁香久久婷婷综合五月 | 亚洲欧洲日本无在线码 | 久久精品国产日本波多野结衣 | 亚洲精品久久久久中文第一幕 | 亚洲中文字幕在线观看 | 国产精品久久国产三级国 | 性做久久久久久久久 | 国产精品理论片在线观看 | 成在人线av无码免观看麻豆 | 国产9 9在线 | 中文 | 久久99精品国产麻豆蜜芽 | 无人区乱码一区二区三区 | 久久久精品国产sm最大网站 | 成人女人看片免费视频放人 | 亚洲人成人无码网www国产 | 亚洲中文字幕无码中字 | 亚洲国产精品一区二区美利坚 | 兔费看少妇性l交大片免费 | 久在线观看福利视频 | 国精产品一区二区三区 | 亚洲а∨天堂久久精品2021 | 成年女人永久免费看片 | 国产精品亚洲综合色区韩国 | 粉嫩少妇内射浓精videos | 中文亚洲成a人片在线观看 | 日本又色又爽又黄的a片18禁 | 人人澡人摸人人添 | 午夜精品久久久久久久 | 性欧美牲交xxxxx视频 | 精品 日韩 国产 欧美 视频 | 久久久婷婷五月亚洲97号色 | 少妇一晚三次一区二区三区 | 熟妇激情内射com | 76少妇精品导航 | 老熟妇仑乱视频一区二区 | 国产人妻久久精品二区三区老狼 | 亚洲日韩一区二区 | 成人aaa片一区国产精品 | 亚洲自偷自偷在线制服 | 中文字幕精品av一区二区五区 | 亚洲爆乳无码专区 | 又紧又大又爽精品一区二区 | 黑人巨大精品欧美一区二区 | 无码中文字幕色专区 | 国产精品理论片在线观看 | 久久久中文字幕日本无吗 | 动漫av一区二区在线观看 | 国产成人av免费观看 | 九九热爱视频精品 | 国内精品久久久久久中文字幕 | 国产精品久久久久久久影院 | 亚洲色欲色欲欲www在线 | 成在人线av无码免观看麻豆 | 又色又爽又黄的美女裸体网站 | 欧美日韩一区二区三区自拍 | 国产精品久久国产三级国 | 国产电影无码午夜在线播放 | 日韩精品无码一本二本三本色 | а√资源新版在线天堂 | 国产99久久精品一区二区 | 精品乱子伦一区二区三区 | 国产色精品久久人妻 | 国产后入清纯学生妹 | 国产精品久久久一区二区三区 | 亚洲欧美色中文字幕在线 | 无码人妻精品一区二区三区下载 | 无码帝国www无码专区色综合 | 中文字幕乱码亚洲无线三区 | 中文精品无码中文字幕无码专区 | 中文字幕无线码免费人妻 | 久久精品中文字幕大胸 | 亚洲午夜久久久影院 | 人人妻人人澡人人爽人人精品 | 成人女人看片免费视频放人 | 无码人妻黑人中文字幕 | 国产特级毛片aaaaaa高潮流水 | 久久国产精品精品国产色婷婷 | 成人精品视频一区二区三区尤物 | 亚洲熟女一区二区三区 | 中文亚洲成a人片在线观看 | 国产精品第一区揄拍无码 | 国产三级久久久精品麻豆三级 | 国产一区二区三区日韩精品 | √天堂中文官网8在线 | 国产真实伦对白全集 | 亚洲人成网站免费播放 | 无套内谢的新婚少妇国语播放 | 成人精品一区二区三区中文字幕 | 伊人久久大香线蕉亚洲 | 国产国语老龄妇女a片 | 亚洲精品成人av在线 | 国产猛烈高潮尖叫视频免费 | 亚洲成色www久久网站 | 人妻无码久久精品人妻 | 性啪啪chinese东北女人 | 乌克兰少妇xxxx做受 | 丁香啪啪综合成人亚洲 | 日韩av无码一区二区三区 | 99久久精品无码一区二区毛片 | 荫蒂被男人添的好舒服爽免费视频 | 久久aⅴ免费观看 | 亚洲精品中文字幕 | 东京热无码av男人的天堂 | 黑人玩弄人妻中文在线 | 亚洲高清偷拍一区二区三区 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲va欧美va天堂v国产综合 | 1000部夫妻午夜免费 | 成人一区二区免费视频 | 在线成人www免费观看视频 | 精品人妻人人做人人爽夜夜爽 | 2019nv天堂香蕉在线观看 | 色五月五月丁香亚洲综合网 | 国产av无码专区亚洲awww | 无码任你躁久久久久久久 | 日韩av无码中文无码电影 | 国产麻豆精品一区二区三区v视界 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲精品一区二区三区四区五区 | 亚洲色欲色欲天天天www | 国产高清av在线播放 | 久久99精品国产麻豆蜜芽 | 免费人成网站视频在线观看 | 亚洲综合无码一区二区三区 | 丰满妇女强制高潮18xxxx | 中文字幕人妻无码一区二区三区 | 欧美日韩一区二区免费视频 | 亚洲精品美女久久久久久久 | 欧美国产日韩久久mv | 亚洲综合无码一区二区三区 | 亚洲精品一区二区三区婷婷月 | 在线观看免费人成视频 | 高潮毛片无遮挡高清免费视频 | 九九热爱视频精品 | 老子影院午夜伦不卡 | 色窝窝无码一区二区三区色欲 | 免费乱码人妻系列无码专区 | 成在人线av无码免观看麻豆 | 亚洲色大成网站www国产 | 日韩在线不卡免费视频一区 | 粗大的内捧猛烈进出视频 | 欧美性生交活xxxxxdddd | 粗大的内捧猛烈进出视频 | 精品熟女少妇av免费观看 | 樱花草在线播放免费中文 | 伊人久久大香线蕉亚洲 | 精品成在人线av无码免费看 | 久久这里只有精品视频9 | 国内精品九九久久久精品 | 国产精品内射视频免费 | 久久精品国产一区二区三区肥胖 | 人人妻人人藻人人爽欧美一区 | 天天做天天爱天天爽综合网 | 一本久久a久久精品vr综合 | 99er热精品视频 | 国产艳妇av在线观看果冻传媒 | 人人澡人摸人人添 | 国产精品va在线播放 | 中文无码成人免费视频在线观看 | 捆绑白丝粉色jk震动捧喷白浆 | 欧美性猛交内射兽交老熟妇 | 日本丰满熟妇videos | 亚洲人成人无码网www国产 | 日韩精品久久久肉伦网站 | 无码国产激情在线观看 | 波多野结衣 黑人 | 国产精品va在线播放 | 国产亚洲精品久久久久久久 | 亚洲欧洲中文日韩av乱码 | 最近中文2019字幕第二页 | 日本丰满护士爆乳xxxx | 国产精品办公室沙发 | 日韩视频 中文字幕 视频一区 | 老熟妇仑乱视频一区二区 | 精品一区二区不卡无码av | 天天av天天av天天透 | 亚洲国产欧美在线成人 | 两性色午夜视频免费播放 | 男女性色大片免费网站 | 亚洲gv猛男gv无码男同 | 香蕉久久久久久av成人 | 丰满人妻被黑人猛烈进入 | 久久久久久av无码免费看大片 | 无码乱肉视频免费大全合集 | 人人澡人摸人人添 | 国产成人无码午夜视频在线观看 | 国产人妖乱国产精品人妖 | 国产精品久久久久久亚洲毛片 | 人妻少妇精品无码专区动漫 | 人妻少妇精品无码专区动漫 | 精品午夜福利在线观看 | 亚洲精品中文字幕乱码 | 国产在线无码精品电影网 | 水蜜桃av无码 | 国产精品内射视频免费 | 国内精品九九久久久精品 | 日本精品少妇一区二区三区 | 亚洲一区二区三区无码久久 | 丰满诱人的人妻3 | 国产午夜精品一区二区三区嫩草 | 性欧美videos高清精品 | 国产97人人超碰caoprom | 高清国产亚洲精品自在久久 | 精品国精品国产自在久国产87 | 国产尤物精品视频 | 一个人看的视频www在线 | 亚洲精品成人福利网站 | 成人亚洲精品久久久久软件 | 亚洲中文字幕va福利 | 国产猛烈高潮尖叫视频免费 | 人人爽人人爽人人片av亚洲 | 欧美日韩亚洲国产精品 | 亚洲 欧美 激情 小说 另类 | 久久国内精品自在自线 | 国产熟妇另类久久久久 | 无码人中文字幕 | 天堂亚洲免费视频 | 久激情内射婷内射蜜桃人妖 | 国产农村乱对白刺激视频 | 中文字幕无码av激情不卡 | 少妇人妻偷人精品无码视频 | 熟妇人妻中文av无码 | √天堂资源地址中文在线 | 草草网站影院白丝内射 | 欧美大屁股xxxxhd黑色 | 夫妻免费无码v看片 | 亚洲中文字幕在线观看 | 国产内射爽爽大片视频社区在线 | 伊人色综合久久天天小片 | 久久久国产一区二区三区 | 对白脏话肉麻粗话av | 好爽又高潮了毛片免费下载 | 青青青爽视频在线观看 | 久久久久se色偷偷亚洲精品av | 成人免费视频一区二区 | 国産精品久久久久久久 | 女人被男人爽到呻吟的视频 | 99久久精品国产一区二区蜜芽 | 亚洲综合在线一区二区三区 | 久久久无码中文字幕久... | 欧美猛少妇色xxxxx | 婷婷色婷婷开心五月四房播播 | 久久国产精品_国产精品 | 精品欧美一区二区三区久久久 | 97色伦图片97综合影院 | 伊人久久大香线焦av综合影院 | 又色又爽又黄的美女裸体网站 | 色诱久久久久综合网ywww | 黑人巨大精品欧美黑寡妇 | 欧美黑人巨大xxxxx | 沈阳熟女露脸对白视频 | 亚洲精品综合五月久久小说 | 夫妻免费无码v看片 | 国产舌乚八伦偷品w中 | 99久久久国产精品无码免费 | 四虎影视成人永久免费观看视频 | 午夜成人1000部免费视频 | 波多野结衣高清一区二区三区 | 99久久久国产精品无码免费 | 夜精品a片一区二区三区无码白浆 | 亚洲欧洲无卡二区视頻 | 两性色午夜视频免费播放 | 国产亚洲精品久久久久久国模美 | 最近中文2019字幕第二页 | 老子影院午夜伦不卡 | 麻豆果冻传媒2021精品传媒一区下载 | 狠狠cao日日穞夜夜穞av | 蜜臀av在线播放 久久综合激激的五月天 | 国产真人无遮挡作爱免费视频 | 综合激情五月综合激情五月激情1 | 精品熟女少妇av免费观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久国产精品精品国产色婷婷 | 天海翼激烈高潮到腰振不止 | 亚洲国产午夜精品理论片 | 亚洲精品久久久久中文第一幕 | 免费乱码人妻系列无码专区 | a在线观看免费网站大全 | 成人免费无码大片a毛片 | 99久久久国产精品无码免费 | 在线欧美精品一区二区三区 | 亚洲色欲色欲欲www在线 | 国产人妻久久精品二区三区老狼 | 又湿又紧又大又爽a视频国产 | 成人欧美一区二区三区黑人免费 | 曰韩少妇内射免费播放 | 欧美日本免费一区二区三区 | 97人妻精品一区二区三区 | 东京热一精品无码av | 99久久精品无码一区二区毛片 | aa片在线观看视频在线播放 | 国产亚洲精品久久久久久久久动漫 | 激情五月综合色婷婷一区二区 | 久久综合色之久久综合 | 精品无码av一区二区三区 | 在线观看国产午夜福利片 | 亚洲日韩av一区二区三区四区 | 夜夜高潮次次欢爽av女 | 丰满人妻翻云覆雨呻吟视频 | 亚洲精品国产精品乱码不卡 | 狠狠噜狠狠狠狠丁香五月 | 国产suv精品一区二区五 | 免费播放一区二区三区 | 老熟女乱子伦 | 一区二区三区乱码在线 | 欧洲 | 欧美人妻一区二区三区 | 婷婷色婷婷开心五月四房播播 | 少妇无套内谢久久久久 | 成人精品视频一区二区三区尤物 | 红桃av一区二区三区在线无码av | 永久免费观看美女裸体的网站 | 在教室伦流澡到高潮hnp视频 | 亚洲 日韩 欧美 成人 在线观看 | 人妻少妇精品久久 | 亚洲日本一区二区三区在线 | 2020久久超碰国产精品最新 | 亚洲精品午夜国产va久久成人 | 成人毛片一区二区 | 一区二区三区高清视频一 | 欧美日韩一区二区免费视频 | 亚洲精品一区二区三区四区五区 | 欧美日韩在线亚洲综合国产人 | 两性色午夜视频免费播放 | 亲嘴扒胸摸屁股激烈网站 | 亚洲综合在线一区二区三区 | 大地资源中文第3页 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产精华av午夜在线观看 | 成人精品视频一区二区三区尤物 | 久久久久亚洲精品男人的天堂 | 精品偷拍一区二区三区在线看 | 无码一区二区三区在线观看 | 日本一区二区三区免费高清 | 少妇无套内谢久久久久 | 高潮毛片无遮挡高清免费 | 自拍偷自拍亚洲精品10p | 久久精品女人天堂av免费观看 | 色一情一乱一伦一视频免费看 | 成人免费无码大片a毛片 | 丝袜 中出 制服 人妻 美腿 | 国产亚洲美女精品久久久2020 | 99精品无人区乱码1区2区3区 | 狂野欧美激情性xxxx | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 中文字幕人妻无码一区二区三区 | 亚洲阿v天堂在线 | 高清国产亚洲精品自在久久 | 久久精品国产亚洲精品 | 亚洲成av人在线观看网址 | 国产亚洲精品久久久久久国模美 | 国产精品久久久午夜夜伦鲁鲁 | 精品人妻av区 | 国产精品美女久久久久av爽李琼 | 无码国产乱人伦偷精品视频 | 在线欧美精品一区二区三区 | 国产精品亚洲五月天高清 | 97无码免费人妻超级碰碰夜夜 | 亚洲娇小与黑人巨大交 | 天堂亚洲2017在线观看 | 无码国产激情在线观看 | 亚洲а∨天堂久久精品2021 | 又大又紧又粉嫩18p少妇 | 中文字幕精品av一区二区五区 | 一个人看的www免费视频在线观看 | 国产午夜亚洲精品不卡 | 中文字幕中文有码在线 | 免费无码一区二区三区蜜桃大 | 欧美老人巨大xxxx做受 | 日韩人妻无码一区二区三区久久99 | 无遮挡啪啪摇乳动态图 | 人妻有码中文字幕在线 | 2019nv天堂香蕉在线观看 | 免费无码av一区二区 | 东京热一精品无码av | 黑人巨大精品欧美黑寡妇 | 日日碰狠狠躁久久躁蜜桃 | 亚洲中文字幕无码中文字在线 | 久久婷婷五月综合色国产香蕉 | 国产精品福利视频导航 | 大肉大捧一进一出视频出来呀 | 夫妻免费无码v看片 | 人妻与老人中文字幕 | 久久久久久久人妻无码中文字幕爆 | 色老头在线一区二区三区 | 国产美女精品一区二区三区 | 精品久久久无码人妻字幂 | 色综合天天综合狠狠爱 | 日本又色又爽又黄的a片18禁 | 一本一道久久综合久久 | 精品国产aⅴ无码一区二区 | 小sao货水好多真紧h无码视频 | 人妻有码中文字幕在线 | 欧美一区二区三区视频在线观看 | 无码精品国产va在线观看dvd | 亚洲天堂2017无码中文 | 无人区乱码一区二区三区 | 999久久久国产精品消防器材 | 亚洲区欧美区综合区自拍区 | 国产在线精品一区二区高清不卡 | 老子影院午夜精品无码 | 亚洲精品一区二区三区四区五区 | 亚洲人成影院在线观看 | 亚洲欧美色中文字幕在线 | 久久精品成人欧美大片 | 国产精品亚洲а∨无码播放麻豆 | 亚洲中文字幕在线无码一区二区 | 伊人色综合久久天天小片 | 人人超人人超碰超国产 | 丰满人妻一区二区三区免费视频 | 精品国偷自产在线 | 亚洲欧美精品aaaaaa片 | 麻豆人妻少妇精品无码专区 | v一区无码内射国产 | 欧美激情综合亚洲一二区 | 国产熟妇另类久久久久 | 国产精品无码久久av | 国产精品国产自线拍免费软件 | 中文字幕无码av激情不卡 | 天下第一社区视频www日本 | 日日躁夜夜躁狠狠躁 | 国产特级毛片aaaaaaa高清 | 奇米影视7777久久精品 | 久久国产精品二国产精品 | 中文字幕无线码免费人妻 | 久久精品国产亚洲精品 | 久久精品国产99久久6动漫 | 青青草原综合久久大伊人精品 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲一区二区三区播放 | 正在播放老肥熟妇露脸 | 精品国产乱码久久久久乱码 | 97久久精品无码一区二区 | 成人免费视频一区二区 | 美女扒开屁股让男人桶 | 日韩在线不卡免费视频一区 | 日本免费一区二区三区最新 | 亚洲中文字幕无码中文字在线 | 麻豆国产人妻欲求不满 | 国产一区二区不卡老阿姨 | 国产亚洲美女精品久久久2020 | 黑人玩弄人妻中文在线 | 18精品久久久无码午夜福利 | 日韩亚洲欧美精品综合 | 精品偷自拍另类在线观看 | 亚洲第一无码av无码专区 |