精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從 0 到 1 實現:AI 版你畫我猜小游戲

人工智能 前端
全民AI時代,前端er該如何蹭上這波熱度?本文將一步步帶大家了解前端應該如何結合端側AI模型,實現一個AI版你畫我猜小游戲。

01、引言

近幾年AI的進化速度堪比科幻片——昨天還在調教ChatGPT寫詩,今天Sora已經能生成電影級畫面了。技術圈仿佛被AI“腌入味”了,說不定連這篇文章都是DeepSeek幫忙寫的(狗頭)。

前端er的野望:當其他行業忙著用AI造火箭時,我們這群和瀏覽器“斗智斗勇”的手藝人,該怎么蹭上這波熱度?

在深入思考如何蹭上熱度之前,首先,我們需要先簡單了解下AI模型的分類。

1.1云端模型和端側模型

從模型的部署方式上來看,AI模型可以簡單分為云端模型(Cloud Model)和端側模型(On-Device Model)兩種。

  • 云端模型:將模型部署在服務集群上,提供一些API能力供端側來調用,端側無需處理計算部分,只需調用API獲取計算結果即可。比如OpenAI的官方API就是如此。
  • 端側模型:直接將模型部署在終端設備上,模型的計算、推理完全依賴終端設備,具有更高的實時性、私密性、安全性,但同時對終端設備等硬件要求也較高。

對于前端來說,由于其非常依賴瀏覽器和終端設備性能,所以原本最適合前端的方式其實是直接調用云端模型API,把計算的負擔轉嫁給服務集群,頁面只需負責展示結果即可。但通常情況下,搭建集群、訓練模型、定制API有很高的資源門檻和成本,現實條件往往不允許我們這樣做。

因此,我們可以轉而考慮利用端側模型來賦能。

1.2大語言模型和特定領域模型

端側模型從概念上來區分,又可以簡單分為大語言模型和特定領域模型。

大語言模型

其中大語言模型(Large Language Model,LLM)就是我們熟知的ChatGPT、DeepSeek、Grok這類模型,它們功能強大,但對設備的性能要求很高,以DeepSeek為例,即使是最小的1.5B版本模型,也至少需要RTX 3060+級別的顯卡才能帶得動,并且模型本身的大小已經達到1.1GB,并不適合部署在前端項目中。



模型版本





參數量





模型大小





顯存





GPU





R1 1.5B





15億





1.1 GB





4–5 GB





RTX 3060 12GB



特定領域模型

所以,最終留給我們的選項就是利用一些特定領域模型來賦能前端,它們可以用來處理某些特定領域的問題。例如,利用視覺(CNN、MobileNet)模型實現圖像分類、人臉檢測,或者利用自然語言模型(NLP)實現問答機器人、文本惡意檢測等。

這些模型等特征是尺寸較小,并且對設備性能要求不高,非常適合直接部署在前端并實現一些AI交互。

所以,接下來我們就來看看,如何從0到1訓練一個圖像分類模型(Doodle Classifier based on CNN),并將模型集成至前端頁面,實現一個經典你畫我猜小游戲-端側AI版。

02、你畫我猜AI版-玩法簡介

動手實踐之前,先來簡單介紹下你畫我猜AI版的玩法,它和普通版本你畫我猜的區別在于:玩家根據提示詞進行涂鴉,由AI來預測玩家畫的詞是什么,如果AI順利猜對玩家畫的詞,則玩家得分。

例如,提示詞是“長城”,則玩家需要通過畫板手繪一個長城,盡量畫的像一些,讓AI猜出正確答案就能得分。

了解了基礎玩法之后,接下來正片開始,詳細介紹如何從零到一開始實現它。

我們提供了簡化版的 live demo,你可以訪問鏈接試試看。同時我們也提供了相關的 demo代碼,你可以隨時訪問github倉庫,下載和嘗試運行它。

03、訓練模型

首先,第一步是訓練模型。

根據上面的玩法簡介,我們知道它本質上是一個基于視覺的圖片分類AI模型,而這個模型的功能是:輸入圖片數據后,模型可以計算出圖片的分類置信結果。例如,輸入一張小貓的圖片,模型的分類計算結果可能為:[貓 90%,狗8%,豬2%],表示模型認為這張圖有90%的概率是只貓,8%的概率是條狗,2%概率是只豬。

這樣一來,我們通過將用戶手繪的canvas中的圖片數據丟給模型,并把模型輸出的置信概率最大的分類當作AI的猜測結果,就可以模擬出AI猜詞的互動了。

而實現這個模型也很簡單,但我們需要了解一些深度學習神經網絡的知識以及tensorflow.js的基礎用法。如果對這兩者不太熟悉,可能需要先自行google一下,做點知識儲備。

那么假設大家已經有了一些基礎的神經網絡、TensorFlow.js基礎知識,就可以利用TensorFlow.js輕松搭建一個基于CNN的圖片分類模型。

3.1獲取數據集

在進入模型訓練之前,我們需要先獲取數據集。

數據集是訓練模型的基礎,我們可以自己創建數據集(這很困難、費時),或者尋找一些開源數據集。剛好Google Lab提供了一套完整的開源涂鴉數據集(The Quick Draw Dataset),數據集中包含了345個不同類別的涂鴉數據集合,總共有5000萬份涂鴉數據,足夠我們挑選使用。


我們可以直接訪問開源涂鴉數據集(The Quick Draw Dataset)下載所需的數據。點擊頁面右上角的Get the Data 跳轉github倉庫,可以看到文檔中列出了多種數據類型:

這里我們直接選擇下載Numpy bitmap files

注意:這里的數據集有345種類別,如果全部進行訓練的話,訓練時間會很長并且最終的模型大小較大,因此,我們可以視情況挑選其中的部分詞匯,例如選擇80個詞匯進行訓練,對于一款小游戲來說,詞匯量也足夠了。

3.2搭建模型和訓練模型

下載完訓練數據之后,接下來我們需要搭建模型結構并進行模型訓練。

如果我們下載了demo代碼,可以看到項目結構如下,主要內容為3個部分:

項目目錄/
├── ?? src/                    
│   ├── ?? index.ts            # 程序入口文件
│   ├── ?? data/               # 數據集
│   │   ├── ?? Apple.npy
│   │   ├── ?? The Great Wall.npy  
│   │   └── ?? ...       
│   └── ?? model/              # 訓練模型相關
│       ├── ?? doodle-data.model.ts  # 數據加載
│       └── ?? classifier.model.ts   # 模型結構
├── ?? package.json

-data目錄:存放訓練數據集

-model目錄:

  • doodle-data.model.ts:數據加載預處理
  • classifier.model.ts:定義模型結構

-index.ts:訓練程序入口

先來看項目的index.ts入口文件,功能非常簡單,主要邏輯就是四步:

  • 加載訓練數據
  • 創建模型
  • 訓練模型
  • 保存模型參數
import { Classifier } from './model/classifier.model';
import { DoodleData } from './model/doodle-data.model';


async function main(){
  const data = new DoodleData({
    directoryData: 'src/data',
    maxImageClass: 20000
  });


  // 1. 加載訓練數據
  data.loadData();
  // 2. 創建模型
  const model = new Classifier(data);
  // 3. 訓練模型
  await model.train();
  // 4. 保存模型參數
  await model.save();
}


main();

了解了核心流程之后,再來詳細看下model目錄下的兩個核心文件:doodle-data.model.ts和classifier.model.ts。

首先是doodle-data.model.ts ,它的核心代碼如下,主要是加載data目錄下的數據,并將數據預處理為tensor張量,后續可于訓練模型。

// 加載data目錄下的數據
loadData() {
  this.classes = fs.readdirSync(this.directoryData)
    .filter((x) => x.endsWith('.npy'))
    .map((x) => x.replace('.npy', ''));
}


// 數據生成器,預處理數據為tensor張量
*dataGenerator() {
  // ...
  for (let j = 0; j < bytes.length; j = j + this.IMAGE_SIZE) {
    const singleImage = bytes.slice(j, j + this.IMAGE_SIZE);
    const image = tf
      .tensor(singleImage)
      .reshape([this.IMAGE_WIDTH, this.IMAGE_HEIGHT, 1])
      .toFloat();
    const xs = image.div(offset);
    const ys = tf.tensor(this.classes.map((x) => (x === label ? 1 : 0)));
    yield { xs, ys };
  }
}

其次是,classifier.model.ts。它的核心代碼如下,代碼的主要功能是:

構建了一個基于CNN的圖像分類模型。通過tf.layers.conv3d()構造了卷積神經網絡結構。

提供了train()方法,用于訓練模型。這里定義了模型訓練的迭代次數(epochs)、訓練的批次大小(batchSize),這些參數會影響模型訓練的最終結果,就是通常我們所說的“模型調參”,當你覺得模型訓練效果不佳時,可以調整這些參數重新訓練,直到達成不錯的準確率。

提供了save()方法,用于保存模型參數。

import * as tf from "@tensorflow/tfjs-node";
import { DoodleData } from "./doodle-data.model";


exportclassClassifier {
  // ...
  // 定義模型結構
  constructor(data: DoodleData) {
    this.data = data;
    this.model = tf.sequential();
    this.model.add(
      tf.layers.conv2d({
        inputShape: [data.IMAGE_WIDTH, data.IMAGE_HEIGHT, 1],
        kernelSize: 3,
        filters: 16,
        strides: 1,
        activation: "relu",
        kernelInitializer: "varianceScaling",
      })
    );
    this.model.add(
      tf.layers.maxPooling2d({
        poolSize: [2, 2],
        strides: [2, 2],
      })
    );
    this.model.add(
      tf.layers.conv2d({
        kernelSize: 3,
        filters: 32,
        strides: 1,
        activation: "relu",
        kernelInitializer: "varianceScaling",
      })
    );
    this.model.add(
      tf.layers.maxPooling2d({
        poolSize: [2, 2],
        strides: [2, 2],
      })
    );
    this.model.add(tf.layers.flatten());
    this.model.add(
      tf.layers.dense({
        units: this.data.totalClasses,
        kernelInitializer: "varianceScaling",
        activation: "softmax",
      })
    );


    const optimizer = tf.train.adam();
    this.model.compile({
      optimizer,
      loss: "categoricalCrossentropy",
      metrics: ["accuracy"],
    });
  }


  // 模型訓練
  async train(){
    const trainingData = tf.data
      .generator(() => this.data.dataGenerator("train"))
      .shuffle(this.data.maxImageClass * this.data.totalClasses)
      .batch(64);


    const testData = tf.data
      .generator(() => this.data.dataGenerator("test"))
      .shuffle(this.data.maxImageClass * this.data.totalClasses)
      .batch(64);


    await this.model.fitDataset(trainingData, {
      epochs: 5,
      validationData: testData,
      callbacks: {
        onEpochEnd: async (epoch, logs) => {
          this.logger.debug(
            `Epoch: ${epoch} - acc: ${logs?.acc.toFixed(
              3
            )} - loss: ${logs?.loss.toFixed(3)}`
          );
        },
        onBatchBegin: async (epoch, logs) => {
          console.log("onBatchBegin" + epoch + JSON.stringify(logs));
        },
      },
    });
  }


  // 保存模型
  async save(){
    fs.mkdirSync("doodle-model", { recursive: true });
    fs.writeFileSync(
      "doodle-model/classes.json",
      JSON.stringify({ classes: this.data.classes })
    );
    await this.model.save("file://./doodle-model");
  }
}

如果我們從github倉庫下載了demo代碼,在根目錄下執行:

npm run start

開啟模型訓練過程,會有一些輸出如下,表示當前的訓練輪次、識別準確率、損失等。

onBatchBegin0{"batch":0,"size":512}
onBatchBegin1{"batch":1,"size":512}
onBatchBegin2{"batch":2,"size":512}
onBatchBegin3{"batch":3,"size":512}
onBatchBegin4{"batch":4,"size":192}
...
[Classifier] Epoch: 0 - acc: 0.078 - loss: 2.632
...

耐心等待日志打完,模型訓練完成之后,我們的項目目錄下就會產出一個額外的目錄,存放模型的訓練結果。

  • classes.json:圖片的所有分類,根據data目錄中的數據文件名稱生成
  • model.json:模型的描述文件
  • weights.bin:模型的參數文件
項目目錄/
├── ?? doodle-model/           # 訓練結果(最終模型)
│   │   ├── ?? classes.json    # 圖片分類     
│   │   ├── ?? model.json      # 模型描述文件
│   │   └── ?? weights.bin     # 模型參數

這樣,我們的模型就訓練完成了。

接下來看看如何在頁面中集成模型,實現從繪制canvas圖片到模型分類預測的效果。

04、集成至頁面

在頁面中的集成模型也非常簡單,我們只需要創建一個可以繪圖的canvas,每隔一段時間就將當前canvas的圖像數據傳輸給模型,觸發一次模型預測即可。

先來看下項目的核心目錄結構:

項目目錄/
├── ?? public/assets/doodle-modle/   # 將訓練生成的模型放置在public目錄下
│   │   ├── ?? classes.json    # 圖片分類     
│   │   ├── ?? model.json      # 模型描述文件
│   │   └── ?? weights.bin     # 模型參數
├── ?? src   
│   ├── ?? models/               
│   │   └── ?? DoodleClassifier.js  # 圖片分類器
│   ├── ?? views/               
│   │   └── ?? DoodleView.vue   # 頁面視圖(canvas畫布)

其中,DoodleClassifier.js的核心代碼如下:

  • loadModel:加載模型,包括model.json、classes.json,在model.json中會自動加載weights.bin
  • predictTopN:輸入圖片數據,調用model.predict() 預測最有可能的TopN個分類結果,并按照置信度排序
import * as tf from "@tensorflow/tfjs";
import apiClient from "@/services/http";


// 加載模型
async loadModel(){
  this.model = await tf.loadLayersModel("assets/doodle-model/model.json");
  const response = await apiClient.get("assets/doodle-model/classes.json");
  this.classes = response.data.classes; 
}


// 預測最有可能的TopN個分類,并按照置信度排序
async predictTopN(data, n){
  const predictions = Array.from(await this.model.predict(data).data());


  const indexedPredictions = predictions.map((probability, index) => ({
    probability,
    index,
  }));


  indexedPredictions.sort((a, b) => b.probability - a.probability);


  const topNPredictions = indexedPredictions.slice(0, n);


  return topNPredictions.map((p) => ({
    label: this.classes[p.index],
    accuracy: p.probability,
  }));
}


// 預測分類結果
async predict(data){
  const argMax = await this.model.predict(data).argMax(-1).data();
  returnthis.classes[argMax[0]];
}

DoodleView.vue的核心代碼如下:

  • 調用new DoodleClassifier()構造圖片分類器
  • 調用loadModel()加載模型
  • 預處理canvas的圖片數據
  • 將預處理的數據傳輸給model.predictTopN(),預測圖片分類
// 構造圖片分類器
this.model = new DoodleClassifier()


// 加載模型
this.model.loadModel()


// 預處理canvas圖片數據
const tensor = tf.browser.fromPixels(imgData, 1);
const resized = tf.image
  .resizeBilinear(tensor, [28, 28])
  .reshape([1, 28, 28, 1]) // Reshape to [1, 28, 28, 1] for batch and single channel
  .toFloat();
const normalized = tf.scalar(1.0).sub(resized.div(tf.scalar(255.0)));


// 預測圖片分類
this.model.predictTopN(normalized, 5).then((predictions) => {
  if (predictions) {
    this.predictions = predictions;
  }
});

到這為止,你畫我猜-AI版就已經基本搭建完成了。實現起來并不復雜。

如果一切順利,并且你按照我們提供的demo構建頁面,就可以直接在項目中運行:

npm run serve

一個簡易版本的你畫我猜AI版就運行成功了,試試看吧。

05、優化措施

通過上面的步驟,我們完成了模型訓練和canvas圖片分類預測的全流程,成功實現了你畫我猜AI版。但實際上可能會遇到兩個比較關鍵的問題。

5.1數據標準化

當我們去調整canvas畫布大小、畫筆粗細后,可能會出現預測結果不準確的情況,此時從canvas獲取的圖像數據和我們喂給模型的訓練數據產生了差異。

這時候我們需要在獲取到canvas數據后,額外做一些數據預處理,將數據標準化,例如:

  • 將畫布的內容區域裁剪為正方形,并居中顯示
  • 將畫布的線條適當變粗,使模型更容易識別

5.2利用 webworker 優化性能

模型的計算過程是十分耗時的,將計算過程放在主線程會導致頁面卡頓,因此我們可以將整個模型的預測部分放入webworker中,以此來提升計算性能,不影響頁面渲染。

06、總結

你畫我猜-端側AI版是前端結合AI的一個簡單案例,為我們提供了前端利用AI賦能的大致思路和基本實現邏輯。條件允許的情況下,我們可以利云端模型來拓展前端業務。但如果缺乏資源,我們則轉而考慮使用端側的特定領域模型來產出一些新玩法、新交互。相比之下,端側AI具有更強的靈活性、安全性和更低的集成成本。大家可以試著在各自的業務中探索和使用端側AI,或許無法產出太大的效益,但也是在全民AI時代下,一些積極的嘗試和沉淀。

07、參考

部分代碼參考自:

責任編輯:龐桂玉 來源: vivo互聯網技術
相關推薦

2012-03-28 22:12:00

游戲

2012-03-26 15:08:22

我畫你猜

2018-07-19 17:36:34

谷歌AIAPP

2015-09-29 09:38:50

Java程序猜大小

2024-12-02 11:24:30

Docker編排技術

2011-01-13 14:29:54

2016-11-28 16:23:23

戴爾

2022-05-09 08:35:43

面試產品互聯網

2012-11-05 10:18:21

云存儲你畫我猜云服務

2021-08-15 22:52:30

前端H5拼圖

2011-05-04 11:31:09

Windows PhoWindows Pho游戲開發

2012-03-26 21:32:38

2022-02-09 20:50:46

短鏈系統場景

2023-08-07 15:18:29

游戲開發鴻蒙Arkts

2025-01-20 10:40:08

2021-03-10 09:21:00

Spring開源框架Spring基礎知識

2023-03-06 11:35:55

經營分析體系

2021-07-01 07:03:32

開發Webpack代碼

2024-06-07 09:13:23

點贊
收藏

51CTO技術棧公眾號

亚洲区国产区| 亚洲天堂一区二区| 国产sm精品调教视频网站| 久久久免费精品视频| mm131丰满少妇人体欣赏图| 四虎国产精品永久在线国在线| 国产二区国产一区在线观看| 久久久欧美精品| 国产欧美小视频| 国偷自产视频一区二区久| 欧美艳星brazzers| 2018国产在线| 快射视频在线观看| 久久久久久久综合狠狠综合| 91久久嫩草影院一区二区| 日韩 欧美 中文| 99久久夜色精品国产亚洲96| 精品一区二区三区四区在线| 性鲍视频在线观看| 成人自拍视频网| 婷婷一区二区三区| 蜜桃麻豆91| 国产成人精品亚洲精品色欲| 自拍偷拍欧美| 亚洲成av人乱码色午夜| www.亚洲高清| 中文字幕影音在线| 亚洲综合精品自拍| 一级二级三级欧美| 免费在线观看一级毛片| 播五月开心婷婷综合| 96国产粉嫩美女| 久久中文字幕在线观看| 久久在线视频| 日韩欧美视频一区| jizzzz日本| 久久亚洲精品爱爱| 欧美三级xxx| 国产96在线 | 亚洲| 性xxxfreexxxx性欧美| av在线不卡免费看| av在线不卡一区| 91av在线免费视频| 一区免费视频| 久久久久久久999| 久久久久久久黄色| 欧美日韩视频一区二区三区| 久热99视频在线观看| 日本一卡二卡在线| 成人国产精品一区二区免费麻豆| 亚洲精品免费在线观看| 青青成人在线| 伦理片一区二区三区| 91首页免费视频| 92看片淫黄大片看国产片| 伊人久久亚洲综合| 久久精品国产亚洲a| 97热精品视频官网| 精品人妻一区二区三区四区| 久久99国内| 日韩精品一区在线观看| 波多野吉衣在线视频| 综合久久成人| 日韩av综合网站| 91亚洲一区二区| 国产一区二区三区| 欧美videos中文字幕| 91视频在线免费| 色狼人综合干| 精品1区2区在线观看| 美女久久久久久久久| 美女午夜精品| 国产午夜精品一区理论片飘花| www.美色吧.com| 蜜臀av一区| 一区三区二区视频| 日韩欧美123区| 欧美成免费一区二区视频| 视频直播国产精品| 欧美 日韩 国产 一区二区三区 | 婷婷综合五月天| 亚洲三区视频| 污污视频在线| 狠狠躁夜夜躁人人爽超碰91| 国产日韩成人内射视频| 嗯啊主人调教在线播放视频 | 欧美日韩国产黄色| 久久久久久久久久久妇女| 欧美噜噜久久久xxx| 日日夜夜综合网| 国内精品久久久久影院薰衣草| 国产成人福利网站| 黄色片中文字幕| 久久精品国产色蜜蜜麻豆| 国产精品久久久久免费| 裸体xxxx视频在线| 亚洲影视资源网| 看欧美ab黄色大片视频免费 | 精品久久中文字幕| 亚洲污视频在线观看| 天堂精品在线视频| 亚洲欧洲成视频免费观看| 亚洲一级生活片| 国产精品丝袜xxxxxxx| 91美女高潮出水| 国产私拍精品| 亚洲高清视频的网址| 精品亚洲一区二区三区四区| 99香蕉久久| 亚洲精美色品网站| 国产视频精品免费| 噜噜噜91成人网| 国产精品丝袜久久久久久高清 | 久久国产精品亚洲77777| 欧美在线精品免播放器视频| 国产一区二区自拍视频| 久久午夜电影网| 神马一区二区影院| 爱啪啪综合导航| 色天天综合色天天久久| 久草福利在线观看| 欧美hd在线| 国产精品草莓在线免费观看| 污视频软件在线观看| 亚洲男人都懂的| 日韩肉感妇bbwbbwbbw| 私拍精品福利视频在线一区| 中文字幕无线精品亚洲乱码一区| 免费在线观看a级片| 欧美视频四区| 91亚洲国产成人精品性色| 你懂的网站在线| 国产亚洲精品福利| 自慰无码一区二区三区| 91p九色成人| 日韩免费性生活视频播放| 这里只有精品在线观看视频| 久久精品免费一区二区三区| 国产精品入口66mio| 一道本无吗dⅴd在线播放一区| 中文幕无线码中文字蜜桃| 成人精品久久| 国产精品第8页| 久久综合九色综合久| 欧美日韩国产在线播放| 亚洲国产精品三区| 精品久久久久久久| 久久免费观看视频| 亚洲第一视频在线| 亚洲五码中文字幕| 91九色蝌蚪porny| 99精品久久| 久久青青草原一区二区| 忘忧草在线影院两性视频| 欧美高清视频一二三区| 人妻丰满熟妇aⅴ无码| 亚洲精品在线二区| 精品不卡一区二区三区| 秋霞伦理一区| 国产亚洲一区二区在线| 国产精品白嫩白嫩大学美女| 香蕉久久a毛片| 日本在线观看一区| 国产黄大片在线观看| 亚洲精品国产综合久久| youjizz在线视频| 国产精品日韩成人| 欧洲美女亚洲激情| 欧美午夜久久| 美日韩精品免费| 开心久久婷婷综合中文字幕| 国产精品亚洲人成在99www| 另类视频在线观看| 天堂网视频在线| 成人福利视频在线| 国产成人免费高清视频| 超碰成人在线免费| 欧美在线视频一区二区| 97电影在线看视频| 日韩欧美成人一区| 少妇高潮av久久久久久| 国产精品传媒在线| 黄色激情在线观看| 日本不卡一二三区黄网| 国产免费xxx| 亚洲精品国产精品粉嫩| 91精品国产综合久久男男| 国产盗摄在线视频网站| 亚洲精品资源美女情侣酒店| 亚洲图片小说视频| 亚洲无线码一区二区三区| 自拍偷拍亚洲天堂| 国产精品77777| 干日本少妇视频| 台湾色综合娱乐中文网| 国产色婷婷国产综合在线理论片a| 超碰国产在线| 欧美亚洲愉拍一区二区| 久久久久久久久久久97| 国产aⅴ综合色| 国产精品三级一区二区| 亚洲精品在线a| 国产成人精品久久| 在线看三级电影| 国产一区二区三区在线观看网站 | 亚洲一区二区免费| 中文字幕高清在线播放| 欧美久久久精品| 黄色av免费在线看| 精品处破学生在线二十三| 中文精品久久久久人妻不卡| 亚洲图片自拍偷拍| 欧美日韩午夜视频| 26uuu亚洲综合色| 99热成人精品热久久66| 欧美日韩国产探花| 一区二区三区欧美在线| 国产精品美女久久久久| 国产精品久久久久秋霞鲁丝| 性欧美video高清bbw| 这里只有精品视频| 美国一级片在线免费观看视频| 在线观看网站黄不卡| 黄网站免费在线| 1000精品久久久久久久久| 95视频在线观看| 国产美女久久久久| 欧美女同在线观看| 男人的天堂久久精品| 国产又粗又大又爽的视频| 狠狠操综合网| 蜜桃av噜噜一区二区三| 人人网欧美视频| 国产成人av一区二区三区| 精品一区二区三区中文字幕视频| 高清一区二区三区四区五区| 青春草在线观看| 亚洲第一中文字幕在线观看| 性欧美18一19性猛交| 日韩视频在线一区二区| 99久久久国产精品无码网爆| 在线播放亚洲一区| 天堂资源在线播放| 亚洲一区二区三区中文字幕| 久久精品国产亚洲av久| 久久蜜臀精品av| 无码人妻精品一区二区三应用大全| 美女精品一区二区| 日韩肉感妇bbwbbwbbw| 麻豆国产91在线播放| 蜜桃视频一区二区在线观看| 亚洲国产一区二区在线观看| 中文字幕一区二区三区5566| 亚洲国产精品久久久天堂| 综合一区中文字幕| 中国成人一区| 日韩国产成人无码av毛片| 黄色成人av网站| 日本欧美黄色片| 久久社区一区| 亚洲区成人777777精品| 狠色狠色综合久久| 国产二级片在线观看| 日韩精品亚洲一区| 青草网在线观看| 99综合在线| 国产精品亚洲二区在线观看| 日本在线播放一区二区三区| 高清av免费看| 国产精品羞羞答答xxdd| 91n.com在线观看| 精品一区二区三区免费毛片爱| 日本精品免费在线观看| 亚洲一本视频| 啊啊啊一区二区| 奇米一区二区三区| www.污网站| 成人动漫一区二区三区| 国产一二三四五区| 亚洲丝袜制服诱惑| 日韩欧美中文字幕一区二区| 亚洲欧美乱综合| 欧美三级视频网站| 2024国产精品| 日本成人精品视频| 婷婷国产在线综合| 亚洲一级片免费看| 亚洲第一精品久久忘忧草社区| 99久久亚洲精品日本无码 | 日韩精品在线免费视频| 亚洲va中文字幕| 日韩精品久久久久久久| 欧美亚洲高清一区| 亚洲国产成人一区二区| 日韩你懂的电影在线观看| 女人天堂在线| 亚洲人成网站色ww在线| av片在线观看免费| 国产成人精品av在线| aiss精品大尺度系列| 亚洲不卡1区| 精品福利久久久| 国产尤物av一区二区三区| 日韩电影在线观看电影| 天天视频天天爽| 成人免费观看视频| 免费看特级毛片| 一本大道久久a久久精品综合| 一级黄色av片| 亚洲成年网站在线观看| 久做在线视频免费观看| 国产91热爆ts人妖在线| 加勒比久久高清| 黄色影视在线观看| 奇米777欧美一区二区| 亚洲最大天堂网| 久久久99免费| 国产视频91在线| 狠狠色丁香婷综合久久| 国产精品久久久久久久久免费看 | 在线观看日本www| 久久久青草青青国产亚洲免观| 你懂得视频在线观看| 高跟丝袜一区二区三区| 精品欧美一区二区精品少妇| 色七七影院综合| 精品无人乱码一区二区三区| 久久久久久久久久码影片| 激情丁香综合| 国产探花一区二区三区| 亚洲婷婷综合色高清在线| 在线观看国产一区二区三区| 亚洲奶大毛多的老太婆| 中日韩脚交footjobhd| 国产精品视频免费观看| 深夜福利久久| 国产亚洲欧美在线视频| 成人av网在线| 日本三级网站在线观看| 欧美中文字幕一区二区三区| 日本aaa在线观看| 欧美在线视频导航| 亚洲国产精品嫩草影院久久av| 中文字幕欧美人与畜| 亚洲人成在线影院| 北京富婆泄欲对白| 亚洲特黄一级片| 国产福利第一页| 久久91超碰青草是什么| 66精品视频在线观看| 给我免费播放片在线观看| 成人免费视频网站在线观看| xxxx日本黄色| 欧美日韩一区二区三区四区| 天天操天天射天天舔| 97久久精品人人澡人人爽缅北| 不卡精品视频| 特级西西人体www高清大胆| 国产99精品国产| 手机免费观看av| 欧美精品第1页| 亚洲小说区图片区都市| 国产精品一区视频| 久久国产精品亚洲77777| 手机毛片在线观看| 欧美老人xxxx18| 色呦呦在线免费观看| 国产一区免费在线观看| 久久激情网站| 欧美风情第一页| 欧美性生活一区| 黄视频网站在线| 国产精品久久久久久久久男| 亚州av乱码久久精品蜜桃 | 国产理论电影在线| 国产一区二区不卡视频| 日韩综合小视频| 亚洲视频重口味| 精品成a人在线观看| 澳门av一区二区三区| 国产一区在线免费观看| 欧美黄色一区| 国产黄色网址在线观看| 亚洲国产视频在线| 免费福利在线观看| 亚洲精品欧美一区二区三区| 99精品久久| 国产精品丝袜一区二区| 国产视频精品免费播放| av在线亚洲一区| 男女av免费观看| 久久久精品中文字幕麻豆发布| 久草手机在线观看| 日韩中文字幕在线视频| 国产精品午夜av| www欧美激情| 欧美日韩一区二区在线 | 国产综合av| 2019日韩中文字幕mv| 国产精品三级视频|