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

首頁 > 開發 > HTML5 > 正文

使用Html5多媒體實現微信語音功能

2024-09-05 07:22:56
字體:
來源:轉載
供稿:網友

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

但是很多人感覺網頁端語音離我們很遙遠,這些更多是本地應用的工作,其實不然,隨著Html5的發展,語音功能也漸漸成為前端必會的功能之一。

為什么要學會HTML5 的語音呢?

1.Html5 規范推進,手機的更新加速了操作系統更新,語音功能將會變成前端主要的工作之一,就像現在的canvas一樣。前端實現語音功能開發速度更快,更節省人力(這意味著給老板省錢,給老板省錢就是在給自己漲工資)

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

3.了解新的技術可以預防面試,二來可以預判技術潮流,不至于學了一堆屠龍之技或者墨守成規,更有利于讓自己的知識和職業核心競爭力一直處在食物鏈的頂端。

4.前端大部分人對語音功能有誤解,以為語音功能就是HTML5 audio標簽而已,事實上真的不是那么簡單的"而已"

不墨跡那么多,咱們直接開發一個小項目啥都明明白兒白兒了,先看效果圖

clipboard.png

業務邏輯非常簡單,

跟我們微信用法一模一樣,手按下去字變成松開結束,同時說話被錄下來,松手的時候,變成按下結束,同時發送語音給對方

我們一步一步一步來,首先我們先整一個html頁面

<!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>微信語音</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">艾達·王</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">我是不是你最疼愛的人?                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">奔跑吧,兄弟!(滾犢子)                        <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" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">大彬哥,你說你咋這么優秀呢?看見你我有一種大海的感覺                        <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" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">不是,我暈船,看見你想吐……                        <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">按下 說話</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;}

這里我說兩個注意點,

1.html部分:

圖省事我并沒有像素級切圖,圖省事我也直接用了svg圖標,具體庫我使用的是

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

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

下面說重點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>微信語音</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 = '松開 結束';                    this.classList.add('activeBtn');                    mediaRecorder.start();                }, false);                oSendBtn.addEventListener('touchend', function (ev) {                    ev.preventDefault();                    this.innerHTML = '按下 說話';                    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" alt="">                    </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">艾達·王</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">我是不是你最疼愛的人?                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">奔跑吧,兄弟?。L犢子)                        <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" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">大彬哥,你說你咋這么優秀呢?看見你我有一種大海的感覺                        <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" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">不是,我暈船,看見你想吐……                        <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">按下 說話</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>

這里實現的錄影功能要注意的點很多,我們一個個說,

第一個東西,

 

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 {            }

 

當大家看一些html5關于錄音的接口的時候,你看到這個

Navigator.getUserMedia()

就要小心了,這個是老規范的東西了,被廢了,新的是

navigator.mediaDevices.getUserMedia

html5 多媒體里面的語音這塊換了好幾茬規范,很亂,有些標簽甚至一個瀏覽器都沒實現過,未曾綻放就枯萎了,你也不用關心也沒必要浪費那個時間知道,你只要知道我說這些就夠了,因為你知道那些被廢掉的過往沒啥用,有那個時間還不如來一局LOL或者王者榮耀(雖然我并不懂二者的區別,不過這兩個游戲應該都挺好玩吧,沒玩過不懂)。

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

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

mediaRecorder = new MediaRecorder(stream);

接下來就是,一按按鈕就生米煮成熟飯了,對應錄音機就是錄完了按按鈕就播放了,但是在我們程序里面要想播放你不僅要有磁帶,還得有錄音機,錄音機就是audio標簽,沒有好辦,我們new一個。這個世界上沒有什么對象是程序員不敢new的,new一個不行,就new兩個。剩下的代碼除了嚇人之外,沒啥缺點,簡單的令人發指。

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" alt="">                    </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);                };

 

其實就是錄好了就播。

OK,是不是很簡單 ,整個項目我說幾個點吧:

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

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

3.新的 知識和技術其實并不復雜,其實很簡單,你想如果新技術不是為了讓功能更好實現,更能解決我們的問題,那開發新技術干嘛?因為那幫大胡子的大牛們沒事干怕被領導說工作量不飽和?技術是為了解決問題和讓我們生活更美好服務的。

4.這個項目IOS 11以下跑不通,因為IOS 11.2之前不支持這個方法,需要IOS本地應用開發人員給你提供支援,但是在android下面是很OK的。而且可以預見,再過幾年IOS 原生也不用給你支援都支持了,那你開發效率得多高。不要以為這些技術很遙遠,html5真正商用也不過15年左右(vue 、react、angular大規模使用才幾年?),機會留給有準備的人。

整個項目細節和要注意的點還是很多的,希望大家真正自己敲一遍,因為你看懂了我的文章跟你會用這個技術兩碼事,祝大家在前端的路上越走越遠(記得?;貋砜纯碸_^)。

總結

以上所述是小編給大家介紹的使用Html5多媒體實現微信語音功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
性欧美暴力猛交69hd| 国外色69视频在线观看| 国产精品视频在线播放| 欧美富婆性猛交| 欧美在线观看网站| 一区二区在线免费视频| 亚洲香蕉av在线一区二区三区| 亚洲欧美日韩成人| 日韩av在线免费| 成人精品在线观看| 欧美精品精品精品精品免费| 国产亚洲成精品久久| 久久成人在线视频| 在线播放国产一区二区三区| 亚洲欧美制服另类日韩| 国产日韩中文在线| 欧美激情视频在线免费观看 欧美视频免费一| 国产精品吴梦梦| 国产精品盗摄久久久| 欧美最猛性xxxxx(亚洲精品)| 精品国产拍在线观看| 国产精品久久久久久久久久久久久久| 亚洲欧美国产制服动漫| 久久久久久亚洲精品中文字幕| 亚洲第一区在线观看| 国产日韩欧美日韩大片| 色噜噜狠狠色综合网图区| 亚洲欧洲国产一区| 亚洲片av在线| 成人在线精品视频| 日韩高清不卡av| 欧美精品电影免费在线观看| 91九色单男在线观看| 国产一区二区三区视频免费| 亚洲视频电影图片偷拍一区| 亚洲欧美日韩国产精品| 日韩精品视频在线| 国产精品99久久久久久白浆小说| 九九热这里只有精品6| 成人网页在线免费观看| 欧美成aaa人片免费看| 精品日本美女福利在线观看| 国产经典一区二区| 2019中文字幕免费视频| 亚洲精品一二区| 久久中文字幕在线视频| 日韩精品中文字幕有码专区| 97国产一区二区精品久久呦| 亚洲精品v天堂中文字幕| 国产999精品| 日韩中文字幕在线播放| 中文字幕9999| 国产精品观看在线亚洲人成网| 在线免费观看羞羞视频一区二区| 亚洲美女精品久久| 欧美亚洲视频一区二区| www国产精品com| 久久视频在线直播| 国产精品久久精品| 激情懂色av一区av二区av| 欧美大片网站在线观看| 亚洲国产精品成人精品| 欧美综合国产精品久久丁香| 国产精品老女人视频| 国产精品一区二区3区| 中文字幕成人在线| 日本高清视频精品| 欧美老少做受xxxx高潮| 中国日韩欧美久久久久久久久| 91精品国产91久久久久久吃药| 国产精品麻豆va在线播放| 91视频国产精品| 国产精品av免费在线观看| 久久这里只有精品视频首页| 亚洲欧美日韩中文在线| 欧美成人在线影院| 国产精品96久久久久久又黄又硬| 最近2019年中文视频免费在线观看| 91av视频在线| 亚洲男人av在线| 亚洲电影免费观看高清完整版| 亚洲丁香婷深爱综合| 亚洲影视中文字幕| 亚洲电影成人av99爱色| 久久精品国产一区| 色噜噜亚洲精品中文字幕| 国产成人avxxxxx在线看| 国产欧美日韩最新| 亚洲精品美女网站| 亚洲成人久久久| 亚洲色图13p| 亚洲福利视频网| 日本精品久久久久影院| 国产精品网站入口| 国内精品一区二区三区四区| 国产综合久久久久| 17婷婷久久www| 国产精品第10页| 久久久久女教师免费一区| 日韩av大片免费看| 国产精品久久久av久久久| 国产女精品视频网站免费| 久久青草福利网站| 日本成人激情视频| 日韩av大片免费看| 亚洲桃花岛网站| 国产日韩在线视频| 亚洲四色影视在线观看| 亚洲欧美中文日韩v在线观看| 爽爽爽爽爽爽爽成人免费观看| 国语自产在线不卡| 亚洲美女免费精品视频在线观看| 国产精品极品尤物在线观看| 国产精品亚洲网站| 91av在线影院| 欧美理论电影在线观看| 亚洲成在人线av| 国产日本欧美一区二区三区在线| 中文字幕欧美专区| 国产精品久久av| 97在线视频免费播放| 日韩电影中文字幕在线观看| 久久天天躁狠狠躁夜夜爽蜜月| 97在线观看视频国产| 国产精品爽爽爽| 97免费在线视频| 欧美在线免费看| 日韩欧美一区二区三区| 久久久之久亚州精品露出| 日韩在线免费av| 日本精品视频在线观看| 久久99精品视频一区97| 精品国产老师黑色丝袜高跟鞋| 亚洲国产小视频| 九九九热精品免费视频观看网站| 欧美精品videos另类日本| 韩国欧美亚洲国产| 国产精品狼人色视频一区| www.久久久久| 91久久中文字幕| 午夜精品久久久久久99热软件| 亚洲男人天堂2023| 亚洲天堂开心观看| 日韩一级黄色av| 亚洲亚裔videos黑人hd| 97视频人免费观看| 97人人爽人人喊人人模波多| 狠狠躁夜夜躁人人躁婷婷91| 久久久久久久999精品视频| 欧洲一区二区视频| 成人午夜在线视频一区| 欧美精品18videosex性欧美| 中文字幕综合一区| 91久久久久久久一区二区| 亚洲最大在线视频| 狠狠色噜噜狠狠狠狠97| 久久久国产影院| 国模精品系列视频| 亚洲精品一二区| 欧洲成人在线视频| 国内精品400部情侣激情| 91伊人影院在线播放| 96pao国产成视频永久免费| 国产精品第七十二页|