婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 使用Html5多媒體實現微信語音功能

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

熱門標簽:如何查看地圖標注 地圖標注軟件打印出來 電話機器人技術 ok電銷機器人 惡搞電話機器人 黃石ai電銷機器人呼叫中心 高德地圖標注商戶怎么標 智能電銷機器人被禁用了么 欣鼎電銷機器人 效果

隨著微信等社交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">奔跑吧,兄弟!(滾犢子)
                        <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多媒體實現微信語音功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

標簽:盤錦 赤峰 阿壩 金昌 萍鄉 綏化 聊城 中山

巨人網絡通訊聲明:本文標題《使用Html5多媒體實現微信語音功能》,本文關鍵詞  使用,Html5,多媒體,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用Html5多媒體實現微信語音功能》相關的同類信息!
  • 本頁收集關于使用Html5多媒體實現微信語音功能的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    正在播放一区二区| 欧美羞羞免费网站| 亚洲不卡在线观看| 亚洲h动漫在线| 91免费视频观看| 色婷婷综合激情| 亚洲视频在线一区| 成人在线一区二区三区| 欧美性受xxxx| 精品久久久久一区| 国产美女视频一区| 精品国产亚洲一区二区三区在线观看 | 国产精品1区2区3区在线观看| 欧美羞羞免费网站| 午夜成人在线视频| 欧美乱妇20p| 成人午夜精品一区二区三区| ...xxx性欧美| 7777精品伊人久久久大香线蕉最新版| 亚洲18影院在线观看| 欧美日韩亚洲综合| 国产不卡一区视频| 亚洲色欲色欲www| 欧美视频中文字幕| 精品无人码麻豆乱码1区2区| 国产清纯在线一区二区www| 91国偷自产一区二区使用方法| 久久精品国产成人一区二区三区| 久久精品人人爽人人爽| 欧美一级黄色录像| 色一情一伦一子一伦一区| 欧美aaaaa成人免费观看视频| 国产精品久久久久三级| 久久影院视频免费| 精品国内二区三区| 欧美一区二区不卡视频| 欧美日韩国产一级片| 国产精品一区二区在线观看不卡| 午夜伊人狠狠久久| 一区二区三区在线观看视频| 久久久综合网站| 欧美成人艳星乳罩| 欧美乱妇23p| aaa亚洲精品一二三区| 国产成人一级电影| 大美女一区二区三区| 国产精品影视在线| 国产精品一品二品| av激情亚洲男人天堂| 91影视在线播放| 91黄色在线观看| 色88888久久久久久影院野外| 欧美亚日韩国产aⅴ精品中极品| 91麻豆精品国产91久久久更新时间 | 99久久777色| 欧美综合一区二区| 精品成人佐山爱一区二区| 国产欧美日韩久久| 午夜精品一区二区三区电影天堂| 久久精品国产网站| 色欧美乱欧美15图片| 久久久久国产成人精品亚洲午夜| 亚洲精品福利视频网站| 国产一区二区在线视频| 91在线视频网址| 国产精品天美传媒| 青青草国产精品97视觉盛宴| 成人综合婷婷国产精品久久蜜臀 | 久久99精品国产.久久久久久| 成人在线一区二区三区| 日韩欧美视频在线| 亚洲成精国产精品女| gogogo免费视频观看亚洲一| 久久综合色综合88| 国产一区二区三区综合| 日韩一级大片在线观看| 亚洲精品国产a久久久久久| 96av麻豆蜜桃一区二区| 日韩理论在线观看| 欧美在线免费播放| 亚洲国产视频在线| 欧美一级日韩一级| 亚洲制服丝袜av| 3d成人动漫网站| 日韩黄色免费电影| 欧美日韩免费一区二区三区视频| 一区二区成人在线| 99久久精品国产毛片| 欧美国产欧美综合| 国产福利精品导航| 亚洲综合激情另类小说区| 97久久精品人人做人人爽50路 | 色诱亚洲精品久久久久久| 国产精品美女久久久久久2018 | caoporm超碰国产精品| 国产日韩高清在线| 97久久超碰精品国产| 亚洲一区在线看| 国产精品午夜春色av| 国产成人免费在线观看不卡| 中文字幕视频一区二区三区久| 欧美日韩一区二区在线观看视频| 奇米亚洲午夜久久精品| 亚洲毛片av在线| 精品入口麻豆88视频| 在线观看91视频| 国产在线视视频有精品| 亚洲国产精品成人久久综合一区| 欧美中文字幕一区二区三区亚洲| 国产传媒一区在线| 首页国产欧美久久| 亚洲欧美另类在线| 国产精品―色哟哟| 久久久久久久久久久99999| 欧美在线观看18| 99久久国产免费看| 91女厕偷拍女厕偷拍高清| www.亚洲色图| 成人黄色免费短视频| 91美女福利视频| 日本高清免费不卡视频| 欧美色男人天堂| 99精品国产视频| 不卡影院免费观看| 91精品福利在线| 日韩欧美国产三级电影视频| 91精品国产一区二区三区香蕉| 欧美精三区欧美精三区| 精品日韩在线一区| 亚洲欧美一区二区三区国产精品| 亚洲精品久久久蜜桃| 日韩成人精品在线| 97精品久久久午夜一区二区三区| 在线视频欧美区| 国产亚洲精品aa| 午夜视频一区在线观看| 成人午夜私人影院| 7777精品伊人久久久大香线蕉完整版| 欧美一区二区高清| 午夜欧美在线一二页| av高清不卡在线| 2020国产精品久久精品美国| 奇米影视一区二区三区| 91论坛在线播放| 日韩美女啊v在线免费观看| 久久99精品一区二区三区三区| 欧美性感一类影片在线播放| 国产亚洲欧美一级| 国产精品99久久久久久似苏梦涵| 在线综合亚洲欧美在线视频| 亚洲一区二区三区免费视频| 日本精品视频一区二区三区| 樱桃视频在线观看一区| 91精品1区2区| 捆绑调教美女网站视频一区| 欧美日韩精品一区二区三区四区 | 国产精品黄色在线观看| 麻豆成人av在线| 精品99一区二区| 91香蕉视频mp4| 亚洲一区二区三区爽爽爽爽爽| 欧美日韩五月天| 美脚の诱脚舐め脚责91| 久久久久久影视| 色综合中文字幕| 丝袜美腿亚洲综合| 久久久久久久免费视频了| 国产91丝袜在线播放0| 最近日韩中文字幕| 日韩免费高清视频| 在线免费不卡视频| 国产精品一区专区| 亚洲成人黄色小说| 国产精品理伦片| 日韩精品影音先锋| 成人avav影音| 久久福利视频一区二区| 亚洲v精品v日韩v欧美v专区| 欧美大片在线观看一区| 色www精品视频在线观看| 国产成人免费视频| 国产一区二区三区香蕉| 亚洲第一综合色| 亚洲综合精品久久| 亚洲摸摸操操av| 亚洲视频小说图片| 亚洲精品国产第一综合99久久 | 丁香桃色午夜亚洲一区二区三区| 亚洲激情成人在线| 日韩美女视频19| 亚洲日本青草视频在线怡红院| 欧美激情一区在线| 国产精品色噜噜| 亚洲天天做日日做天天谢日日欢 | 亚洲精品成人悠悠色影视| 久久久久久久久久美女| 国产精品家庭影院| 亚洲自拍欧美精品| 日韩国产精品久久久久久亚洲| 亚洲综合一区在线|