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

首頁 > 開發 > HTML5 > 正文

HTML5中的websocket實現直播功能

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

做視頻直播這一塊,前期研究了很多方案,包括websocket,因為各種原因最后沒有采取這個方案,但還是想記錄一下學習的心得。

WebSocket是HTML5開始提供的一種在單個 TCP 連接上進行全雙工通訊的協議。

在WebSocket API中,瀏覽器和服務器只需要做一個握手的動作,然后,瀏覽器和服務器之間就形成了一條快速通道。兩者之間就直接可以數據互相傳送。

瀏覽器通過 JavaScript 向服務器發出建立 WebSocket 連接的請求,連接建立以后,客戶端和服務器端就可以通過 TCP 連接直接交換數據。

當你獲取 Web Socket 連接后,你可以通過send()方法來向服務器發送數據,并通過onmessage事件來接收服務器返回的數據。

做的過程中,主要的思維是:在錄像頁面利用setTimeout()每隔固定的時間通過canvas將視頻轉化為一幀一幀的圖像,然后用websocket的socket.send()將圖片數據發送給服務器。在直播頁面就是先創建一個<img>的結構,通過websocket的socket.onmessage()獲取到圖像數據,并展示<img>標簽上,形成直播。

附上代碼

錄像頁面HTML結構

<video autoplay id="sourcevid" style="width:1600;height:900px"></video>      <canvas id="output" style="display:none"></canvas>  

錄像頁面js

<script type="text/javascript" charset="utf-8">          //創建一個+實例          var socket = new WebSocket("ws://"+document.domain+":8080");          var back = document.getElementById('output');          //返回一個用于在畫布上繪圖的環境。          var backcontext = back.getContext('2d');          var video = document.getElementsByTagName('video')[0];          var success = function(stream){              //獲取視屏流,轉換為url              video.src = window.URL.createObjectURL(stream);          }          //打開socket          socket.onopen = function(){              draw();              console.log("open success")          }          // 將視頻幀繪制到Canvas對象上,Canvas每100ms切換幀,形成肉眼視頻效果            var draw = function(){              try{                  backcontext.drawImage(video,0,0, back.width, back.height);              }catch(e){                  if (e.name == "NS_ERROR_NOT_AVAILABLE") {                      return setTimeout(draw, 100);                  } else {                      throw e;                  }              }              if(video.src){                  // Canvas的內容轉化成PNG data URI并發送到服務器,0.5為和壓縮系數                  socket.send(back.toDataURL("image/jpeg", 0.5));              }              setTimeout(draw, 100);          }          //調用設備的攝像頭,并將資源放入video標簽          navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia ||          navigator.mozGetUserMedia || navigator.msGetUserMedia;          navigator.getUserMedia({video:true, audio:false}, success, console.log);      </script>  

直播頁面HTML結構:

<img id="receiver" style="width:1600px;height:900px"/>  

直播頁面JS

<script type="text/javascript" charset="utf-8">          //創建一個socket實例          var receiver_socket = new WebSocket("ws://"+document.domain+":8008");          alert("ws://"+document.domain+":8008")          var image = document.getElementById('receiver');           // 監聽消息          receiver_socket.onmessage = function(data)          {              image.src=data.data;          }      </script>  

總結

以上所述是小編給大家介紹的HTML5中的websocket實現直播功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品视频在线免费观看| 久久久久久久国产精品| 欧美高清在线视频观看不卡| 免费97视频在线精品国自产拍| 一区二区三区天堂av| 亚洲人午夜色婷婷| 欧美另类99xxxxx| 中文字幕精品国产| 欧美性资源免费| 久久久久国产精品免费| 亚洲毛片在线观看.| 韩国三级日本三级少妇99| 中文字幕久久久av一区| 国产97人人超碰caoprom| 日韩成人激情在线| 98午夜经典影视| 久久精品99国产精品酒店日本| 日韩高清有码在线| 国产一区av在线| 日韩经典第一页| 亚洲加勒比久久88色综合| 日韩在线观看免费高清完整版| 欧美午夜www高清视频| 久久久久久国产精品三级玉女聊斋| 日韩成人在线播放| 色妞久久福利网| 国产欧美精品日韩精品| 夜夜嗨av色综合久久久综合网| 中文字幕精品在线| 91高清免费在线观看| 福利微拍一区二区| 久久久久久有精品国产| 国产99久久精品一区二区| 欧美自拍视频在线| 欧美性69xxxx肥| 久色乳综合思思在线视频| 欧美日韩精品在线| 在线精品国产成人综合| 欧美视频在线视频| 国产日韩精品在线观看| 欧美日韩午夜剧场| 成人a级免费视频| 色先锋资源久久综合5566| 亚洲一品av免费观看| 欧美性猛交xxxx黑人猛交| 欧美另类第一页| 国内精品国产三级国产在线专| 国产国语刺激对白av不卡| 欧美精品videofree1080p| 中文字幕av一区二区三区谷原希美| 日韩亚洲精品电影| 欧美日韩亚洲高清| 亚洲精品久久久久久久久久久| 亚洲精品视频久久| 亚洲精品久久久久中文字幕欢迎你| 91美女片黄在线观| 亚洲国产精品系列| 国产成人综合精品在线| 91久久精品国产91久久| 国产精品一区久久久| 欧美日韩国产色| 亚州av一区二区| 亚洲美女av在线播放| 成人h猎奇视频网站| 91日韩在线视频| 成人欧美在线视频| 4438全国亚洲精品在线观看视频| 精品国产电影一区| 亚洲国产精彩中文乱码av在线播放| 欧美乱大交xxxxx另类电影| 亚洲成人中文字幕| 国产精品综合久久久| 国产成人精品一区| 成人深夜直播免费观看| 日韩一区二区在线视频| 91av在线免费观看| 日韩av影片在线观看| 亚洲精品国产精品国自产在线| 亚洲精品网址在线观看| 久久视频这里只有精品| 久久精品在线视频| 日韩精品亚洲元码| 91av视频在线免费观看| 亚洲一区第一页| 久久香蕉国产线看观看av| 久久久久这里只有精品| 色偷偷噜噜噜亚洲男人的天堂| x99av成人免费| 日韩国产高清视频在线| 国产91在线播放九色快色| 久久精品最新地址| 热久久99这里有精品| 国产在线观看一区二区三区| 欧美一区二粉嫩精品国产一线天| 久久九九全国免费精品观看| 成人网址在线观看| 色综合五月天导航| x99av成人免费| 久久亚洲精品一区二区| 欧美黑人性生活视频| 亚洲成人黄色网址| 欧美性生交大片免网| 久久婷婷国产麻豆91天堂| 中文国产成人精品| 一区二区三区国产在线观看| 亚洲精品www久久久久久广东| 国产视频久久久| 国产噜噜噜噜久久久久久久久| 日本sm极度另类视频| 日韩av手机在线看| 亚洲国产欧美一区二区三区同亚洲| 亚洲天堂免费观看| 国产69精品久久久久久| 久久精品国产一区二区电影| 久久天天躁日日躁| 欧美黑人国产人伦爽爽爽| 亚洲 日韩 国产第一| 黑人巨大精品欧美一区免费视频| 亚洲最大av网站| 亚洲一区精品电影| 国内精品久久久久久久久| 日本欧美一二三区| 欧美激情啊啊啊| 亚洲第一免费网站| 亚洲香蕉成人av网站在线观看| 久久久久久国产精品久久| 国产精品爱啪在线线免费观看| 日韩免费中文字幕| 久久精品视频网站| 高清一区二区三区四区五区| 欧美日韩成人在线观看| 亚洲国产天堂网精品网站| 国产一区二区黄| 欧美专区中文字幕| 国产精品视频一区国模私拍| 精品国产一区二区三区久久狼5月| 51色欧美片视频在线观看| 欧美肥老太性生活视频| 91精品视频在线播放| 一区国产精品视频| 亚洲曰本av电影| 久久精品欧美视频| 久久久精品久久久| 亚洲第一区中文99精品| 国产精品成熟老女人| 日韩av最新在线| 亚洲最大福利视频网站| 欧美影院成年免费版| 91精品国产色综合| 中文字幕九色91在线| 国产精品99久久久久久久久| 国产伊人精品在线| 亚洲黄色在线观看| 91久久国产综合久久91精品网站| 亚洲欧美国产一区二区三区| 久久久久北条麻妃免费看| 伊人久久精品视频| 4444欧美成人kkkk| 亚洲成**性毛茸茸| 国产精品色婷婷视频| 久久久久久久久久婷婷| 日韩精品在线视频| 欧美黑人一区二区三区| 久久婷婷国产麻豆91天堂|