波多野结衣简介_爱的色放3_欧美精品一区二_五月亚洲婷婷_美女被娇喘视频_亚洲午夜免费_好吊色视频988gao在线观看_在线一区_99久久精品免费视频_欧美色吊丝_亚洲色图小说_亚洲两性视频_男女做的视频_亚洲自拍图片_免费黄色一级片

資訊專欄INFORMATION COLUMN

Canvas + WebSocket + Redis 實現一個視頻彈幕

WelliJhon / 832人閱讀

摘要:創建彈幕功能的類及基本參數處理布局時需要注意的默認寬為,高為,我們要保證完全覆蓋整個視頻,需要讓與寬高相等。因為我們不確定每一個使用該功能的視頻的寬高都是一樣的,所以畫布的寬高并沒有通過來設置,而是通過在類創建實例初始化屬性的時候動態設置。


閱讀原文


頁面布局

首先,我們需要實現頁面布局,在根目錄創建 index.html 布局中我們需要有一個 video 多媒體標簽引入我們的本地視頻,添加輸入彈幕的輸入框、確認發送的按鈕、顏色選擇器、字體大小滑動條,創建一個 style.css 來調整頁面布局的樣式,這里我們順便創建一個 index.js 文件用于后續實現我們的核心邏輯,先引入到頁面當中。

HTML 布局代碼如下:





    
    
    視頻彈幕


    

Canvas + WebSocket + Redis 實現視頻彈幕

CSS 樣式代碼如下:

/* 文件:style.css */
#cantainer {
    text-align: center;
}
#content {
    width: 640px;
    margin: 0 auto;
    position: relative;
}
#canvas {
    position: absolute;
}
video {
    width: 640px;
    height: 360px;
}
input {
    vertical-align: middle;
}

布局效果如下圖:


定義接口,構造假數據

我們彈幕中的彈幕數據正常情況下應該是通過與后臺數據交互請求回來,所以我們需要先定義數據接口,并構造假數據來實現前端邏輯。

數據字段定義:

value:表示彈幕的內容(必填)

time:表示彈幕出現的時間(必填)

speed:表示彈幕移動的速度(選填)

color:表示彈幕文字的顏色(選填)

fontSize:表示彈幕的字體大小(選填)

opacity:表示彈幕文字的透明度(選填)

上面的 valuetime 是必填參數,其他的選填參數可以在前端設置默認值。

前端定義的假數據如下:

// 文件:index.js
let data = [
    {
        value: "這是第一條彈幕",
        speed: 2,
        time: 0,
        color: "red",
        fontSize: 20
    },
    {
        value: "這是第二條彈幕",
        time: 1
    }
];


實現前端彈幕的邏輯

我們希望是把彈幕封裝成一個功能,只要有需要的地方就可以使用,從而實現復用,那么不同的地方使用這個功能通常的方式是 new 一個實例,傳入當前使用該功能對應的參數,我們也使用這種方式來實現,所以我們需要封裝一個統一的構造函數或者類,參數為當前的 canvas 元素、video 元素和一個 options 對象,options 里面的 data 屬性為我們的彈幕數據,之所以不直接傳入 data 是為了后續參數的擴展,嚴格遵循開放封閉原則,這里我們就統一使用 ES6 的 class 類來實現。

1、創建彈幕功能的類及基本參數處理

布局時需要注意 Canvas 的默認寬為 300px,高為 150px,我們要保證 Canvas 完全覆蓋整個視頻,需要讓 Canvas 與 video 寬高相等。
因為我們不確定每一個使用該功能的視頻的寬高都是一樣的,所以 Canvas 畫布的寬高并沒有通過 CSS 來設置,而是通過 JS 在類創建實例初始化屬性的時候動態設置。

// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);
    }
}

應該掛在實例上的屬性除了有當前的 canvas 元素、video 元素、彈幕數據的默認選項以及彈幕數據之外,還應該有一個代表當前是否渲染彈幕的參數,因為視頻暫停的時候,彈幕也是暫停的,所以沒有重新渲染,因為是否暫停與彈幕是否渲染的狀態是一致的,所以我們這里就用 isPaused 參數來代表當前是否暫停或重新渲染彈幕,值類型為布爾值。

2、創建構造每一條彈幕的類

我們知道,后臺返回給我們的彈幕數據是一個數組,這個數組里的每一個彈幕都是一個對象,而對象上有著這條彈幕的信息,如果我們需要在每一個彈幕對象上再加一些新的信息或者在每一個彈幕對象的處理時用到了當前彈幕功能類 CanvasBarrage 實例的一些屬性值,取值顯然是不太方便的,這樣為了后續方便擴展,遵循開放封閉原則,我們把每一個彈幕的對象轉變成同一個類的實例,所以我們創建一個名為 Barrage 的類,讓我們每一條彈幕的對象進入這個類里面走一遭,掛上一些擴展的屬性。

// 文件:index.js
class Barrage {
    constructor(item, ctx) {
        this.value = item.value; // 彈幕的內容
        this.time = item.time; // 彈幕出現的時間
        this.item = item; // 每一個彈幕的數據對象
        this.ctx = ctx; // 彈幕功能類的執行上下文
    }
}

在我們的 CanvasBarrage 類上有一個存儲彈幕數據的數組 data,此時我們需要給 CanvasBarrage 增加一個屬性用來存放 “加工” 后的每條彈幕對應的實例。

// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);

        // ********** 以下為新增代碼 **********
        // 存放所有彈幕實例,Barrage 是創造每一條彈幕的實例的類
        this.barrages = this.data.map(item => new Barrage(item, this));
        // ********** 以上為新增代碼 **********
    }
}

其實通過上面操作以后,我們相當于把 data 里面的每一條彈幕對象轉換成了一個 Barrage 類的一個實例,把當前的上下文 this 傳入后可以隨時在每一個彈幕實例上獲取 CanvasBarrage 類實例的屬性,也方便我們后續擴展方法,遵循這種開放封閉原則的方式開發,意義是不言而喻的。

3、在 CanvasBarrage 類實現渲染所有彈幕的 render 方法

CanvasBarragerender 方法是在創建彈幕功能實例的時候應該渲染 Canvas 所以應該在 CanvasBarrage 中調用,在 render 內部,每一次渲染之前都應該先將 Canvas 畫布清空,所以需要給當前的 CanvasBarrage 類新增一個屬性用于存儲 Canvas 畫布的內容。

// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);

        // 存放所有彈幕實例,Barrage 是創造每一條彈幕的實例的類
        this.barrages = this.data.map(item => new Barrage(item, this));

        // ********** 以下為新增代碼 **********
        // Canvas 畫布的內容
        this.context = canvas.getContext("2d");

        // 渲染所有的彈幕
        this.render();
        // ********** 以上為新增代碼 **********
    }

    // ********** 以下為新增代碼 **********
    render() {
        // 渲染整個彈幕
        // 第一次先進行清空操作,執行渲染彈幕,如果沒有暫停,繼續渲染
        this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        // 渲染彈幕
        this.renderBarrage();
        if (this.isPaused == false) {
            // 遞歸渲染
            requestAnimationFrame(this.render.bind(this));
        }
    }
    // ********** 以上為新增代碼 **********
}

在上面的 CanvasBarragerender 函數中,清空時由于 Canvas 性能比較好,所以將整個畫布清空,所以從坐標 (0, 0) 點,清空的寬高為整個 Canvas 畫布的寬高。

只要視頻是在播放狀態應該不斷的調用 render 方法實現清空畫布、渲染彈幕、判斷是否暫停,如果非暫停狀態繼續渲染,所以我們用到了遞歸調用 render 去不斷的實現渲染,但是遞歸時如果直接調用 render,性能特別差,程序甚至會掛掉,以往這種情況我們會在遞歸外層加一個 setTimeout 來定義一個短暫的遞歸時間,但是這個過程類似于動畫效果,如果使用 setTimeout 其實是將同步代碼轉成了異步執行,會增加不確定性導致畫面出現卡頓的現象。

這里我們使用 H5 的新 API requestAnimationFrame,可以在平均 1/60 S 內幫我執行一次該方法傳入的回調,我們直接把 render 函數作為回調函數傳入 requestAnimationFrame,該方法是按照幀的方式執行,動畫流暢,需要注意的是,render 函數內使用了 this,所以應該處理一下 this 指向問題。

由于我們使用面向對象的方式,所以渲染彈幕的具體細節,我們抽離出一個多帶帶的方法 renderBarrage,接下來看一下 renderBarrage 的實現。

4、CanvasBarrage 類 render 內部 renderBarrage 的實現
// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);

        // 存放所有彈幕實例,Barrage 是創造每一條彈幕的實例的類
        this.barrages = this.data.map(item => new Barrage(item, this));

        // Canvas 畫布的內容
        this.context = canvas.getContext("2d");

        // 渲染所有的彈幕
        this.render();
    }
    render() {
        // 渲染整個彈幕
        // 第一次先進行清空操作,執行渲染彈幕,如果沒有暫停,繼續渲染
        this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        // 渲染彈幕
        this.renderBarrage();
        if (this.isPaused == false) {
            // 遞歸渲染
            requestAnimationFrame(this.render.bind(this));
        }
    }

    // ********** 以下為新增代碼 **********
    renderBarrage() {
        // 將數組的彈幕一個一個取出,判斷時間和視頻的時間是否符合,符合就執行渲染此彈幕
        let time = this.video.currentTime;
        this.barrages.forEach(barrage => {
            // 當視頻時間大于等于了彈幕設置的時間,那么開始渲染(時間都是以秒為單位)
            if (time >= barrage.time) {
                // 初始化彈幕的各個參數,只有在彈幕將要出現的時候再去初始化,節省性能,初始化后再進行繪制
                // 如果沒有初始化,先去初始化一下
                if (!barrage.isInited) {
                    // 初始化后下次再渲染就不需要再初始化了,所以創建一個標識 isInited
                    barrage.init();
                    barrage.isInited = true;
                }
            }
        });
    }
    // ********** 以上為新增代碼 **********
}

此處的 renderBarrage 方法內部主要對每一條彈幕實例所設置的出現時間和視頻的播放時間做對比,如果視頻的播放時間大于等于了彈幕出現的時間,說明彈幕需要繪制在 Canvas 畫布內。

之前我們的每一條彈幕實例的屬性可能不全,彈幕的其他未傳參數并沒有初始化,所以為了最大限度的節省性能,我們在彈幕該第一次繪制的時候去初始化參數,等到視頻播放的時間變化再去重新繪制時,不再初始化參數,所以初始化參數的方法放在了判斷彈幕出現時間的條件里面執行,又設置了代表彈幕實例是不是初始化了的參數 isInited,初始化函數 init 執行過一次后,馬上修改 isInited 的值,保證只初始化參數一次。

renderBarrage 方法中我們可以看出來,其實我們是循環了專門存放每一條彈幕實例(Barrage 類的實例)的數組,我們在內部用實例去調用的方法 init 應該是在 Barrage 類的原型上,下面我們去 Barrage 類上實現 init 的邏輯。

5、Barrage 類 init 的實現
// 文件:index.js
class Barrage {
    constructor(item, ctx) {
        this.value = item.value; // 彈幕的內容
        this.time = item.time; // 彈幕出現的時間
        this.item = item; // 每一個彈幕的數據對象
        this.ctx = ctx; // 彈幕功能類的執行上下文
    }

    // ********** 以下為新增代碼 **********
    init() {
        this.opacity = this.item.opacity || this.ctx.opacity;
        this.color = this.item.color || this.ctx.color;
        this.fontSize = this.item.fontSize || this.ctx.fontSize;
        this.speed = this.item.speed || this.ctx.speed;

        // 求自己的寬度,目的是用來校驗當前是否還要繼續繪制(邊界判斷)
        let span = document.createElement("span");

        // 能決定寬度的只有彈幕的內容和文字的大小,和字體,字體默認為微軟雅黑,我們就不做設置了
        span.innerText = this.value;
        span.style.font = this.fontSize + "px "Microsoft YaHei";

        // span 為行內元素,取不到寬度,所以我們通過定位給轉換成塊級元素
        span.style.position = "absolute";

        document.body.appendChild(span); // 放入頁面
        this.width = span.clientWidth; // 記錄彈幕的寬度
        document.body.removeChild(span); // 從頁面移除

        // 存儲彈幕出現的橫縱坐標
        this.x = this.ctx.canvas.width;
        this.y = this.ctx.canvas.height;

        // 處理彈幕縱向溢出的邊界處理
        if (this.y < this.fontSize) {
            this.y = this.fontSize;
        }
        if (this.y > this.ctx.canvas.height - this.fontSize) {
            this.y = this.ctx.canvas.height - this.fontSize;
        }
    }
    // ********** 以上為新增代碼 **********
}

在上面代碼的 init 方法中我們其實可以看出,每條彈幕實例初始化的時候初始的信息除了之前說的彈幕的基本參數外,還獲取了每條彈幕的寬度(用于后續做彈幕是否已經完全移出屏幕的邊界判斷)和每一條彈幕的 xy 軸方向的坐標并為了防止彈幕在 y 軸顯示不全做了邊界處理。

6、實現每條彈幕的渲染和彈幕移除屏幕的處理

我們當時在 CanvasBarrage 類的 render 方法中的渲染每個彈幕的方法 renderBarrage中(原諒這么啰嗦,因為到現在內容已經比較多,說的具體一點方便知道是哪個步驟,哈哈)只做了對每一條彈幕實例的初始化操作,并沒有渲染在 Canvas 畫布中,這時我們主要做兩部操作,實現每條彈幕渲染在畫布中和左側移出屏幕不再渲染的邊界處理。

// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);

        // 存放所有彈幕實例,Barrage 是創造每一條彈幕的實例的類
        this.barrages = this.data.map(item => new Barrage(item, this));

        // Canvas 畫布的內容
        this.context = canvas.getContext("2d");

        // 渲染所有的彈幕
        this.render();
    }
    render() {
        // 渲染整個彈幕
        // 第一次先進行清空操作,執行渲染彈幕,如果沒有暫停,繼續渲染
        this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        // 渲染彈幕
        this.renderBarrage();
        if (this.isPaused == false) {
            // 遞歸渲染
            requestAnimationFrame(this.render.bind(this));
        }
    }
    renderBarrage() {
        // 將數組的彈幕一個一個取出,判斷時間和視頻的時間是否符合,符合就執行渲染此彈幕
        let time = this.video.currentTime;
        this.barrages.forEach(barrage => {
            // ********** 以下為改動的代碼 **********
            // 當視頻時間大于等于了彈幕設置的時間,那么開始渲染(時間都是以秒為單位)
            if (!barrage.flag && time >= barrage.time) {
                // ********** 以上為改動的代碼 **********

                // 初始化彈幕的各個參數,只有在彈幕將要出現的時候再去初始化,節省性能,初始化后再進行繪制
                // 如果沒有初始化,先去初始化一下
                if (!barrage.isInited) {
                    // 初始化后下次再渲染就不需要再初始化了,所以創建一個標識 isInited
                    barrage.init();
                    barrage.isInited = true;
                }

                // ********** 以下為新增代碼 **********
                barrage.x -= barrage.speed;
                barrage.render(); // 渲染該條彈幕
                if (barrage.x < barrage.width * -1) {
                    barrage.flag = true; // 是否出去了,出去了,做停止渲染的操作
                }
                // ********** 以上為新增代碼 **********
            }
        });
    }
}

每個彈幕實例都有一個 speed 屬性,該屬性代表著彈幕移動的速度,換個說法其實就是每次減少的 x 軸的差值,所以我們其實是通過改變 x 軸的值再重新渲染而實現彈幕的左移,我們創建了一個標識 flag 掛在每個彈幕實例下,代表是否已經離開屏幕,如果離開則更改 flag 的值,使外層的 CanvasBarrage 類的 render 函數再次遞歸時不進入渲染程序。

每一條彈幕具體是怎么渲染的,通過代碼可以看出每個彈幕實例在 x 坐標改變后都調用了實例方法 render 函數,注意此 render 非彼 render,該 render 函數屬于 Barrage 類,目的是為了渲染每一條彈幕,而 CanvasBarrage 類下的 render,是為了在視頻時間變化時清空并重新渲染整個 Canvas 畫布。

7、Barrage 類下的 render 方法的實現
// 文件:index.js
class Barrage {
    constructor(item, ctx) {
        this.value = item.value; // 彈幕的內容
        this.time = item.time; // 彈幕出現的時間
        this.item = item; // 每一個彈幕的數據對象
        this.ctx = ctx; // 彈幕功能類的執行上下文
    }
    init() {
        this.opacity = this.item.opacity || this.ctx.opacity;
        this.color = this.item.color || this.ctx.color;
        this.fontSize = this.item.fontSize || this.ctx.fontSize;
        this.speed = this.item.speed || this.ctx.speed;

        // 求自己的寬度,目的是用來校驗當前是否還要繼續繪制(邊界判斷)
        let span = document.createElement("span");

        // 能決定寬度的只有彈幕的內容和文字的大小,和字體,字體默認為微軟雅黑,我們就不做設置了
        span.innerText = this.value;
        span.style.font = this.fontSize + "px "Microsoft YaHei";

        // span 為行內元素,取不到寬度,所以我們通過定位給轉換成塊級元素
        span.style.position = "absolute";

        document.body.appendChild(span); // 放入頁面
        this.width = span.clientWidth; // 記錄彈幕的寬度
        document.body.removeChild(span); // 從頁面移除

        // 存儲彈幕出現的橫縱坐標
        this.x = this.ctx.canvas.width;
        this.y = this.ctx.canvas.height;

        // 處理彈幕縱向溢出的邊界處理
        if (this.y < this.fontSize) {
            this.y = this.fontSize;
        }
        if (this.y > this.ctx.canvas.height - this.fontSize) {
            this.y = this.ctx.canvas.height - this.fontSize;
        }
    }

    // ********** 以下為新增代碼 **********
    render() {
        this.ctx.context.font = this.fontSize + "px "Microsoft YaHei"";
        this.ctx.context.fillStyle = this.color;
        this.ctx.context.fillText(this.value, this.x, this.y);
    }
    // ********** 以上為新增代碼 **********
}

從上面新增代碼我們可以看出,其實 Barrage 類的 render 方法只是將每一條彈幕的字號、顏色、內容、坐標等屬性通過 Canvas 的 API 添加到了畫布上。

8、實現播放、暫停事件

還記得我們的 CanvasBarrage 類里面有一個屬性 isPaused,屬性值控制了我們是否遞歸渲染,這個屬性與視頻暫停的狀態是一致的,我們在播放的時候,彈幕不斷的清空并重新繪制,當暫停的時候彈幕也應該跟著暫停,說白了就是不在調用 CanvasBarrage 類的 render 方法,其實就是在暫停、播放的過程中不斷的改變 isPaused 的值即可。

還記得我們之前構造的兩條假數據 data 吧,接下來我們添加播放、暫停事件,來嘗試使用一下我們的彈幕功能。

// 文件:index.js
// 實現一個簡易選擇器,方便獲取元素,后面獲取元素直接調用 $
const $ = document.querySelector.bind(document);

// 獲取 Canvas 元素和 Video 元素
let canvas = $("#canvas");
let video = $("#video");

let canvasBarrage = new CanvasBarrage(canvas, video, {
    data
});

// 添加播放事件
video.addEventListener("play", function() {
    canvasBarrage.isPaused = false;
    canvasBarrage.render();
});

// 添加暫停事件
video.addEventListener("pause", function() {
    canvasBarrage.isPaused = true;
});
9、實現發送彈幕事件
// 文件:index.js
$("#add").addEventListener("click", function() {
    let time = video.currentTime; // 發送彈幕的時間
    let value = $("#text").value; // 發送彈幕的文字
    let color = $("#color").value; // 發送彈幕文字的顏色
    let fontSize = $("#range").value; // 發送彈幕的字體大小
    let sendObj = { time, value, color, fontSize }; //發送彈幕的參數集合
    canvasBarrage.add(sendObj); // 發送彈幕的方法
});

其實我們發送彈幕時,就是向 CanvasBarrage 類的 barrages 數組里添加了一條彈幕的實例,我們多帶帶封裝了一個 add 的實例方法。

// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);

        // 存放所有彈幕實例,Barrage 是創造每一條彈幕的實例的類
        this.barrages = this.data.map(item => new Barrage(item, this));

        // Canvas 畫布的內容
        this.context = canvas.getContext("2d");

        // 渲染所有的彈幕
        this.render();
    }
    render() {
        // 渲染整個彈幕
        // 第一次先進行清空操作,執行渲染彈幕,如果沒有暫停,繼續渲染
        this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        // 渲染彈幕
        this.renderBarrage();
        if (this.isPaused == false) {
            // 遞歸渲染
            requestAnimationFrame(this.render.bind(this));
        }
    }
    renderBarrage() {
        // 將數組的彈幕一個一個取出,判斷時間和視頻的時間是否符合,符合就執行渲染此彈幕
        let time = this.video.currentTime;
        this.barrages.forEach(barrage => {
            // 當視頻時間大于等于了彈幕設置的時間,那么開始渲染(時間都是以秒為單位)
            if (!barrage.flag && time >= barrage.time) {
                // 初始化彈幕的各個參數,只有在彈幕將要出現的時候再去初始化,節省性能,初始化后再進行繪制
                // 如果沒有初始化,先去初始化一下
                if (!barrage.isInited) {
                    // 初始化后下次再渲染就不需要再初始化了,所以創建一個標識 isInited
                    barrage.init();
                    barrage.isInited = true;
                }

                barrage.x -= barrage.speed;
                barrage.render(); // 渲染該條彈幕
                if (barrage.x < barrage.width * -1) {
                    barrage.flag = true; // 是否出去了,出去了,做停止渲染的操作
                }
            }
        });
    }

    // ********** 以下為新增代碼 **********
    add(item) {
        this.barrages.push(new Barrage(item, this));
    }
    // ********** 以上為新增代碼 **********
}
10、拖動進度條實現彈幕的前進和后退

其實我們發現,彈幕雖然實現了正常的播放、暫停以及發送,但是當我們拖動進度條的時候彈幕應該是跟著視頻時間同步播放的,現在的彈幕一旦播放過無論怎樣拉動進度條彈幕都不會再出現,我們現在就來解決這個問題。

// 文件:index.js
// 拖動進度條事件
video.addEventListener("seeked", function() {
    canvasBarrage.reset();
});

我們在事件內部其實只是調用了一下 CanvasBarrage 類的 reset 方法,這個方法就是在拖動進度條的時候來幫我們初始化彈幕的狀態。

// 文件:index.js
class CanvasBarrage {
    constructor(canvas, video, options = {}) {
        // 如果沒有傳入 canvas 或者 video 直接跳出
        if (!canvas || !video) return;
        this.canvas = canvas; // 當前的 canvas 元素
        this.video = video; // 當前的 video 元素

        // 設置 canvas 與 video 等高
        this.canvas.width = video.clientWidth;
        this.canvas.height = video.clientHeight;

        // 默認暫停播放,表示不渲染彈幕
        this.isPaused = true;

        // 沒傳參數的默認值
        let defaultOptions = {
            fontSize: 20,
            color: "gold",
            speed: 2,
            opacity: 0.3,
            data: []
        };

        // 對象的合并,將默認參數對象的屬性和傳入對象的屬性統一放到當前實例上
        Object.assign(this, defaultOptions, options);

        // 存放所有彈幕實例,Barrage 是創造每一條彈幕的實例的類
        this.barrages = this.data.map(item => new Barrage(item, this));

        // Canvas 畫布的內容
        this.context = canvas.getContext("2d");

        // 渲染所有的彈幕
        this.render();
    }
    render() {
        // 渲染整個彈幕
        // 第一次先進行清空操作,執行渲染彈幕,如果沒有暫停,繼續渲染
        this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        // 渲染彈幕
        this.renderBarrage();
        if (this.isPaused == false) {
            // 遞歸渲染
            requestAnimationFrame(this.render.bind(this));
        }
    }
    renderBarrage() {
        // 將數組的彈幕一個一個取出,判斷時間和視頻的時間是否符合,符合就執行渲染此彈幕
        let time = this.video.currentTime;
        this.barrages.forEach(barrage => {
            // 當視頻時間大于等于了彈幕設置的時間,那么開始渲染(時間都是以秒為單位)
            if (!barrage.flag && time >= barrage.time) {
                // 初始化彈幕的各個參數,只有在彈幕將要出現的時候再去初始化,節省性能,初始化后再進行繪制
                // 如果沒有初始化,先去初始化一下
                if (!barrage.isInited) {
                    // 初始化后下次再渲染就不需要再初始化了,所以創建一個標識 isInited
                    barrage.init();
                    barrage.isInited = true;
                }

                barrage.x -= barrage.speed;
                barrage.render(); // 渲染該條彈幕
                if (barrage.x < barrage.width * -1) {
                    barrage.flag = true; // 是否出去了,出去了,做停止渲染的操作
                }
            }
        });
    }
    add(item) {
        this.barrages.push(new Barrage(item, this));
    }

    // ********** 以下為新增代碼 **********
    reset() {
        // 先清空 Canvas 畫布
        this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        let time = this.video.currentTime;
        // 循環每一條彈幕實例
        this.barrages.forEach(barrage => {
            // 更改已經移出屏幕的彈幕狀態
            barrage.flag = false;
            // 當拖動到的時間小于等于當前彈幕時間是,重新初始化彈幕的數據,實現渲染
            if (time <= barrage.time) {
                barrage.isInited = false;
            } else {
                barrage.flag = true; // 否則將彈幕的狀態設置為以移出屏幕
            }
        });
    }
    // ********** 以上為新增代碼 **********
}

其實 reset 方法中值做了幾件事:

清空 Canvas 畫布;

獲取當前進度條拖動位置的時間;

循環存儲彈幕實例的數組;

將所有彈幕更改為未移出屏幕;

判斷拖動時間和每條彈幕的時間;

在當前時間以后的彈幕重新初始化數據;

以前的彈幕更改為已移出屏幕。

從而實現了拖動進度條彈幕的 “前進” 和 “后退” 功能。


使用 WebSocket 和 Redis 實現前后端通信及數據存儲 1、服務器代碼的實現

要使用 WebSocket 和 Redis 首先需要去安裝 wsredis 依賴,在項目根目錄執行下面命令:

npm install ws redis

我們創建一個 server.js 文件,用來寫服務端的代碼:

// 文件:index.js
const WebSocket = require("ws"); // 引入 WebSocket
const redis = require("redis"); // 引入 redis

// 初始化 WebSocket 服務器,端口號為 3000
let wss = new WebSocket.Server({
    port: 3000
});

// 創建 redis 客戶端
let client = redis.createClient(); // key value

// 原生的 websocket 就兩個常用的方法 on("message")、on("send")
wss.on("connection", function(ws) {
    // 監聽連接
    // 連接上需要立即把 redis 數據庫的數據取出返回給前端
    client.lrange("barrages", 0, -1, function(err, applies) {
        // 由于 redis 的數據都是字符串,所以需要把數組中每一項轉成對象
        applies = applies.map(item => JSON.parse(item));

        // 使用 websocket 服務器將 redis 數據庫的數據發送給前端
        // 構建一個對象,加入 type 屬性告訴前端當前返回數據的行為,并將數據轉換成字符串
        ws.send(
            JSON.stringify({
                type: "INIT",
                data: applies
            })
        );
    });

    // 當服務器收到消息時,將數據存入 redis 數據庫
    ws.on("message", function(data) {
        // 向數據庫存儲時存的是字符串,存入并打印數據,用來判斷是否成功存入數據庫
        client.rpush("barrages", data, redis.print);

        // 再將當前這條數據返回給前端,同樣添加 type 字段告訴前端當前行為,并將數據轉換成字符串
        ws.send(
            JSON.stringify({
                type: "ADD",
                data: JSON.parse(data)
            })
        );
    });
});

服務器的邏輯很清晰,在 WebSocket 連接上時,立即獲取 Redis 數據庫的所有彈幕數據返回給前端,當前端點擊發送彈幕按鈕發送數據時,接收數據存入 Redis 數據庫中并打印驗證數據是否成功存入,再通過 WebSocket 服務把當前這一條數返回給前端,需要注意一下幾點:

從 Redis 數據庫中取出全部彈幕數據的數組內部都存儲的是字符串,需要使用 JSON.parse 方法進行解析;

將數據發送前端時,最外層要使用 JSON.stringify 重新轉換成字符串發送;

在初始化階段 WebSocket 發送所有數據和前端添加新彈幕 WebSocket 將彈幕的單條數據重新返回時,需要添加對應的 type 值告訴前端,當前的操作行為。

2、前端代碼的修改

在沒有實現后端代碼之前,前端使用的是 data 的假數據,是在添加彈幕事件中,將獲取的新增彈幕信息通過 CanvasBarrage 類的 add 方法直接創建 Barrage 類的實例,并加入到存放彈幕實例的 barrages 數組中。

現在我們需要更正一下交互邏輯,在發送彈幕事件觸發時,我們應該先將獲取的單條彈幕數據通過 WebSocket 發送給后端服務器,在服務器重新將消息返還給我們的時候,去將這條數據通過 CanvasBarrage 類的 add 方法加入到存放彈幕實例的 barrages 數組中。

還有在頁面初始化時,我們之前在創建 CanvasBarrage 類實例的時候直接傳入了 data 假數據,現在需要通過 WebSocket 的連接事件,在監聽到連接 WebSocket 服務時,去創建 CanvasBarrage 類的實例,并直接把服務端返回 Redis 數據庫真實的數據作為參數傳入,前端代碼修改如下:

// 文件:index.js
// ********** 下面代碼被刪掉了 **********
// let canvasBarrage = new CanvasBarrage(canvas, video, {
//     data
// });
// ********** 上面代碼被刪掉了 **********

// ********** 以下為新增代碼 **********
let canvasBarrage;

// 創建 WebSocket 連接
let socket = new WebSocket("ws://localhost:3000");

// 監聽連接事件
socket.onopen = function() {
    // 監聽消息
    socket.onmessage = function(e) {
        // 將收到的消息從字符串轉換成對象
        let message = JSON.parse(e.data);

        // 根據不同情況判斷是初始化還是發送彈幕
        if (message.type === "INIT") {
            // 創建 CanvasBarrage 的實例添加彈幕功能,傳入真實的數據
            canvasBarrage = new CanvasBarrage(canvas, video, {
                data: message.data
            });
        } else if (message.type === "ADD") {
            // 如果是添加彈幕直接將 WebSocket 返回的單條彈幕存入 barrages 中
            canvasBarrage.add(message.data);
        }
    };
};
// ********** 以上為新增代碼 **********

$("#add").addEventListener("click", function() {
    let time = video.currentTime; // 發送彈幕的時間
    let value = $("#text").value; // 發送彈幕的文字
    let color = $("#color").value; // 發送彈幕文字的顏色
    let fontSize = $("#range").value; // 發送彈幕的字體大小
    let sendObj = { time, value, color, fontSize }; //發送彈幕的參數集合

    // ********** 以下為新增代碼 **********
    socket.send(JSON.stringify(sendObj));
    // ********** 以上為新增代碼 **********

    // ********** 下面代碼被刪掉了 **********
    // canvasBarrage.add(sendObj); // 發送彈幕的方法
    // ********** 上面代碼被刪掉了 **********
});

現在我們可以打開 index.html 文件并啟動 server.js 服務器,就可以實現真實的視頻彈幕操作了,但是我們還是差了最后一步,當前的服務只能同時服務一個人,但真實的場景是同時看視頻的有很多人,而且發送的彈幕是共享的。

3、實現多端通信、彈幕共享

我們需要處理兩件事情:

第一件事情是實現多端通信共享數據庫信息;

第二件事情是當有人離開的時候清除關閉的 WebSocket 對象。

// 文件:server.js
const WebSocket = require("ws"); // 引入 WebSocket
const redis = require("redis"); // 引入 redis

// 初始化 WebSocket 服務器,端口號為 3000
let wss = new WebSocket.Server({
    port: 3000
});

// 創建 redis 客戶端
let client = redis.createClient(); // key value

// ********** 以下為新增代碼 **********
// 存儲所有 WebSocket 用戶
let clientsArr = [];
// ********** 以上為新增代碼 **********

// 原生的 websocket 就兩個常用的方法 on("message")、on("send")
wss.on("connection", function(ws) {
    // ********** 以下為新增代碼 **********
    // 將所有通過 WebSocket 連接的用戶存入數組中
    clientsArr.push(ws);
    // ********** 以上為新增代碼 **********

    // 監聽連接
    // 連接上需要立即把 redis 數據庫的數據取出返回給前端
    client.lrange("barrages", 0, -1, function(err, applies) {
        // 由于 redis 的數據都是字符串,所以需要把數組中每一項轉成對象
        applies = applies.map(item => JSON.parse(item));

        // 使用 websocket 服務器將 redis 數據庫的數據發送給前端
        // 構建一個對象,加入 type 屬性告訴前端當前返回數據的行為,并將數據轉換成字符串
        ws.send(
            JSON.stringify({
                type: "INIT",
                data: applies
            })
        );
    });

    // 當服務器收到消息時,將數據存入 redis 數據庫
    ws.on("message", function(data) {
        // 向數據庫存儲時存的是字符串,存入并打印數據,用來判斷是否成功存入數據庫
        client.rpush("barrages", data, redis.print);

        // ********** 以下為修改后的代碼 **********
        // 循環數組,將某一個人新發送的彈幕在存儲到 Redis 之后返回給所有用戶
        clientsArr.forEach(w => {
            // 再將當前這條數據返回給前端,同樣添加 type 字段告訴前端當前行為,并將數據轉換成字符串
            w.send(
                JSON.stringify({
                    type: "ADD",
                    data: JSON.parse(data)
                })
            );
        });
        // ********** 以上為修改后的代碼 **********
    });

    // ********** 以下為新增代碼 **********
    // 監聽關閉連接事件
    ws.on("close", function() {
        // 當某一個人關閉連接離開時,將這個人從當前存儲用戶的數組中移除
        clientsArr = clientsArr.filter(client => client != ws);
    });
    // ********** 以上為新增代碼 **********
});

上面就是 Canvas + WebSocket + Redis 視頻彈幕的實現,實現過程可能有些復雜,但整個過程寫的還是比較詳細,可能需要一定的耐心慢慢的讀完,并最好一步一步跟著寫一寫,希望這篇文章可以讓讀到的人解決視頻彈幕類似的需求,真正理解整個過程和開放封閉原則,認識到前端面向對象編程思想的美。


文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://www.hztianpu.com/yun/113984.html

相關文章

  • Canvas + WebSocket + Redis 實現一個視頻彈幕

    摘要:創建彈幕功能的類及基本參數處理布局時需要注意的默認寬為,高為,我們要保證完全覆蓋整個視頻,需要讓與寬高相等。因為我們不確定每一個使用該功能的視頻的寬高都是一樣的,所以畫布的寬高并沒有通過來設置,而是通過在類創建實例初始化屬性的時候動態設置。 showImg(https://segmentfault.com/img/remote/1460000018998386); 閱讀原文 頁面布...

    gekylin 評論0 收藏0
  • Canvas + WebSocket + Redis 實現一個視頻彈幕

    摘要:創建彈幕功能的類及基本參數處理布局時需要注意的默認寬為,高為,我們要保證完全覆蓋整個視頻,需要讓與寬高相等。因為我們不確定每一個使用該功能的視頻的寬高都是一樣的,所以畫布的寬高并沒有通過來設置,而是通過在類創建實例初始化屬性的時候動態設置。 showImg(https://segmentfault.com/img/remote/1460000018998386); 閱讀原文 頁面布...

    wangdai 評論0 收藏0
  • 彈幕,是怎樣練成的?

    showImg(https://segmentfault.com/img/bVbk1Nl?w=1080&h=602); 說起彈幕看過視頻的都不會陌生,那滿屏充滿著飄逸評論的效果,讓人如癡如醉,無法自拔 最近也是因為在學習關于 canvas 的知識,所以今天就想和大家分享一個關于彈幕的故事 那么究竟彈幕是怎樣煉成的呢? 我們且往下看(look) 看什么?看效果 showImg(https://s...

    lwx12525 評論0 收藏0
  • 全棧開發——動手打造屬于自己的直播間(Vue+SpringBoot+Nginx)

    摘要:經過琢磨,其實是要考慮安全性的。具體在以下幾個方面跨域連接協議升級前握手攔截器消息信道攔截器對于跨域問題,我們可以通過方法來設置可連接的域名,防止跨站連接。 前言 大學的學習時光臨近尾聲,感嘆時光匆匆,三年一晃而過。同學們都忙著找工作,我也在這里拋一份簡歷吧,歡迎各位老板和獵手誠邀。我們進入正題。直播行業是當前火熱的行業,誰都想從中分得一杯羹,直播養活了一大批人,一個平臺主播粗略估計就...

    e10101 評論0 收藏0

發表評論

0條評論

WelliJhon

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
狠狠干.com | 青青免费在线视频 | 99视频免费看 | 日韩在线免费av | 欧美片网站免费 | 狠狠操天天操 | 灌篮高手全国大赛电影 | 丰满少妇在线观看 | 大陆熟妇丰满多毛xxxⅹ | 国产精品久久久久久亚洲色 | 伊人久久国产 | 成人黄色免费电影 | 亚洲综合色在线 | 狠狠干2023| 黄视频在线播放 | www.色婷婷 | aaaa一级片| 欧美丝袜丝交足nylons | 国产亚洲精品女人久久久久久 | 风流少妇一区二区三区91 | av影院在线观看 | 特黄aaaaaaaaa毛片免费视频 | 中文字幕一区二区三区5566 | 潘金莲一级淫片免费放动漫 | 水密桃av| 青青草成人av | 一级黄色大片 | 欧美一区二区三区成人精品 | 自拍偷拍专区 | 都市激情一区 | 四虎影库在线播放 | 午夜在线观看影院 | 日本在线视频免费观看 | 琪琪五月天 | 在线免费看污视频 | 黄色av网站免费 | 91成人免费看 | 日韩精品视频在线免费观看 | 国产h视频在线观看 | 欧美激情性做爰免费视频 | 免费a级大片 | 国产精品探花视频 | 亚洲国产精品免费 | 动漫3d精品一区二区三区乱码 | 国产成人中文字幕 | 久久精品一区 | 在线观看成人网 | 四虎成人精品永久免费av九九 | 人妻少妇精品视频一区二区三区 | 樱桃视频app看片 | 图片区偷拍区小说区 | 夜夜骑天天操 | 男女网站免费 | 完美搭档在线观看 | 午夜在线观看影院 | 日本黄色网址大全 | 成人片免费视频 | 色愁久久 | 欧美日韩中文字幕一区二区 | 打白嫩光屁屁女网站 | 国产福利在线观看 | 视频在线观看免费大片 | 柠檬福利第一导航在线 | 97看片吧| 亚洲欧美精品一区二区三区 | 日韩一区二区三区四区五区六区 | 欧美日韩在线观看一区二区 | 日韩国产免费 | 欧美性生活一区二区 | 狂野欧美| 免费在线观看黄色av | www.夜夜骑 | 免费麻豆视频 | 欧美精品久久99 | 天堂影视在线观看 | 爱吃波客今天最新视频 | 国产精品99视频 | 怡红院最新网址 | 色七七视频| 欧美九九 | 澳门黄色一级片 | 精品国内自产拍在线观看视频 | 好看的h文| 午夜视频在线免费 | 草比网站| 激情网五月| 国产亚洲一区二区三区在线观看 | 亚洲三级精品 | 日韩精品一区二区三区免费视频 | 一级免费观看 | 69久久久久 | h片在线免费看 | 日韩中文字幕不卡 | av中文网站| 精品视频一区二区三区四区 | 午夜视频在线播放 | 天天操天天操天天操 | 青青草狠狠干 | 日韩精品无码一区二区三区久久久 | 免费爱爱视频网站 | 成人免费毛片果冻 | 天天干夜夜欢 | 日韩精品无码一区二区三区久久久 | 二十四小时在线更新观看 | 国内精品久久久久久 | 国产在线高清 | 老师让我她我爽了好久视频 | 色吧av色av| 不卡在线播放 | 色av资源 | 国产日韩在线视频 | 国产做爰免费视频观看 | 美女爆乳18禁www久久久久久 | 国产视频一区二区在线观看 | 蜜乳av红桃嫩久久 | 毛片官网| 一区二区三区日韩欧美 | 97播播 | 美女隐私无遮挡 | 欧美春色 | 久久在线看 | 永久免费视频网站直接看 | 国产高清av在线 | 一区二区三区黄 | 国产一区免费视频 | 黄av资源 | 色久视频 | 国内精品久久久久久 | 韩国一区二区在线观看 | 国产人成视频在线观看 | 啪啪网站免费看 | 好吊操视频这里只有精品 | 精品无码久久久久久久久 | 欧美人妻日韩精品 | 五月天婷婷综合网 | 蕾丝视频污 | 一区二区免费 | 欧美大片黄色 | 日韩欧美国产高清 | 日韩城人网站 | 亚洲一区二区精品在线 | 快播黄色电影 | 日韩黄色在线 | 成人在线播放视频 | 日韩一区二区三区四区在线 | 中文字幕一区二区人妻电影 | 91成人在线观看喷潮动漫 | 天天插天天狠 | 国产精品久久久久久亚洲色 | 亚洲欧美精品一区二区三区 | 欧美专区第一页 | 成人在线一区二区三区 | 少妇高潮惨叫久久久久久 | 一区二区在线免费观看视频 | 青青草国产成人99久久 | 亚洲一区二区欧美 | 婷婷欧美 | 超碰在线人人 | 亚洲精品第一页 | 秋霞午夜| 国产麻豆精品久久一二三 | 人妻少妇精品视频一区二区三区 | 99资源在线 | 91热热 | 麻豆精品一区二区 | 精品人妻无码中文字幕18禁 | 色婷婷av一区二区三区之红樱桃 | 国产免费不卡 | 成人xx视频 | 午夜精品一区二区三区在线视频 | 黄色在线 | 国产在线看片 | 久久久久久少妇 | 日韩欧美国产高清 | 欧美大片高清免费观看 | 免费一级大片 | 成年人免费视频观看 | 日韩一级黄色大片 | 草莓视频污视频 | 精品人妻无码中文字幕18禁 | 国产青青草视频 | 欧美福利视频导航 | 99在线视频播放 | 国产黄色录像 | 欧美性猛交xxxx乱大交俱乐部 | 中文在线免费视频 | 神马久久精品 | 国产成人在线免费观看视频 | 在线播放国产一区 | 91精品国产成人观看 | 丰满少妇在线观看 | 中文字幕丰满乱子伦无码专区 | 欧美大片高清免费观看 | 欧美日韩h| 天天干视频在线观看 | 综合久久久久 | 欧美日韩国产高清 | 中文在线www | 日本一区二区视频在线 | 熟妇熟女乱妇乱女网站 | 日本高清三区 | 国产精品欧美在线 | 国内精品久久久久久 | 久久三级视频 | 欧美国产日韩一区二区 | 最近中文字幕av | 鲁一鲁在线 | 国产精品久久久久av | 男女瑟瑟网站 | 夜夜视频| 国产精品自拍偷拍 | 97在线播放| 午夜免费播放观看在线视频 | 911精品国产一区二区在线 | 国产精品久久久久久亚洲色 | 亚洲男同视频 | 亚洲免费三级 | 大陆熟妇丰满多毛xxxⅹ | 免费一级毛片麻豆精品 | 男女床上拍拍拍 | 张柏芝亚洲一区二区三区 | 欧美亚洲中文精品字幕 | 中文字幕亚洲乱码熟女1区2区 | 成人做爰视频www | 天天插天天狠 | 岛国av大片 | 午夜精品亚洲 | 精品不卡视频 | 少妇被躁爽到高潮无码人狍大战 | 亚洲乱码一区二区 | 色哟哟精品一区 | 国产福利在线观看 | 欧美日韩性视频 | 午夜免费观看视频 | 亚洲欧美精品一区二区三区 | 欧美丰满熟妇bbbbbb | 国产在线97 | 中国精品毛片 | 国产午夜在线视频 | 亚洲视频国产精品 | 伊人久久狼人 | 久久国产免费 | 成人啪啪漫画羞羞漫画 | 五月开心网 | 先锋成人资源 | 婷婷亚洲天堂 | 日批国产| 国产91在线视频 | 九一网站在线观看 | 欧美亚洲另类小说 | 人妻少妇精品视频一区二区三区 | 伊人网视频 | 怡红院最新网址 | 国产精品第三页 | 亚洲草逼视频 | 亚洲精品v| 可以免费看的av网站 | 欧美综合一区二区三区 | 成年人性生活视频 | 亚洲午夜一区二区 | 欧亚一区二区 | www.黄色在线观看 | 野花视频免费在线观看 | 91色国产 | 4hu最新网址 | 日本黄色精品 | 99激情| 极度诱惑香港电影完整 | 三级av在线 | 国产精品视频在线观看 | 午夜精品电影 | 碧蓝之海动漫在线观看免费高清 | 亚洲高潮av| 伊人久久国产 | 久久久96人妻无码精品 | 91亚洲国产成人精品一区 | 强行糟蹋人妻hd中文 | 青青草国产精品 | 成年人性生活视频 | 爆操欧美美女 | 激情网五月 | 中日韩中文字幕 | 日韩在线免费av | 国产片在线 | 337p日本欧洲亚洲大胆张筱雨 | 草草免费视频 | 国产精品白丝喷水在线观看 | 性高潮视频在线观看 | 波多在线观看 | 张柏芝亚洲一区二区三区 | 91精品国产91久久久久久黑人 | 久热只有精品 | av中文天堂 | 麻豆国产精品一区 | 在线无限看免费粉色视频 | xxx在线视频 | 91在线观看视频 | 黑丝啪啪| 污片视频在线观看 | 日本网站免费观看 | 五月天久久久久久 | 能免费看av的网站 | 樱桃视频app看片 | 欧美日韩性视频 | 日韩经典一区二区 | 高清日韩 | 久久ww| 天天毛片 | 日本黄色大片免费 | 精品久久二区 | 日本乳汁视频 | 国产又爽又黄视频 | 欧美成人三区 | 动漫美女无遮挡免费 | 欧美在线亚洲 | 精品无码国产一区二区三区51安 | 欧美性猛交xxxx乱大交退制版 | 青青草青青操 | www.在线播放 | 日本免费中文字幕 | 国产第页 | 国产成人在线观看免费网站 | 日本天堂网在线观看 | 色av影院| 亚洲av无码国产综合专区 | 久久久96人妻无码精品 | 欧美春色 | 在线不卡中文字幕 | 亚洲色成人www永久网站 | 欧美在线中文字幕 | 免费av影视 | av中文网站 | 青青草狠狠干 | 成年人一级片 | www.伊人网 | 丰满少妇在线观看 | 91精品网 | 免费一级片视频 | 国产视频资源 | 中文字幕一区二区三区5566 | 91嫩草视频在线观看 | 欧美综合一区 | 久久久久噜噜噜亚洲熟女综合 | 中文字幕自拍偷拍 | 日本黄色大片免费 | av在线播放中文字幕 | 性视频播放免费视频 | 国产精品精品软件视频 | 黄色网入口| 少妇扒开粉嫩小泬视频 | 婷婷五月综合久久中文字幕 | 日本高清视频在线 | 日本中文字幕免费 | 91禁漫h动漫羞羞网站 | 久久久久久久精 | 亚洲视频在线观看一区二区 | 日韩视频一区在线观看 | 超碰97人人草 | 美女免费视频观看 | 五月开心网 | 国产福利在线观看 | 日韩毛毛片 | av电影免费在线播放 | 快播黄色电影 | 午夜精品久久久久久久久久 | 欧美放荡性医生videos | 在线观看黄色网页 | 91精品国产91久久久久久黑人 | 极度诱惑香港电影完整 | 亚洲xxx视频| 午夜精品亚洲 | 欧美成人激情视频 | 自拍偷拍国产精品 | 18免费网站 | 看特级毛片 | 国产一区二区在线看 | 一区二区三区黄 | 国产成人a人亚洲精品无码 最近中文字幕av | 国产无遮挡裸体免费视频 | 成年人一级片 | 91麻豆精品国产91久久久久久 | 福利视频免费 | 丁香婷婷久久久综合精品国产 | 欧美二区在线观看 | 尤物av在线 | 日本精品视频在线播放 | 欧美激情一区二区三区 | 久久伊人精品 | 亚洲视频二 | 小宝贝真紧h军人h | 污污网站在线免费观看 | 婷婷香蕉 | 美国毛片网站 | 天天毛片 | 久久久久久av无码免费网站 | 黄色美女一级片 | 欧美一级成人 | 男女网站免费 | 色婷婷一区 | 在线观看黄色网页 | 欧美日韩影院 | 精品无码国产一区二区三区51安 | 污污视频免费观看 | 暖暖日本在线视频 | 神马影院午夜伦理 | 欧美二区在线观看 | 自拍偷拍第五页 | 欧美一区免费观看 | 国产精品第三页 | 国产成人a人亚洲精品无码 最近中文字幕av | 亚洲成年人av | 午夜精品电影 | 国产午夜在线视频 | 国产精品天天狠天天看 | 精品无码久久久久 | 91久久久久国产一区二区 | 神马影院午夜伦理 | 阿娇全套94张未删图久久 | 亚洲国产精品无码久久久久高潮 | 一区二区三区欧美视频 | 久草五月天 | 国产精品免费久久 | 国产一区二区视频在线 | 国产色播 | 国产卡一卡二 | 91精品国产综合久久久蜜臀粉嫩 | 91日本在线 | 欧美成在线| 在线观看毛片网站 | 中国男女全黄大片 | 日韩在线视频看看 | 婷婷香蕉| 日韩国产免费 | 91快射| 九九热视频在线播放 | 美女扒开尿口给男人桶 | 国语对白永久免费 | www夜片内射视频日韩精品成人 | 久久免费看少妇高潮 | 女~淫辱の触手3d动漫 | 免费一级毛片麻豆精品 | 日本中文字幕免费 | 久草久热| 日韩精品视频在线免费观看 | 久久亚洲电影 | 91精品视频在线播放 | 欧美骚少妇| 一区二区三区毛片 | 午夜视频在线免费 | 日韩精品一区二区三区免费视频 | 超碰人人超碰 | 台湾黄色网址 | 日本在线观看 | 五月精品| 麻豆av一区二区 | 亚洲图片欧美 | 青青91 | 日韩2区| 天堂在线1| 亚洲成人精品久久 | 日韩精品无码一区二区三区久久久 | 亚洲精品777 | 欧美尻逼 | 久久影视精品 | 亚洲黄色小说网 | 国产性色av | 欧美性视屏 | 男人插入女人阴道视频 | 秋霞午夜| www.五月激情 | 怡红院av | 国产亚洲色婷婷久久99精品91 | 爱逼综合 | 毛茸茸的中国女bbw 国产午夜精品久久久 | www男人天堂| 1024国产在线 | 亚洲av无码国产综合专区 | 午夜色图| 牛牛电影国产一区二区 | 色妞综合 | 国产又粗又大又爽视频 | 婷婷超碰| 黄免费看 | 完美搭档在线观看 | 久操视频免费观看 | 色婷婷777777仙踪林 | 性一交一乱一区二区洋洋av | 四虎精品一区二区三区 | 亚洲美女视频 | 日日夜夜爽爽 | 国产乱码精品一区二区三区中文 | 欧美成人精品激情在线视频 | 中文字幕一区二区三区人妻不卡 | 农村妇女毛片 | 亚洲第一免费 | 成人在线视频观看 | 少妇高潮惨叫久久久久久 | 性一交一乱一区二区洋洋av | 精品一二三区 | 国产在线看片 | 成人激情片 | 在线播放精品 | 日韩美女在线视频 | 毛茸茸的中国女bbw 国产午夜精品久久久 | 日本福利在线观看 | 亚洲黄色小说网 | 欧美精品久久久久久 | 先锋成人资源 | 国产呦小j女精品视频 | 欧美黄色片免费看 | 91久久久久久 | 樱桃视频app看片 | 亚洲精品小视频 | 色鬼艳魔大战1春荡女淫 | 国产精品入口麻豆 | 欧美影院一区 | 欧洲激情网 | 二十四小时在线更新观看 | 2019毛片 | 国产乱人| 波多野吉衣一二三区乱码 | 久久国产小视频 | 青青青国产在线 | 成人免费视频国产免费 | 国产青青草视频 | 精品国产不卡 | 在线观看毛片网站 | 青青青草视频在线观看 | 国产一区二区在线免费 | 免费在线国产视频 | 免费国产一区 | 天天天天干 | 日本亚洲色大成网站www久久 | 特黄aaaaaaaaa毛片免费视频 | 波多野结衣av无码 | 欧美一级生活片 | 深夜成人福利视频 | 青青草激情视频 | 色中色在线视频 | 色鬼艳魔大战1春荡女淫 | 殴美一级黄色片 | 精品无码免费视频 | av中文天堂 | 黄色网址免费 | 成人hd | 国产欧美在线看 | 欧美国产日韩一区二区 | 国产又大又黄的视频 | 涩人阁| 色中文字幕 | 懂色av一区二区三区免费观看 | 日日操夜夜爱 | 日本在线视频中文字幕 | 亚洲不卡在线视频 | 中国极品少妇xxxx做受 | 黄色三级生活片 | 久久99亚洲精品 | 人人草人人爽 | 国内精品久久久久久 | 亚洲区一区二区三区 | 亚洲成人精品久久 | 国产在线小视频 | 在线视频 日韩 | 国产精品偷拍 | 九九九热视频 | 中文字幕自拍偷拍 | 亚洲欧美精品一区二区三区 | 亚洲成年人 | 日一日射一射 | 成年人精品 | www.夜夜| 国产成人av一区 | 国产乱码精品一区二区三区中文 | 9999热| 国产黄色片在线播放 | 日韩av一二三 | 男人都懂的网站 | 中文字幕一区二区人妻电影 | 国产精品久久久久av | 日韩脚交footjobhd| 国偷自产视频一区二区久 | 91抖音在线观看 | 原神女裸体看个够无遮挡 | 1024手机在线看片 | h片在线免费看 | 中文字幕一区二区三区人妻不卡 | 欧美9999 | 国产又粗又猛视频免费 | 欧美色图在线播放 | 日韩av一二三 | 国产精品久久久久久吹潮 | 爱搞国产| 小嫩女直喷白浆 | 国产一区二区在线免费 | 国产又粗又猛视频免费 | 丁香网站 | 久草久热 | 五月天狠狠干 | 柠檬福利第一导航在线 | 亚洲特级毛片 | 成人看片泡妞 | 精品视频一区二区三区四区 | 1769在线视频 | 欧美高清hd18日本 | 嘛豆视频 | 男女网站免费 | 久久久久性 | 免费一二三区 | av中文网 | 中国挤奶哺乳午夜片 | 狠狠操天天操 | 九九视频在线播放 | 丰满少妇在线观看 | 特黄aaaaaaaaa真人毛片 | 亚洲青青草原 | 午夜久久福利 | 1024国产在线 | 日日夜夜精 | 免费麻豆视频 | 北京富婆泄欲对白 | 看全色黄大色黄女片18 | 少妇视频在线观看 | 日韩人妻无码一区二区三区99 | 一区二区在线免费观看视频 | 在线精品观看 | 张柏芝亚洲一区二区三区 | 欧美在线中文字幕 | 草莓视频免费在线观看 | 午夜大片 | 久久久久久av无码免费网站 | 天天插天天狠 | 高h喷水荡肉少妇爽多p视频 | 牛牛电影国产一区二区 | 午夜看毛片 | 蕾丝视频污 | 亚洲三级图片 | 一级片黄色 | 日韩在线视频看看 | 污污内射久久一区二区欧美日韩 | 看特级毛片 | 插插插91| 久青草视频在线观看 | 久久与婷婷 | 国产又粗又猛又爽又黄的 | 国产亚洲精品女人久久久久久 | 成人自拍av | 欧美日韩在线观看一区二区 | 成年人免费网站在线观看 | 日本亚洲色大成网站www久久 | 欧美精品久久99 | 国产精选在线观看 | 国产一区二区av | 无码人妻久久一区二区三区 | 91亚洲国产成人精品一区 | 日韩videos| 福利视频免费 | 沟厕沟厕近拍高清视频 | 日韩爱爱网 | 欧美丰满熟妇bbbbbb | 一级黄色短视频 | 最新国产露脸在线观看 | 国产视频资源 | 中日韩中文字幕 | 草民午夜理伦三级 | 欧美成人免费在线视频 | 午夜资源站 | 图片区偷拍区小说区 | 伊人久久大香线蕉av一区 | 80日本xxxxxxxxx96| 亚洲深夜视频 | 久草色在线 | 日韩在线免费av | 求av网址 | 在线97| 成人黄色免费电影 | 久久极品视频 | 日本在线观看 | 国产二区电影 | 日韩av高清| 不良视频在线观看 | 都市激情 亚洲 | 91精品人妻一区二区三区蜜桃欧美 | 91亚洲国产成人精品一区 | 日韩高清一区 | 精品视频一区二区三区四区 | 牛牛电影国产一区二区 | 99爱在线| 色欲av无码一区二区三区 | 涩涩五月天 | av无限看 | 蜜桃av噜噜一区二区三区麻豆 | 久热只有精品 | 女人做爰全过程免费观看美女 | 午夜免费小视频 | 国产乱子伦精品视频 | 久久久青草 | 中文字幕一区二区三区人妻不卡 | 国产精品av一区 | 一区二区免费 | 97播播| 两女双腿交缠激烈磨豆腐 | 亚洲欧美日韩综合在线 | 日韩精品视频在线免费观看 | 国产高清免费在线播放 | 看特级毛片 | 牛牛电影国产一区二区 | gogo人体做爰大胆视频 | 极度诱惑香港电影完整 | 青青草视频免费 | 一区二区三区日韩欧美 | 三级av片| 青青青青操 | 台湾黄色网址 | 奇米色777 | 四虎影视免费永久大全 | 免费看欧美大片 | 久久久久亚洲精品 | 在线观看成人网 | 国产美女自慰在线观看 | 动漫3d精品一区二区三区乱码 | 九九热九九 | 中文字幕一区二区三区精华液 | 美女爆乳18禁www久久久久久 | 爱搞国产| 打屁股调教视频 | 欧美国产日韩一区二区 | 在线97| 天天综合亚洲 | 在线免费看污视频 | 午夜美女福利 | 久久久久草 | 欧美综合一区二区三区 | 久久超 | 国产乱码精品一区二区三区中文 | 就去吻亚洲 | 亚洲天堂一区二区三区 | a一级黄色| 亚洲精品自拍 | 欧美69久成人做爰视频 | 在线黄色av网站 | 五十路母 | 91丨九色丨黑人外教 | 日本久色 | 久青草视频在线观看 | 亚洲国产成人精品女人久久久 | 91抖音在线观看 | 91久久国产综合久久91精品网站 | 中文字幕不卡在线观看 | 成人啪啪漫画羞羞漫画 | 免费av影视| 91好色先生| 欧美四区 | 日本妈妈9| 成年人免费视频观看 | 综合色视频 | 欧美成人激情视频 | 国产人妻精品一区二区三区不卡 | 丁香花电影免费播放电影 | 91桃色在线观看 | 伊人国产在线 | av在线电影网 | 在线免费看污视频 | 一级性爱视频 | 国产精品v欧美精品v日韩 | 欧美精品成人在线 | 在线看片你懂得 | 综合色视频 | 大地二资源在线观看高清国语版 | 日韩精品久久久久久久 | 在线播放精品 | 久久久久久久久久网站 | 在线免费看污视频 | 中文字幕 自拍偷拍 | 婷婷亚洲天堂 | 艳母动漫在线播放 | 97看片吧| 福利在线观看 | 久久久久久一区二区三区 | 怡红院av| 免费一级毛片麻豆精品 | 97精品在线观看 | 欧亚一区二区 | 伊人色网 | 91成人免费看 | 西西44rtwww国产精品 | 尤物视频免费观看 | 久久99久久99精品免观看软件 | 免费三片在线观看网站v888 | 国产色播 | 日韩av一区二区三区在线观看 | 性色av蜜臀av浪潮av老女人 | 久久与婷婷| 亚洲综合色视频 | 日本h在线 | 色综合网址 | www男人天堂| 毛片官网 | 黄污视频在线观看 | www日本高清视频 | www.亚洲 | 精品无码久久久久久久久 | 福利视频免费 | 强睡邻居人妻中文字幕 | 大陆熟妇丰满多毛xxxⅹ | 国产精品探花一区二区在线观看 | 伊人国产在线 | 欧美日韩三级在线 | aaaa一级片| 91桃色在线观看 | 色情毛片 | 黄色片链接 | 亚洲黄色在线观看 | 久久男人天堂 | xxx在线视频 | 日本美女一区二区 | 51国产偷自视频区视频 | 男人都懂的网站 | 亚洲色图自拍 | 伊人99热| 久久久国产一区二区三区 | 中文字幕视频在线观看 | 欧美第二页 | 日屁网站 | 极度诱惑香港电影完整 | 成人精品影院 | 亚洲精品二 | 黄色国产视频 | 精品日韩在线观看 | 美国免费高清电影在线观看 | 成人午夜淫片免费观看 | 国产7777| 丁香六月综合激情 | 国产在线精品视频 | 国产在线精品视频 | www.欧美在线 | 亚洲精品国产精品乱码不99按摩 | 麻豆av一区二区 | 91亚洲国产成人精品一区 | 欧美69久成人做爰视频 | 美国毛片网站 | 日韩中文字幕不卡 | 国产精品入口麻豆 | 精品少妇theporn | 国产又大又黄的视频 | 爱逼综合 | 羞羞网站在线观看 | 国产青青草视频 | 美女三级视频 | 在线观看国产黄色 | 国产激情久久久久久熟女老人av | 国产午夜精品久久久 | 久久久久草 | 亚洲成成品网站 | 日韩在线视频看看 | 强行糟蹋人妻hd中文 | 亚洲综合久久久 | 永久免费视频网站直接看 | 成人黄色录像 | 国产精品久久国产精麻豆96堂 | 中日一级片 | 亚洲av毛片 | 久久亚洲精品小早川怜子 | 91亚洲精品在线观看 | 一级全黄裸体片 | 在线精品观看 | 日韩性视频 | 一起操在线观看 | 黄漫app | 午夜美女福利 | 久久国产免费视频 | 在线播放精品 | 奇米影视在线播放 | 久久成年人视频 | 99er这里只有精品 | 操到喷水 | 在线无限看免费粉色视频 | 国产麻豆精品久久一二三 | 明日叶三叶| 日韩三级 | 中文字幕一区二区三区5566 | 女女在线| 蜜臀尤物一区二区三区直播 | 韩国一区二区三区在线观看 | 丰满熟妇被猛烈进入高清片 | 在线h网站 | 女人洗澡一级特黄毛片 | 成人丁香婷婷 | 99热这里只有精品在线观看 | 亚洲黄色av | 欧美精品亚洲精品 | 一区二区免费在线观看 | 善良的女朋友在线观看 | 日韩欧美一级片 | 午夜三区| 91桃色在线观看 | 丝袜 亚洲 另类 欧美 重口 | 色婷婷在线影院 | 成人综合色站 | 四虎影库在线播放 | 欧美激情黑白配 | 91久久国产综合久久91精品网站 | 98在线视频 | 五月婷婷中文 | 天天射天天射 | 国产黄色a | 亚洲特级毛片 | 国产精品白丝喷水在线观看 | 免费在线国产视频 | 国产精品久久影视 | 五月精品| 成人丁香婷婷 | 337p日本欧洲亚洲大胆张筱雨 | 国产三级在线观看视频 | 久久这里有 | 欧美夜夜 | 欧美私人影院 | 免费看欧美大片 | 禁断介护老人中文字幕 | 日本成人一级片 | 五月婷婷开心中文字幕 | 福利免费视频 | 最新国产露脸在线观看 | 国产亚洲色婷婷久久99精品91 | 91丝袜在线 | 亚洲成成品网站 | 农村老妇性真猛 | 樱桃av | 亚洲欧美在线看 | 日韩午夜一区 | 亚洲区一区二区三区 | 美女吞精视频 | 美国毛片网站 | 亚洲h视频在线观看 | 欧美一级生活片 | 成人黄网免费观看视频 | 亚洲天堂av在线播放 | 亚洲女优在线观看 | 99久久久无码国产精品免费蜜柚 | 少妇高潮惨叫久久久久久 | 天天摸夜夜添狠狠添婷婷 | 欧美私人影院 | 性爱一级视频 | 无码人妻久久一区二区三区 | 911精品国产一区二区在线 | 强睡邻居人妻中文字幕 | 亚洲色图另类 | 国产呦小j女精品视频 | av老女人 | 欧美成人精品激情在线视频 | 你懂得在线观看 | 黄av资源 | 淫欲的美女理论电影完整版 | 男人天堂中文字幕 | 色哟哟精品一区 | 亚洲深夜视频 | 岛国av大片 | 能免费看av的网站 | 全是肉的高h文〈男男〉 | 原神女裸体看个够无遮挡 | 黄视频在线播放 | 91久久久久国产一区二区 | 免费看日韩毛片 | 樱桃香蕉视频 | 91视频污| 免费在线一区二区三区 | 在线观看www.| 五月天亚洲色图 | 深夜福利免费观看 | 亚洲天堂午夜 | 亚洲乱码一区二区 | 欧美 日韩 精品 | 免费一二三区 | 欧美激情黑白配 | 欧美在线中文字幕 | 色婷婷av一区二区三区之红樱桃 | 天天干天天干天天干 | 国产精品久久影视 | 女人免费视频 | 丁香婷婷久久久综合精品国产 | 亚洲精品中文字幕 | 国产成人精品无码片区在线 | 亚洲三级图片 | 国产九九精品视频 | 黄色一级图片 | 日本少妇xxxxx | 日本一区精品 | heyzo在线播放 | 人人草人人爽 | 9999热| 九九综合网 | 国产伦精品一区 | 和黑帮大佬的365 | 亚洲国产成人精品女人久久久 | 成人羞羞国产免费 | a一级黄色| 张柏芝亚洲一区二区三区 | 亚洲区一区二区三区 | 国产首页 | 黄色网入口 | 午夜在线观看影院 | 国产精品2 | 亚洲视频二 | 日韩在线观看视频网站 | 国产卡一卡二 | 国产首页 | 日本在线三级 | 成人片免费视频 | 日韩美女在线视频 | 久久亚洲一区二区 | 91亚洲欧美 | 久久综合亚洲 | 老年人毛片 | www.色婷婷 | 一级性爱视频 | 日韩在线观看视频网站 | 91精品国产aⅴ一区二区 | 午夜国产片 | 一区二区三区日本 | 国产一区二区中文字幕 | 亚洲黄视频 | 欧美亚洲国产一区二区三区 | 少妇无码一区二区三区 | 国产乱码一区 | 国产精品第三页 | 日韩一区二区三区四区五区六区 | 久久这里有| 亚洲青草视频 | 亚洲一区色 | 丁香婷婷久久久综合精品国产 | 国产精品入口麻豆 | 日韩av一区在线 | 欧洲成人免费视频 | 欧美成人高清视频 | 日韩国产欧美一区二区 | 久久伊人精品 | 精品影院 | 亚洲天堂第一页 | 国产激情久久久久久熟女老人av | 久久一| 2019中文字幕在线观看 | 免费av网站观看 | 成人精品在线视频 | 麻豆国产精品一区 | 欧美精品中文 | 福利在线观看 | 在线免费看污视频 | 久久久久久久精 | 欧美综合一区二区三区 | 青青导航| 一本不卡| 狠狠干狠狠插 | 亚洲专区在线播放 | 中文字字幕在线中文乱码电影 | 超碰在线亚洲| 亚洲精品小视频 | 狠狠干狠狠插 | 超碰在线影院 | 免费在线一区二区三区 | 91久久精品一区二区 | 成人精品影院 | 爱吃波客今天最新视频 | 精品午夜视频 | 欧美有码在线 | 久久大香 | 久久大陆 | 日本一级一片免费视频 | 久久精品国产亚洲AV无码男同 | 国语对白永久免费 | 巨粗高h双龙筋肉体育生 | www.国产91| 97人人爱 | 神马久久久久久久久 | 都市激情一区 | 午夜久久久久久久久久 | 潘金莲一级淫片免费放动漫 | 91久久精品日日躁夜夜躁欧美 | 五月婷婷六月色 | 亚洲激情网 | 国内91视频 | 午夜精品一区二区三区在线视频 | 日本国产一区二区三区 | 午夜黄视频 | 神马久久久久久久久 | 午夜欧美激情 | 香港a毛片 | 日韩av第一页 | 日本h在线 | 国模在线观看 | 国产精品久久国产精麻豆96堂 | 夜夜草导航 | av中文网站| 亚洲特级毛片 | 国产乱码精品一区二区三区中文 | 亚洲手机在线观看 | 欧美九九 | 成人影片在线播放 | 艳母动漫在线播放 | 4hu最新网址 | 国产青青草视频 | 欧美视频久久久 | 欧美黄在线 | 亚洲xxx视频 | 后宫秀女调教(高h,np) | 性爱一级视频 | 91亚洲国产成人精品一区 | 国产超级av| 91抖音在线观看 | 亚洲综合小说 | 午夜国产精品视频 | 在线观看xxxx | 亚洲国产精品无码久久久久高潮 | 91色站| 国产白丝在线观看 | 美女一区二区三区四区 | 精品无码国产一区二区三区51安 | 国产精品天天干 | 尤物av在线 | 爆操欧美美女 | 国语毛片| 久久精品国产亚洲AV无码男同 | 亚洲综合色在线 | 日本久久99| av影片在线播放 | 国产精品久久国产精麻豆96堂 | 四虎成人在线观看 | 国产片91| 涩涩网站在线观看 | 国产中文字幕一区 | 韩国无码一区二区三区精品 | 在线看片你懂得 | 爱情岛亚洲论坛入口福利 | 色噜噜狠狠狠综合曰曰曰 | 色天堂视频 | 国产精品sm| 亚洲美女一区二区三区 | 五月婷婷激情四射 | 69精品无码成人久久久久久 | 亚洲天堂av网站 | 狠狠操在线观看 | 国语毛片| 91亚洲国产成人精品一区 | 精品视频一区二区三区四区 | 捆绑无遮挡打光屁股 | 三级av电影 | www.色婷婷| 高h言情 | 国产激情久久久久久熟女老人av | 女~淫辱の触手3d动漫 | 成人久久视频 | 国产片一区二区三区 | 美国免费高清电影在线观看 | 99re国产精品 | 69精品无码成人久久久久久 | 久久看看 | 亚洲欧美日本一区 | 成人久久视频 | 国产7777| 不卡在线播放 | 亚洲一区二区观看 | 天天摸夜夜添狠狠添婷婷 | 国产xxxx孕妇 | 91麻豆精品一二三区在线 | 欧美骚少妇| 手机在线观看毛片 | 大陆熟妇丰满多毛xxxⅹ | 秋霞一区| 日韩精品福利 | 色欲av无码一区二区三区 | 橹图极品美女无圣光 | 国产呦系列 | 美女一区 | 国产精品91久久 | 日本五十肥熟交尾 | 天天射天天射 | 完美搭档在线观看 | 51国产视频| 欧美日韩中文字幕一区二区 | 91大神久久 | 亚洲一级影院 | 男女视频免费 | 日韩精品免费一区二区夜夜嗨 | 韩国三级与黑人 | 91好色先生 | www.欧美在线 | 91精品国产aⅴ一区二区 | 黄页网站在线播放 | 日日夜夜精| 国产精品入口麻豆 | 亚洲熟妇无码久久精品 | 污污网站在线免费观看 | 日日夜操 | 久久大香| 欧美成人免费在线视频 | 91在线播放视频 | 国产精品白丝喷水在线观看 | 1024国产精品 | 动漫美女无遮挡免费 | 深夜视频18 | 超碰免费公开 | 80日本xxxxxxxxx96 国产超级av | 精品久久网| 精品久久免费 | 老鸭资源 | 色综合网址| 亚洲免费福利视频 | 久久久国产一区二区三区 | 五月天狠狠操 | 少妇无码一区二区三区 | av免费一区 | 都市激情一区 | 日本极品丰满ⅹxxxhd | av中文网| 久久久久久亚洲av无码专区 | 久色网站 | 97播播 | 日韩看片| 黑人爱爱视频 | 色婷婷伊人| www.伊人网| 女人做爰全过程免费观看美女 | 午夜人体| 亚洲理论片 | 欧美国产日韩一区二区 | 一区二区免费在线观看 | 熟睡侵犯の奶水授乳在线 | 日韩中文欧美 | 奇米久久 | 亚洲爽爽 | www.日本高清| 日本久久99| 午夜精品久久久久久久久久 | 亚洲色成人www永久网站 | 亚洲一区在线视频观看 | 四虎影库在线播放 | 第一福利丝瓜av导航 | 午夜a级片 | 国产欧美在线看 | 一级全黄裸体片 | 日本特黄一级 | 久久成人免费视频 | 亚洲一区二区三区免费视频 | 橹图极品美女无圣光 | 国产在线97 | 少妇av一区 | 日韩精品无码一区二区三区久久久 | 欧美专区第一页 | 国产一区二区欧美 | av中文天堂| 久热只有精品 | 日韩一区二区三区四区五区六区 | 欧美一区二区三区不卡 | 在线观看免费黄色 | 91成人在线观看喷潮动漫 | 成年人毛片 | 黄色美女一级片 | 午夜院线| 中文字幕亚洲区 | 91麻豆精品一二三区在线 | 91狠狠| 超碰美女| 成年人视频免费在线观看 | 中文av在线播放 | 国产精品白虎 | 欧美性生活一区二区 | 中国挤奶哺乳午夜片 | 欧美国产日韩一区二区 | 国产网站免费 | 中文字幕一区二区三区人妻不卡 | 在线观看www. | 在线看福利影 | 99视频免费看 | 欧美va视频| 国产精品久久一区二区三区 | 爆操欧美美女 | 亚洲精品一二区 | 美女视频网址 | 亚洲欧美另类图片 | 欧美色图狠狠干 | 午夜精品电影 | 九一网站在线观看 | 特黄aaaaaaaaa毛片免费视频 | 婷婷五月综合久久中文字幕 | 不卡久久| 日韩在线观看一区 | 中文字幕第18页 | 成人91视频 | 涩人阁| 禁断介护老人中文字幕 | 日日夜夜影院 | 亚洲综合区 | www狠狠干 | 日韩五月天 | 欧美mv日韩mv国产网站app | 日本美女一区二区 | www婷婷 | 性综艺节目av在线播放 | 亚洲熟妇色自偷自拍另类 | 无码人妻精品一区二区三区蜜桃91 | 成人午夜淫片免费观看 | 沟厕沟厕近拍高清视频 | 成年人视频网 | 成人综合色站 | 亚洲人天堂 | 国产三级在线观看视频 | 91人人爽| 打白嫩光屁屁女网站 | 在线高清观看免费观看 | 婷婷中文 | 超碰夫妻 | 爱逼综合 | 我我色综合| 亚洲爽爽 | 国产亚洲精品成人a | 人人草在线 | 国产首页 | 玩弄人妻少妇500系列 | 91丨九色丨黑人外教 | 日韩精品无码一区二区三区久久久 | 中文字幕亚洲乱码熟女1区2区 | 男人都懂的网站 | 日韩影音| 日韩视频一区在线观看 | 亚洲av毛片 | 欧美日韩在线观看一区二区 | 国产尻逼视频 | 欧美成人高清视频 | 波多野结衣av无码 | 黄色精品在线观看 | 亚洲女成人图区 | 欧美亚洲中文精品字幕 | 日日操夜夜爱 | 日韩有码第一页 | 少妇69xx| 91色国产| 免费看日韩毛片 | 日韩精品免费一区二区夜夜嗨 | 亚洲av无码乱码国产精品久久 | 一级片黄色 | 日韩人妻无码一区二区三区99 | 欧美一级少妇 | 国产成人a人亚洲精品无码 最近中文字幕av | 女m被s玩胸虐乳哭着求饶 | 色鬼艳魔大战1春荡女淫 | 麻豆av在线播放 | 亚洲女成人图区 | 欧美国产片 | 久久久久久国产精品 | 久久久久久久成人 | 爱逼综合 | 成人免费黄色网 | 免费三片在线观看网站v888 | 免费看欧美大片 | 成人影片在线播放 | 日本美女交配 | 91大尺度| 岛国av大片 | 日韩欧美大片在线观看 | 97在线播放 | 夜夜操夜夜爱 | 人妻少妇偷人精品视频 | 国产卡一卡二 | 五月婷婷开心中文字幕 | 中国女人内谢69xxxx | 美女爆乳18禁www久久久久久 | 中文字幕一区二区三区精华液 | 深夜成人福利视频 | 国产成人a人亚洲精品无码 最近中文字幕av | 大地二资源在线观看高清国语版 | 柠檬福利第一导航在线 | 国产在线97 | 激情视频一区 | 久热在线| 亚洲一区国产一区 | 妻子的性幻想 | 免费a视频在线观看 | 日韩看片| av在线播放中文字幕 | 国产成人在线观看免费网站 | 绿帽视频 | 久久国产亚洲 | 国产精品探花一区二区在线观看 | 国产日比视频 | 五月开心网 | 日本高清二区 | 国产伦精品一区 | 亚洲涩综合 | 91久久国产综合久久91精品网站 | 亚洲最大av在线 | 性史性dvd影片农村毛片 | 免费黄色网址大全 | 激情开心网站 | 女人洗澡一级特黄毛片 | 91免费视频 | 日韩欧美大片在线观看 | 亚洲美女视频 | 波多野结衣简介 | 日韩五码 | 精品无码久久久久 | 国产精品自拍一区 | 亚洲色图自拍 | 成年人免费网站在线观看 | 91色站| av无限看 | 一区二区三区欧美视频 | 久久国产精品免费视频 | 丁香花电影免费播放电影 | 国产色网站 | 久久久久久中文字幕 | 91丨九色丨黑人外教 | 成人hd | ass亚洲肉体欣赏pics | 污污视频免费观看 | 性生活免费网站 | 国产又爽又黄视频 | 欧美xxxx18国产 | 欧美bbbbbbbbbbbb精品 | 野花视频免费在线观看 | 国产1区2区在线观看 | 欧美国产日韩一区二区 | 熟女人妻aⅴ一区二区三区60路 | 美女视频网址 | 四虎影视免费永久大全 | 国产精品v欧美精品v日韩 | 国产精品白虎 | 永久免费视频网站直接看 | 超碰免费av| 91精品国产免费 | 国产黄色一级大片 | 欧美高清hd18日本 | 国产一区免费 | 久久国产免费 | 奇米久久 | 国产一级二级 | 成人免费在线播放 | 欧美性生活一区二区 | 欧美亚洲另类小说 | 一级黄色免费 | 污污网站在线 | 欧美日韩专区 | 97在线视频免费 | 亚洲图色av | 欧洲激情网 | 免费一二三区 | 波多野结衣av无码 | 在线观看国产精品入口男同 | 黄网在线免费观看 | 在线观看黄色片 | 亚洲av无码乱码国产精品久久 | 亚洲性事| 懂色av一区二区三区免费观看 | 超碰97人人草 | 午夜在线网站 | 黄色片链接 | 亚洲天堂一区二区三区 | 牛牛电影国产一区二区 | 日本一区二区在线 | 玖玖国产 | 国产一级二级 | 黄av资源 | 二区三区视频 | 国产精品视频入口 | 久久伊人精品 | 免费三片在线观看网站v888 | 久久免费精品 | 精品不卡视频 | 狠狠干2023| 波多野结衣中文字幕在线 | 日本亚洲色大成网站www久久 | 三级av电影 | 日本在线视频免费观看 | 久久国产精品免费视频 | 日韩视频一区 | 嘿咻免费视频 | 成年网站在线视频网站 | 亚洲xxx视频| 黑人极品ⅴideos精品欧美棵 | 亚洲成年人| 国产日韩在线视频 | 国产又大又黄的视频 | 91桃色在线观看 | 在线观看黄色网页 | 一本一道久久a久久精品蜜桃 | 蜜臀尤物一区二区三区直播 | 久草视频免费在线 | 国产精品偷拍 | 4438成人网| 久久手机视频 | 天堂网av在线 | 欧美一级少妇 | 最新日韩在线 | 国内精品久久久久久 | 中文字幕第4页 | 女女在线 | 亚洲天堂av在线播放 | 青青草青青操 | 黄色漫画免费观看 | 青青草成人在线观看 | 火影忍者羞羞漫画 | 国产精品嫩草69影院 | 国产一区二区视频在线 | 激情网五月 | 97人人爱 | 免费麻豆视频 | av在线播放中文字幕 | 韩国一区二区三区在线观看 | 懂色av一区二区三区免费观看 | 成人h在线观看 | 日韩精品久 | 免费观看av的网站 | 国产又粗又猛视频免费 | 中国国产bdsm紧缚捆绑 | 人妻精品久久久久中文字幕 | 久久亚洲精品小早川怜子 | 久久久久久久精 | 亚洲男同视频 | 亚洲深夜视频 | 欧洲成人av | 青青免费在线视频 | 欧美做受xxxxxⅹ性视频 | 少妇被躁爽到高潮无码人狍大战 | mm131美女视频| 99re国产| 成人午夜淫片免费观看 | 中文字幕一二三 | 亚洲精品v| 一级免费观看 | 午夜资源站| 国产呦小j女精品视频 | 色婷婷在线影院 | 自拍偷拍专区 | 欧美激情黑白配 | 99热这里只有精品在线观看 | 日韩大尺度视频 | 亚洲熟妇无码久久精品 | 超碰在线国产 | 欧美成人黄色片 | 特黄色一级片 | 4438成人网 | 国产精品v欧美精品v日韩 | 婷婷av一区二区三区 | 女人洗澡一级特黄毛片 | 国产精品久久久久久吹潮 | av影院在线观看 | 欧美性猛交xxxx乱大交俱乐部 | 美女靠逼app | 成人影片在线播放 | 激情开心网站 | 亚洲女优在线观看 | 国产一区二区在线免费 | 狠狠操天天操 | 一区二区在线免费观看视频 | 女~淫辱の触手3d动漫 | 色婷婷社区 | 成年人视频免费在线观看 | 国产尻逼视频 | 超碰狠狠操| 婷婷午夜激情 | 免费成人av片 | 成人污视频在线观看 | 肉丝av| 成年人免费视频观看 | 永久91嫩草亚洲精品人人 | 俄罗斯特级毛片 | 日本网站免费观看 | 玉女心经 在线 | 激情小说在线 | av不卡网站 | 日韩av一二三 | 成年人免费网站在线观看 | 99热这里只有精品在线观看 | 免费观看av的网站 | 美女扒开尿口给男人桶 | 哪里可以看毛片 | 国产美女视频免费观看下载软件 | 成人啪啪漫画羞羞漫画 | www日本高清视频 | 日本精品在线 | 免费一级片视频 | 欧美性猛交xxxx乱大交退制版 | 91老肥熟| 亚洲欧美日韩综合在线 | 亚洲成年人影院 | 欧美xxxx18国产| 欧美成人小视频 | 人人草人人射 | 天天亚洲| 大香焦久久| 亚洲国产精品无码久久久久高潮 | 很黄很污的网站 | 久久久观看 | 欧美有码在线 | 天天操天天操天天操 | 欧美成人精品激情在线视频 | 玉女心经 在线 | 色婷婷综合久久久中文字幕 | 在线高清观看免费观看 | 国产精品视频在线观看 | 91视频污| 国产乱人 | 欧美精品久久久久久 | 91成人免费视频 | 夜夜操狠狠操 | 超碰免费av | 一级片手机在线观看 | 火影忍者羞羞漫画 | 超大量吹潮系列合集 | 爆操欧美美女 | 丁香花电影免费播放电影 | 清纯粉嫩极品夜夜嗨av | 日一日射一射 | 美女娇喘| 国产激情网址 | 国产中文字幕在线播放 | 男人都懂的网站 | aaaaa黄色片| 国产精选在线观看 | 韩国无码一区二区三区精品 | 欧美69久成人做爰视频 | 国产精品嫩草69影院 | 久久不卡影院 | 精品视频一区二区三区四区 | 91久久久久久 | 奶妈的诱惑 | mm131美女视频 | 潘金莲一级淫片免费放动漫 | 国产日比视频 | 秋霞av鲁丝片一区二区 | 欧美精品成人在线 | 日韩三级黄色 | 美女隐私无遮挡 | 丰满熟妇被猛烈进入高清片 | 香港黄色网 | 国产一区精品在线观看 | 日韩在线观看一区 | 激情宗合网 | 人成在线 | 国产亚洲精品女人久久久久久 | 一区二区在线免费观看视频 | 日韩一区二区三区四区在线 | 亚洲激情网 | 米奇影视777 | 中文字幕一二三 | 日日碰 | 日韩精品一区二区三区免费视频 | www.色多多| 国产乱子伦精品视频 | 波多在线观看 | 黄色av中文字幕 | 久久大香 | 成人影片在线播放 | 中文在线免费视频 | 欧美专区第一页 | 老鸭资源 | 年代下乡啪啪h文 | 丁香六月综合 | 精久久久久久久 | 特色黄色片 | 日韩一区二区三区四区五区六区 | 欧美有码在线 | 日屁网站| 亚洲欧美精品一区二区三区 | 男女日批视频 | 久久精品一 | yy6080午夜| 免费看一级大片 | 久久成人免费视频 | 在线观看毛片网站 | 欧美精品一线 | 7777奇米影视 | 免费色片 | 操操干干 | 黄色精品在线观看 | 国产高清免费在线播放 | 性综艺节目av在线播放 | 日日操夜夜爱 | 日屁网站| 欧美高清hd18日本 | 青青青国产在线 | 国产精品2 | 久久与婷婷 | 成人在线播放视频 | 国产精品一级 | 沟厕沟厕近拍高清视频 | 五月婷婷中文 | 午夜在线网站 | 国产麻豆精品久久一二三 | 精品国产欧美一区二区三区成人 | 久久成人在线 | 成人啪啪漫画羞羞漫画 | 免费在线观看黄色av | 中国极品少妇xxxx做受 | 夜夜摸夜夜操 | 久久精品噜噜噜成人 | 亚洲精品白浆高清久久久久久 | 精品视频一区二区三区四区 | 日韩啊啊啊 | 丰满熟妇乱又伦 | 潘金莲一级淫片免费放动漫 | 青春草视频 | 欧美一级网| 久久作爱视频 | 精品国产欧美一区二区三区成人 | 免费av网站观看 | 激情宗合网 | 日本五十肥熟交尾 | 国产精品白丝喷水在线观看 | 中文字幕 自拍偷拍 | 免费在线一区二区三区 | 99久久久无码国产精品免费蜜柚 | 美女一区二区三区四区 | 看片网站在线观看 | 女人洗澡一级特黄毛片 | 色婷婷av一区二区三区之红樱桃 | 婷婷五月综合久久中文字幕 | 碧蓝之海动漫在线观看免费高清 | 欧美区一区二 | 久久久久久久成人 | 国产精品久久久久久吹潮 | 日本人体视频 | www夜片内射视频日韩精品成人 | 91免费影片 | 日本精品在线 | 免费成人av在线 | 亚洲激情成人 | 美女爆乳18禁www久久久久久 | 国产精品111 | 国产片在线 | 欧美片网站免费 | www日本高清视频 | 91精品国产aⅴ一区二区 | 欧美日韩影院 | 中文字幕av久久爽一区 | 亚洲综合小说 | 激情小说亚洲图片 | 免费观看av的网站 | 91久久国产综合久久91精品网站 | 欧美精品久久99 | 亚洲一区二区精品在线 | 91黄色大片 | 日韩中文字幕不卡 | 欧美一区二区三区不卡 | 国产呦小j女精品视频 | ass大乳尤物肉体pics | 国产视频大全 | 国产精品第三页 | 日韩欧美一级片 | 视频在线观看免费大片 | 肉丝av| 能免费看av的网站 | 91亚洲国产成人精品一区 | 青青免费在线视频 | 日韩精品一区二区三区免费视频 | 午夜三区 | 国产一级二级 | 国产麻豆精品久久一二三 | 国产精品女优 | 免费的一级片 | 超碰在线影院 | 亚洲欧美另类图片 | 欧美一级网 | 人人草人人爽 | 超碰美女 | 欧美黑人xxxx | 人人草人人爽 | 成年网站在线视频网站 | 一区二区三区毛片 | 成人av图片| 日韩三级 | 在线播放国产一区 | 亚洲深夜视频 | 亚洲精品第一页 | 国产无套精品一区二区三区 | 中文字幕一区二区三区人妻不卡 | 超碰夫妻 | 337p亚洲精品色噜噜狠狠 | 国产日韩在线视频 | 美女扒开尿口给男人桶 | 中文av网| 精品无码人妻一区二区三区品 | 成人观看 | 久久午夜视频 | 亚洲国产精品免费 | 欧美熟妇精品一区二区蜜桃视频 | 91人人爽| 狠狠干超碰 | 日韩精品五区 | 91成人免费看 | 国产精品入口麻豆 | 九九热视频在线播放 | 欧美亚洲中文精品字幕 | 色婷婷av一区二区三区之红樱桃 | 天天操天 | 国产无遮挡裸体免费视频 | 黄网在线免费观看 | 成年人视频网 | 国产a级黄色片 | 激情小说亚洲图片 | 在线色av | 在线精品观看 | 日韩高清不卡 | 成人av网站在线 | 综合导航| 伊人久久大香线蕉av一区 | 色鬼艳魔大战1春荡女淫 | 日韩av第一页 | 久久99久久99精品免观看软件 | 久久精品爱 | 午夜国产精品视频 | 午夜寂寞院| 无码人妻精品一区二区三区蜜桃91 | 亚洲最新网址 | 都市激情 亚洲 | 免费一级毛片麻豆精品 | 欧美成人小视频 | 五月婷婷小说 | 日韩免费网站 | 欧美xxxx18国产| 色愁久久| 欧美日韩亚洲二区 | 美国av导航| 欧美日韩影院 | 成人在线综合 | 色婷婷av一区二区三区之红樱桃 | 超污视频网站 | 青青草青青操 | 国产精品天天干 | 青青草狠狠干 | 亚洲欧美日韩综合在线 | 日韩欧美精品在线 | 9999热| 尤物视频免费观看 | 中文字幕亚洲精品 | 日韩精品无码一区二区三区久久久 | 国产午夜精品理论片 | 成人性生交大片免费 | 免费精品久久 | 国产精品精品国产 | 懂色av蜜臀av粉嫩av分享 | 久久综合狠狠综合久久综合88 | 五月婷婷,六月丁香 | 国偷自产视频一区二区久 | 95在线视频 | 欧美bbbbbbbbbbbb精品 | 欧美mv日韩mv国产网站app | 成人激情片 | 97在线公开视频 | 人妻丰满熟妇av无码区hd | 善良的女朋友在线观看 | 在线欧美| 日韩美女网| 日韩美女在线视频 | 黄色一级带| 黄免费看 | 女~淫辱の触手3d动漫 | 日韩在线观看视频网站 | 午夜在线网站 | 久久久观看 | 欧美a∨ | 操干视频| 日韩精品在线一区 | 激情宗合网 | 国产精品久久久久久吹潮 | 成人激情片 | 中文字幕 自拍偷拍 | a在线观看| 天天操天| 国产视频一区在线 | 精品人妻无码中文字幕18禁 | 日韩美女网 | 国产视频黄 | 性生活免费网站 | 潘金莲一级淫片免费放动漫 | 91精品国产免费 | 特级av片 | 奇米色777 | 香港a毛片 | 午夜在线观看影院 | 欧美日韩三级在线 | 亚洲精品乱码久久久久 | 欧美一卡二卡三卡 | 日本高清三区 | 国产无遮挡裸体免费视频 | 捆绑无遮挡打光屁股 | 91天天| 久久精品成人 | 亚洲视频国产精品 | 亚洲精品自拍 | 久久色婷婷 | 中文字幕第一页在线 | 7799精品视频| 国产高清av在线 | 天天草夜夜| 色哟哟一区 | 91免费影片| 国语对白永久免费 | www.日本高清 | 日本一级一片免费视频 | 一区二区在线免费观看视频 | 一本一道久久a久久精品蜜桃 | 动漫3d精品一区二区三区乱码 | 奇米影视av | 日韩国产欧美一区二区 | 玉女心经在线看 | 黄色小说免费在线观看 | 成年女人免费视频 | 91亚洲精品在线观看 | 日韩爱爱网 | 日本国产一区二区三区 | 免费三片在线观看网站v888 | 中日韩中文字幕 | 久草久热 | 日日夜操 | 在线色av| gogogo日本免费观看电视 | 成人久久视频 | 国产一区精品在线观看 | 日本福利在线观看 | 夜夜操夜夜爱 | 午夜国产片 | 国产精品黑丝 | a级黄毛片 | 麻豆成人免费 | gogo人体做爰大胆视频 | 日本极品丰满ⅹxxxhd | 麻豆成人在线 | 亚洲三级免费 | 亚洲高清成人 | 一级免费观看 | 99热这里只有精品在线观看 | 日本高清视频在线 | 日本在线三级 | 午夜色福利 | 亚洲精品色午夜无码专区日韩 | 捆绑无遮挡打光屁股 | 欧美成人激情在线 | 强睡邻居人妻中文字幕 | 女同vk| 青青草成人在线观看 | 国产一区免费视频 | 涩涩网站在线观看 | 日韩精品福利 | 噜噜噜久久 | 黄色一级图片 | 日韩精品在线视频 | 打屁股调教视频 | 4hu最新网址 | 久久色婷婷 | 北条麻妃99精品青青久久 | 一级免费观看 | 日韩精品一区二区三区免费视频 | 色欲av无码一区二区三区 | 日韩一区二区三区四区五区六区 | <