亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 編程 > HTML > 正文

使用Html5多媒體實(shí)現(xiàn)微信語(yǔ)音功能

2024-08-26 00:21:35
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

隨著微信等社交App的興起,語(yǔ)音聊天成為很多App必備功能,大到將語(yǔ)音聊天作為主要功能的社交App,小到電商App的語(yǔ)音客服、店小二功能,語(yǔ)音聊天成為了必不可少的方式。

但是很多人感覺(jué)網(wǎng)頁(yè)端語(yǔ)音離我們很遙遠(yuǎn),這些更多是本地應(yīng)用的工作,其實(shí)不然,隨著Html5的發(fā)展,語(yǔ)音功能也漸漸成為前端必會(huì)的功能之一。

為什么要學(xué)會(huì)HTML5 的語(yǔ)音呢?

1.Html5 規(guī)范推進(jìn),手機(jī)的更新加速了操作系統(tǒng)更新,語(yǔ)音功能將會(huì)變成前端主要的工作之一,就像現(xiàn)在的canvas一樣。前端實(shí)現(xiàn)語(yǔ)音功能開(kāi)發(fā)速度更快,更節(jié)省人力(這意味著給老板省錢(qián),給老板省錢(qián)就是在給自己漲工資)

2.即使是現(xiàn)在本地應(yīng)用做語(yǔ)音功能,熟悉前端語(yǔ)音交互的各種坑能夠讓你們的同事關(guān)系更和諧,協(xié)作更順暢,而不是互相掐架。

3.了解新的技術(shù)可以預(yù)防面試,二來(lái)可以預(yù)判技術(shù)潮流,不至于學(xué)了一堆屠龍之技或者墨守成規(guī),更有利于讓自己的知識(shí)和職業(yè)核心競(jìng)爭(zhēng)力一直處在食物鏈的頂端。

4.前端大部分人對(duì)語(yǔ)音功能有誤解,以為語(yǔ)音功能就是HTML5 audio標(biāo)簽而已,事實(shí)上真的不是那么簡(jiǎn)單的"而已"

不墨跡那么多,咱們直接開(kāi)發(fā)一個(gè)小項(xiàng)目啥都明明白兒白兒了,先看效果圖

clipboard.png

業(yè)務(wù)邏輯非常簡(jiǎn)單,

跟我們微信用法一模一樣,手按下去字變成松開(kāi)結(jié)束,同時(shí)說(shuō)話(huà)被錄下來(lái),松手的時(shí)候,變成按下結(jié)束,同時(shí)發(fā)送語(yǔ)音給對(duì)方

我們一步一步一步來(lái),首先我們先整一個(gè)html頁(yè)面

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta http-equiv="X-UA-Compatible" content="ie=edge">    <title>微信語(yǔ)音</title>    <link rel="stylesheet" href="css/record.css"></head><body>    <div id="wrap">        <header id="header">            <div id="left">                <i class="material-icons">                    chevron_left                </i>                微信(184)            </div>            <div id="mid">艾達(dá)·王</div>            <div id="right">                <i class="material-icons">                    more_horiz                </i>            </div>        </header>        <div id="contentWrap">            <ul id="chatList">                <li class="item_me">                    <div class="chatContent">我是不是你最疼愛(ài)的人?                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg"                    </div>                    <div class="chatContent">奔跑吧,兄弟?。L犢子)                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">這里我就不多說(shuō)了,上來(lái)就是一梭子代碼……                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg"                    </div>                    <div class="chatContent">大彬哥,你說(shuō)你咋這么優(yōu)秀呢?看見(jiàn)你我有一種大海的感覺(jué)                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">老妹兒,你是不是喜歡上我了呢……                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg"                    </div>                    <div class="chatContent">不是,我暈船,看見(jiàn)你想吐……                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>            </ul>        </div>        <footer id="footer">            <div id="keyboard">                <i class="material-icons">                    keyboard                </i>            </div>            <div id="sayBtn">                <span id="sendBtn" class="sendBtn">按下 說(shuō)話(huà)</span>            </div>            <div id="icon"><i class="material-icons">                    sentiment_satisfied                </i></div>            <div id="add"><i class="material-icons">                    add_circle_outline                </i></div>        </footer>    </div></body></html>

css部分,

*{    margin: 0;    padding: 0;}ul li{ list-style: none;}html,body{    height: 100%;    width: 100%;    overflow: hidden;}body{    background: #ebebeb;}@font-face {    font-family: 'Material Icons';    font-style: normal;    font-weight: 400;    src: url(../css/iconfont/MaterialIcons-Regular.eot); /* For IE6-8 */    src: local('Material Icons'),      local('MaterialIcons-Regular'),      url(../css/iconfont/MaterialIcons-Regular.woff) format('woff2'),      url(../css/iconfont/MaterialIcons-Regular.woff2) format('woff'),      url(../css/iconfont/MaterialIcons-Regular.ttf) format('truetype');  }  .material-icons {    font-family: 'Material Icons';    font-weight: normal;    font-style: normal;    font-size: 32px;  /* Preferred icon size */    display: inline-block;    /* line-height: 0.01rem; */    text-transform: none;    letter-spacing: normal;    word-wrap: normal;    white-space: nowrap;    direction: ltr;      /* Support for all WebKit browsers. */    -webkit-font-smoothing: antialiased;    /* Support for Safari and Chrome. */    text-rendering: optimizeLegibility;      /* Support for Firefox. */    -moz-osx-font-smoothing: grayscale;      /* Support for IE. */    font-feature-settings: 'liga';  }#wrap{    display: flex;    flex-direction: column;    justify-content: space-between;    height: 100%;}#header{    height: 46px;    line-height: 46px;    background: #363539;    display: flex;    align-items: center;    color: #fff;    justify-content: space-between;}#header #left{    display: flex;    align-items: center;    font-size: 14px;    width: 100px;}#header #right{    display: flex;    align-items: center;    width: 100px;    justify-content: flex-end;}#header #right i{    padding-right: 6px;}#header #mid{    text-align: center;    flex: 1;}#contentWrap{    flex: 1;    overflow-y:auto;}.item_me,.item_audio{    display: flex;    align-items: flex-start;    justify-content:flex-end;    padding: 8px;}.item_you{    display: flex;    align-items: flex-start;    justify-content:flex-start;    padding: 8px;}.avatar{    width: 40px;    height: 40px;}.avatar img{width: 100%;}.item_me .chatContent{    padding: 10px;    background: #a0e75a;    border: 1px solid #6fb44d;    margin-right: 15px;    border-radius: 5px;    position: relative;}.chatContent span{width:0; height:0; font-size:0; overflow:hidden; position:absolute;}.item_me .chatContent span.bot{    border-width:8px;     border-style:solid dashed dashed;     border-color: transparent transparent transparent #6fb44d;     right:-17px;     top:10px;}.item_me .chatContent span.top{    border-width:8px;     border-style:solid dashed dashed;     border-color:transparent transparent transparent #a0e75a ;      right:-15px;     top:10px;} .item_you .chatContent{    padding: 10px;    background: #a0e75a;    border: 1px solid #6fb44d;    margin-left: 15px;    border-radius: 5px;    position: relative;} .item_you .chatContent span.bot{    border-width:8px;     border-style:solid dashed dashed;     border-color: transparent #6fb44d transparent transparent ;     left:-17px;     top:10px;}.item_you .chatContent span.top{    border-width:8px;     border-style:solid dashed dashed;     border-color:transparent #a0e75a transparent transparent  ;      left:-15px;     top:10px;}        #footer{    height: 46px;    padding: 0 4px;    background: #f4f5f6;    border-top: 1px solid #d7d7d8;    display: flex;    align-items: center;    color: #7f8389;    justify-content: space-around;}#sayBtn{    flex: 1;    display: flex;    margin: 0 5px;    color:#565656;    font-weight: bold;}.sendBtn{    display: block;    flex: 1;    padding: 8px;    background: #f4f5f6;    border:1px solid #bec2c1;    border-radius: 5px;    text-align: center;}.activeBtn{    display: block;    flex: 1;    padding: 8px;    background: #c6c7ca;    border:1px solid #bec2c1;    border-radius: 5px;    text-align: center;}.item_audio .chatContent{    padding: 6px;    background: #fff;    border: 1px solid #999;    border-radius: 5px;    margin-right: 15px;    position: relative;    width:120px;    min-height: 20px;}.item_audio .chatContent span.bot{    border-width:8px;     border-style:solid dashed dashed;     border-color: transparent transparent transparent #999;     right:-17px;     top:10px;}.item_audio .chatContent span.top{    border-width:8px;     border-style:solid dashed dashed;     border-color:transparent transparent transparent #fff ;      right:-15px;     top:10px;} .material-icons_wifi{    transform: rotate(90deg);    color: #a5a5a5;    font-size: 22px;}.redDot{    background: #f45454;    border-radius: 50%;    width: 8px;    height: 8px;    margin-right: 10px;}

這里我說(shuō)兩個(gè)注意點(diǎn),

1.html部分:

圖省事我并沒(méi)有像素級(jí)切圖,圖省事我也直接用了svg圖標(biāo),具體庫(kù)我使用的是

https://material.io/tools/icons/?style=outline

2.css部分:使用flex布局。我只是為了講解Html5功能,所以flex并沒(méi)有寫(xiě)兼容性寫(xiě)法,另外App頭部部分寫(xiě)法大家注意一下,那里是非常常用的。

下面說(shuō)重點(diǎn)js部分。

 

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta http-equiv="X-UA-Compatible" content="ie=edge">    <title>微信語(yǔ)音</title>    <link rel="stylesheet" href="css/record.css">    <script>        document.addEventListener('DOMContentLoaded', function () {            var oSendBtn = document.getElementById('sendBtn');            var soundClips = document.querySelector('.sound-clips');            var mediaRecorder;            var oChatList = document.getElementById('chatList');            navigator.getUserMedia = (navigator.getUserMedia ||                navigator.webkitGetUserMedia ||                navigator.mozGetUserMedia ||                navigator.msGetUserMedia);            if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {                navigator.mediaDevices.getUserMedia(                    // constraints - only audio needed for this app                    {                        audio: true                    })                    // Success callback                    .then(function (stream) {                        rec(stream);                    })                    // Error callback                    .catch(function (err) {                    }                    );            } else {            }             function rec(stream) {                mediaRecorder = new MediaRecorder(stream);                oSendBtn.addEventListener('touchstart', function (ev) {                    ev.preventDefault();                    this.innerHTML = '松開(kāi) 結(jié)束';                    this.classList.add('activeBtn');                    mediaRecorder.start();                }, false);                oSendBtn.addEventListener('touchend', function (ev) {                    ev.preventDefault();                    this.innerHTML = '按下 說(shuō)話(huà)';                    this.classList.remove('activeBtn');                    mediaRecorder.stop();                }, false);                mediaRecorder.ondataavailable = function (e) {                    var clipContainer = document.createElement('li');                    var audio = document.createElement('audio');                    clipContainer.classList.add('item_audio');                    clipContainer.innerHTML = `                    <div class = "redDot"></div>                    <div class="chatContent">                        <i class="material-icons material-icons_wifi">wifi</i>                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>`;                    audio.setAttribute('controls', '');                    oChatList.appendChild(clipContainer);                    var audioURL = window.URL.createObjectURL(e.data);                    audio.src = audioURL;                    oChatList.addEventListener('touchstart', function (ev) {                        if (ev.srcElement.parentNode.className!== 'item_audio') return;                        audio.play();                        ev.srcElement.parentNode.removeChild(ev.srcElement.parentNode.children[0])                    }, false);                };            }        }, false);    </script></head><body>    <div id="wrap">        <header id="header">            <div id="left">                <i class="material-icons">                    chevron_left                </i>                微信(184)            </div>            <div id="mid">艾達(dá)·王</div>            <div id="right">                <i class="material-icons">                    more_horiz                </i>            </div>        </header>        <div id="contentWrap">            <ul id="chatList">                <li class="item_me">                    <div class="chatContent">我是不是你最疼愛(ài)的人?                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg"                    </div>                    <div class="chatContent">奔跑吧,兄弟!(滾犢子)                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">這里我就不多說(shuō)了,上來(lái)就是一梭子代碼……                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg"                    </div>                    <div class="chatContent">大彬哥,你說(shuō)你咋這么優(yōu)秀呢?看見(jiàn)你我有一種大海的感覺(jué)                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">老妹兒,你是不是喜歡上我了呢……                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg"                    </div>                    <div class="chatContent">不是,我暈船,看見(jiàn)你想吐……                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>            </ul>        </div>        <footer id="footer">            <div id="keyboard">                <i class="material-icons">                    keyboard                </i>            </div>            <div id="sayBtn">                <span id="sendBtn" class="sendBtn">按下 說(shuō)話(huà)</span>            </div>            <div id="icon"><i class="material-icons">                    sentiment_satisfied                </i></div>            <div id="add"><i class="material-icons">                    add_circle_outline                </i></div>        </footer>    </div></body></html>

這里實(shí)現(xiàn)的錄影功能要注意的點(diǎn)很多,我們一個(gè)個(gè)說(shuō),

第一個(gè)東西,

 

navigator.getUserMedia = (navigator.getUserMedia ||                navigator.webkitGetUserMedia ||                navigator.mozGetUserMedia ||                navigator.msGetUserMedia);            if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {                navigator.mediaDevices.getUserMedia(                    {                        audio: true                    })                    // Success callback                    .then(function (stream) {                        rec(stream);                    })                    // Error callback                    .catch(function (err) {                    }                    );            } else {            }

 

當(dāng)大家看一些html5關(guān)于錄音的接口的時(shí)候,你看到這個(gè)

Navigator.getUserMedia()

就要小心了,這個(gè)是老規(guī)范的東西了,被廢了,新的是

navigator.mediaDevices.getUserMedia

html5 多媒體里面的語(yǔ)音這塊換了好幾茬規(guī)范,很亂,有些標(biāo)簽甚至一個(gè)瀏覽器都沒(méi)實(shí)現(xiàn)過(guò),未曾綻放就枯萎了,你也不用關(guān)心也沒(méi)必要浪費(fèi)那個(gè)時(shí)間知道,你只要知道我說(shuō)這些就夠了,因?yàn)槟阒滥切┍粡U掉的過(guò)往沒(méi)啥用,有那個(gè)時(shí)間還不如來(lái)一局LOL或者王者榮耀(雖然我并不懂二者的區(qū)別,不過(guò)這兩個(gè)游戲應(yīng)該都挺好玩吧,沒(méi)玩過(guò)不懂)。

里面的東西大家也不需要看懂,什么promise了,什么媒體流了,你不用知道,你就知道這樣一件事就行了,

上面的代碼就相當(dāng)于打開(kāi)了水龍頭(或者說(shuō)按下的錄音機(jī)的錄音鍵),那么我們得有東西接著水啊,我們可以用電飯鍋(錄音機(jī)的話(huà)就是磁帶)放水龍頭下面看著它往里面ci(我們老家話(huà),射的意思),如下代碼

mediaRecorder = new MediaRecorder(stream);

接下來(lái)就是,一按按鈕就生米煮成熟飯了,對(duì)應(yīng)錄音機(jī)就是錄完了按按鈕就播放了,但是在我們程序里面要想播放你不僅要有磁帶,還得有錄音機(jī),錄音機(jī)就是audio標(biāo)簽,沒(méi)有好辦,我們new一個(gè)。這個(gè)世界上沒(méi)有什么對(duì)象是程序員不敢new的,new一個(gè)不行,就new兩個(gè)。剩下的代碼除了嚇人之外,沒(méi)啥缺點(diǎn),簡(jiǎn)單的令人發(fā)指。

mediaRecorder.ondataavailable = function (e) {                    var clipContainer = document.createElement('li');                    var audio = document.createElement('audio');                    clipContainer.classList.add('item_audio');                    clipContainer.innerHTML = `                    <div class = "redDot"></div>                    <div class="chatContent">                        <i class="material-icons material-icons_wifi">wifi</i>                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png"                    </div>`;                    audio.setAttribute('controls', '');                    oChatList.appendChild(clipContainer);                    var audioURL = window.URL.createObjectURL(e.data);                    audio.src = audioURL;                    oChatList.addEventListener('touchstart', function (ev) {                        if (ev.srcElement.parentNode.className!== 'item_audio') return;                        audio.play();                        ev.srcElement.parentNode.removeChild(ev.srcElement.parentNode.children[0])                    }, false);                };

 

其實(shí)就是錄好了就播。

OK,是不是很簡(jiǎn)單 ,整個(gè)項(xiàng)目我說(shuō)幾個(gè)點(diǎn)吧:

1.切圖結(jié)構(gòu)合理是你后面做功能的前提,結(jié)構(gòu)做的好,后面就省事,想想諸葛不亮吧,未出茅廬人家就把html5結(jié)構(gòu)搭好了,有三個(gè)section.

2.原生js和ES6的基礎(chǔ)打牢可以為你提供不同的思路,比如我這里就使用了事件委托,還有ES6模板引擎。尤其是事件委托,不用的話(huà)查找節(jié)點(diǎn)很麻煩,另外代碼套來(lái)套去也容易亂。

3.新的 知識(shí)和技術(shù)其實(shí)并不復(fù)雜,其實(shí)很簡(jiǎn)單,你想如果新技術(shù)不是為了讓功能更好實(shí)現(xiàn),更能解決我們的問(wèn)題,那開(kāi)發(fā)新技術(shù)干嘛?因?yàn)槟菐痛蠛拥拇笈儧](méi)事干怕被領(lǐng)導(dǎo)說(shuō)工作量不飽和?技術(shù)是為了解決問(wèn)題和讓我們生活更美好服務(wù)的。

4.這個(gè)項(xiàng)目IOS 11以下跑不通,因?yàn)镮OS 11.2之前不支持這個(gè)方法,需要IOS本地應(yīng)用開(kāi)發(fā)人員給你提供支援,但是在android下面是很OK的。而且可以預(yù)見(jiàn),再過(guò)幾年IOS 原生也不用給你支援都支持了,那你開(kāi)發(fā)效率得多高。不要以為這些技術(shù)很遙遠(yuǎn),html5真正商用也不過(guò)15年左右(vue 、react、angular大規(guī)模使用才幾年?),機(jī)會(huì)留給有準(zhǔn)備的人。

整個(gè)項(xiàng)目細(xì)節(jié)和要注意的點(diǎn)還是很多的,希望大家真正自己敲一遍,因?yàn)槟憧炊宋业奈恼赂銜?huì)用這個(gè)技術(shù)兩碼事,祝大家在前端的路上越走越遠(yuǎn)(記得?;貋?lái)看看^_^)。

總結(jié)

以上所述是小編給大家介紹的使用Html5多媒體實(shí)現(xiàn)微信語(yǔ)音功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到HTML教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
手机在线观看国产精品| 精品久久久久久无码中文野结衣| 四虎成人精品在永久在线观看| 国产中文字幕一区| av一区二区久久| 欧美色视频一区二区三区在线观看| 国产夜色精品一区二区av| 欧美日韩国产高清电影| 黄色国产网站在线观看| 97人澡人人添人人爽欧美| 欧美色图色就是色| 六月婷婷色综合| 另类专区欧美制服同性| 农村黄色一级片| 欧美一区三区四区| 日韩免费视频一区二区视频在线观看| 国产精品久久久午夜夜伦鲁鲁| 欧美激情视频网址| 国产精一区二区| 2020国内自拍视频| 在线视频你懂| 91香蕉国产在线观看| 欧美大片1688| 污视频在线看网站| 激情视频网站在线观看| 日本r级电影在线观看| 久久精品免费看| 国产丝袜护土调教在线视频| 亚洲自拍另类综合| 亚洲精品www久久久久久广东| 91麻豆精品秘密| 日本午夜视频| 日本三级片在线观看| 无码日韩人妻精品久久蜜桃| 成人性生交大片| 青青草免费av| 精品国产91乱高清在线观看| 国产图片综合| 黑人巨大精品欧美黑白配亚洲| 欧美激情精品久久久久久小说| 538任你躁精品视频网免费| 亚洲 自拍 另类 欧美 丝袜| 国产精品久久婷婷| 永久免费av片在线观看全网站| 亚洲欧美日韩另类精品一区二区三区| 日韩激情图片| 国产成人精选| 日韩福利片在线观看| 91视频xxxx| caoporn97在线视频| 国产一区二区三区高清播放| 精品久久久久久中文字幕一区奶水| 碰草在线视频| 欧美性猛交xxxx乱大交丰满| 中文字幕一二三| 一本色道久久综合亚洲精品不卡| 亚洲一区二区三区精品在线观看| 99一区二区三区| 亚洲国产成人av在线| 国产美女永久免费无遮挡| 中文字幕免费观看视频| 天堂中文在线网| 久久中文字幕无码| 国产精品久久久久久| 9765激情中文在线| 国产精品亚洲二区在线观看| 成人午夜剧场视频网站| 午夜精品国产更新| 黑森林精品导航| 小向美奈子av| 亚洲欧洲日产国码av系列天堂| 久久久999免费视频| 国产精品一级| 亚洲啪啪综合av一区二区三区| www日本在线观看| 鲁丝片一区二区三区| www.精选视频.com| 99久久亚洲一区二区三区青草| 色综合.com| 色婷婷av一区二区三区久久| 日韩精品福利视频| 国产精品久久久久久一区二区| 性生交大片免费看女人按摩| 免费黄色国产视频| 亚洲欧美日韩动漫| 亚洲性猛交xxxx乱大交| 在线观看不卡一区| 免费成人在线网站| 欧美一个色资源| 久久99精品久久久久子伦| 黄色网战在线观看| 瑟瑟在线观看| 香蕉久久夜色精品国产更新时间| 麻豆疯狂做受xxxx高潮视频| 制服丝袜亚洲精品中文字幕| 亚洲免费观看高清完整| 香蕉久久a毛片| 色综合电影网| 老司机2019福利精品视频导航| 亚洲黄色免费在线观看| 精品久久亚洲| 国产成人免费视频网站| 三级精品视频| 国产精品一区二区免费看| 久久成人免费视频| 97超碰在线人人| 久久国产精品99国产| 视频在线观看免费影院欧美meiju| 欧美福利第一页| 九九热hot精品视频在线播放| 看片一区二区| 国模极品一区二区三区| www.夜夜爱| 黄页免费在线观看| 亚洲欧洲午夜一线一品| 国产高潮视频在线观看| 久久精品国产亚洲a∨麻豆| 色综合婷婷久久| 欧美国产成人精品一区二区三区| 五月激情婷婷网| 韩国午夜理伦三级不卡影院| 九色在线播放| 亚洲av片不卡无码久久| 久久99性xxx老妇胖精品| 高清不卡一区二区三区| 超碰97久久国产精品牛牛| 91社区在线观看| 成人网在线播放| 郴州新闻综合频道在线直播| 黄色亚洲精品| 不卡的国产精品| 国产尤物在线播放| 亚洲精品国产电影| 天天色天天射综合网| 亚洲黄色大片| 国产精品久久久久9999赢消| 91精品啪在线观看国产60岁| 国产精品日日摸夜夜摸av| 美女999久久久精品视频| 欧美黄色免费视频| 国自产拍偷拍精品啪啪一区二区| 老司机在线精品视频| 超碰aⅴ人人做人人爽欧美| 国产尤物在线视频| 四虎精品影院在线观看视频| 日韩影院一区二区| 伊是香蕉大人久久| 91在线地址| 永久免费观看精品视频| 羞羞电影在线观看www| 日本免费新一区视频| 精品视频一区二区三区在线观看| 日韩中文字在线| 亚洲av综合色区无码另类小说| 国内精品视频一区二区三区| 夜夜揉揉日日人人青青一国产精品| 成年男女免费视频网站不卡| 日本一区二区高清| 日本韩国欧美超级黄在线观看| 国产美女永久免费| 国产综合动作在线观看| 91在线丨porny丨国产| 婷婷综合影院| 玖玖爱这里只有精品| 久久免费视频网站| 在线观看免费视频一区二区三区| 国产麻豆精品在线观看| 亚洲黄色一区| 国产精品美腿一区在线看| 在线一区二区三区四区| 日韩精品在在线一区二区中文| 91国内在线播放| 香港欧美日韩三级黄色一级电影网站| 日本中文字幕高清视频| 亚洲香蕉中文网| 97香蕉久久夜色精品国产| 性猛交ⅹxxx富婆video| 日韩精品免费电影| 88av在线播放| 在线看的网站你懂| 国产一区二区在线观看视频| 成人美女视频在线看| 精品美女在线观看视频在线观看| 北条麻妃在线一区二区| av加勒比在线| 精品久久久一区| 福利一区二区在线| 精品人在线二区三区| 午夜久久久久久久| 在线免费观看黄色小视频| 亚洲国产精品成人无久久精品| 精品久久久久久中文字幕| 国产精品h视频| 成人春色激情网| 日韩电影av| 国产探花精品一区二区| 黑人巨大40厘米重口ysn| 99re免费99re在线视频手机版| 成人黄色片视频网站| 日韩av在线第一页| 成人福利网址| 中文字幕av一区二区三区| 在线免费看黄网站| 日本成人手机在线| 又粗又大的机巴好爽欧美| 116美女写真午夜一级久久| av在线影视| 福利地址发布页| 99久久精品免费| 91玉足脚交白嫩脚丫在线播放| 亚洲精品一区二区三区蜜桃久| 无限国产资源| 午夜精品视频一区| 国产高清自拍一区| 国内精品麻豆| 日韩在线视频一区| 蜜桃视频在线观看播放| 很污很黄的网站| 欲色天天网综合久久| 91在线公开视频| 欧美日韩精品欧美日韩精品| 处破女av一区二区| 亚洲永久精品视频| 国产男女猛烈无遮挡在线喷水| 99久久国产免费| 欧洲猛交xxxx乱大交3| 久久成人免费观看| 国产免费人做人爱午夜视频| 国内精品嫩模av私拍在线观看| 人与牲动交xxxxbbb| 九九热视频精品在线观看| 精灵使的剑舞无删减版在线观看| 欧美丰满艳妇bbwbbw| 亚洲欧洲国产伦综合| 一级黄色毛毛片| 精品亚洲国内自在自线福利| 天天操天天操天天操| 成人高清伦理免费影院在线观看| 免费一级网站| 国产秒拍福利视频露脸| 1024成人网| 国产日韩欧美一区二区| 亚洲自拍第三页| 欧美在线播放一区| 都市激情亚洲综合| 内射毛片内射国产夫妻| 特级特黄刘亦菲aaa级| 精品人妻一区二区三区日产| 黄色免费视频观看| 国产九色在线| 久久精品91久久久久久再现| 国产伦精品一区二区三区千人斩| 性欧美暴力猛交69hd| 亚洲精品老司机| 精品捆绑美女sm三区| 奇米精品一区二区三区在线观看一| 天堂精品在线视频| 亚洲精品国产成人久久av盗摄| 日日碰狠狠添天天爽超碰97| 亚洲女在线观看| 亚洲精品一二区| 亚欧在线观看视频| 欧美黑人xxxx| 石原莉奈一区二区三区高清在线| 国产不卡网站| 国产精品日韩精品在线播放| 日韩午夜av一区| 最新视频 - x88av| 骚视频在线观看| 国产在线欧美在线| 丝袜老师在线| 国产第一页在线| 波多野结衣在线网站| 偷拍亚洲精品| 亚洲男人的天堂在线观看| 黄色电影网站在线观看| 国产一区免费在线观看| 26uuu另类亚洲欧美日本老年| 青娱乐国产精品视频| 91欧美精品午夜性色福利在线| 日韩高清av在线| 99精品国产一区二区三区2021| 日本激情视频网| 精品国产a一区二区三区v免费| 欧美久久在线| 国内精品免费视频精选在线观看| av五月婷婷| 久久久久久免费观看| 国产色综合一区二区三区| 日韩久久久久久久久| 国产精品8888| 久久久久久久久久美女| 色国产精品一区在线观看| 日韩美女一区二区三区| 中文字幕在线视频免费| 亚洲高清视频网站| 99精品美女视频在线观看热舞| 欧美色手机在线观看| 97人人做人人爱| 五月婷婷欧美视频| av在线电影免费观看| 午夜精品久久久内射近拍高清| 久久福利视频导航| 最近中文在线观看| 伊人精品影院| 国产美女福利视频| 亚洲欧美日韩在线一区| 香蕉成人啪国产精品视频综合网| 日韩av手机版| 欧美激情va永久在线播放| 精品国产自在精品国产浪潮| 精品国产一区av| 国产视频欧美| 风流少妇一区二区| a中文字幕www| 午夜dj在线观看高清视频完整版| 椎名由奈jux491在线播放| 男人的天堂va在线| 亚洲一区二区三区视频播放| 精品少妇一区二区三区在线视频| 国产精选久久| 国产精品99久久免费黑人人妻| 日本一区二区三区免费乱视频| 400部精品国偷自产在线观看| 欧美黑人xxxxx性受| 在线免费观看黄色片| 日韩免费黄色片| 爱啪视频在线观看视频免费|