Merge pull request #1112 from ZLMediaKit/feature/update_rtcsdkdemo

update zlm rtc sdk demo
This commit is contained in:
夏楚 2021-09-17 14:08:00 +08:00 committed by GitHub
commit 03aa9290ab
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 59 additions and 36 deletions

View File

@ -4,14 +4,14 @@ var ZLMRTCClient = (function (exports) {
const Events$1 = { const Events$1 = {
WEBRTC_NOT_SUPPORT: 'WEBRTC_NOT_SUPPORT', WEBRTC_NOT_SUPPORT: 'WEBRTC_NOT_SUPPORT',
WEBRTC_ICE_CANDIDATE_ERROR: 'WEBRTC_ICE_CANDIDATE_ERROR', WEBRTC_ICE_CANDIDATE_ERROR: 'WEBRTC_ICE_CANDIDATE_ERROR',
WEBRTC_OFFER_ANSWER_EXCHANGE_FAILED: 'WEBRTC_OFFER_ANSWER_EXCHANGE_FAILED', WEBRTC_OFFER_ANWSER_EXCHANGE_FAILED: 'WEBRTC_OFFER_ANWSER_EXCHANGE_FAILED',
WEBRTC_ON_REMOTE_STREAMS: 'WEBRTC_ON_REMOTE_STREAMS', WEBRTC_ON_REMOTE_STREAMS: 'WEBRTC_ON_REMOTE_STREAMS',
WEBRTC_ON_LOCAL_STREAM: 'WEBRTC_ON_LOCAL_STREAM', WEBRTC_ON_LOCAL_STREAM: 'WEBRTC_ON_LOCAL_STREAM',
CAPTURE_STREAM_FAILED: 'CAPTURE_STREAM_FAILED' CAPTURE_STREAM_FAILED: 'CAPTURE_STREAM_FAILED'
}; };
const VERSION = '1.0.1'; const VERSION = '1.0.1';
const BUILD_DATE = 'Mon Jun 07 2021 18:09:53 GMT+0800 (China Standard Time)'; const BUILD_DATE = 'Fri Sep 17 2021 10:41:58 GMT+0800 (China Standard Time)';
// Copyright (C) <2018> Intel Corporation // Copyright (C) <2018> Intel Corporation
// //
@ -7342,16 +7342,16 @@ var ZLMRTCClient = (function (exports) {
let ret = response.data; //JSON.parse(response.data); let ret = response.data; //JSON.parse(response.data);
if (ret.code != 0) { if (ret.code != 0) {
// mean failed for offer/answer exchange // mean failed for offer/anwser exchange
this.dispatch(Events$1.WEBRTC_OFFER_ANSWER_EXCHANGE_FAILED, ret); this.dispatch(Events$1.WEBRTC_OFFER_ANWSER_EXCHANGE_FAILED, ret);
return; return;
} }
let answer = {}; let anwser = {};
answer.sdp = ret.sdp; anwser.sdp = ret.sdp;
answer.type = 'answer'; anwser.type = 'answer';
log(this.TAG, 'answer:', ret.sdp); log(this.TAG, 'answer:', ret.sdp);
this.pc.setRemoteDescription(answer).then(() => { this.pc.setRemoteDescription(anwser).then(() => {
log(this.TAG, 'set remote sucess'); log(this.TAG, 'set remote sucess');
}).catch(e => { }).catch(e => {
error(this.TAG, e); error(this.TAG, e);
@ -7399,11 +7399,21 @@ var ZLMRTCClient = (function (exports) {
}; };
if (this.options.simulcast && stream.getVideoTracks().length > 0) { if (this.options.simulcast && stream.getVideoTracks().length > 0) {
VideoTransceiverInit.sendEncodings = [ VideoTransceiverInit.sendEncodings = [{
{ rid: "h", active: true, maxBitrate: 1000000 }, rid: 'h',
{ rid: "m", active: true, maxBitrate: 500000, scaleResolutionDownBy: 2 }, active: true,
{ rid: "l", active: true, maxBitrate: 200000, scaleResolutionDownBy: 4 } maxBitrate: 1000000
]; }, {
rid: 'm',
active: true,
maxBitrate: 500000,
scaleResolutionDownBy: 2
}, {
rid: 'l',
active: true,
maxBitrate: 200000,
scaleResolutionDownBy: 4
}];
} }
if (stream.getAudioTracks().length > 0) { if (stream.getAudioTracks().length > 0) {
@ -7442,16 +7452,16 @@ var ZLMRTCClient = (function (exports) {
let ret = response.data; //JSON.parse(response.data); let ret = response.data; //JSON.parse(response.data);
if (ret.code != 0) { if (ret.code != 0) {
// mean failed for offer/answer exchange // mean failed for offer/anwser exchange
this.dispatch(Events$1.WEBRTC_OFFER_ANSWER_EXCHANGE_FAILED, ret); this.dispatch(Events$1.WEBRTC_OFFER_ANWSER_EXCHANGE_FAILED, ret);
return; return;
} }
let answer = {}; let anwser = {};
answer.sdp = ret.sdp; anwser.sdp = ret.sdp;
answer.type = 'answer'; anwser.type = 'answer';
log(this.TAG, 'answer:', ret.sdp); log(this.TAG, 'answer:', ret.sdp);
this.pc.setRemoteDescription(answer).then(() => { this.pc.setRemoteDescription(anwser).then(() => {
log(this.TAG, 'set remote sucess'); log(this.TAG, 'set remote sucess');
}).catch(e => { }).catch(e => {
error(this.TAG, e); error(this.TAG, e);

File diff suppressed because one or more lines are too long

View File

@ -22,12 +22,12 @@
<p> <p>
<label for="streamUrl">url:</label> <label for="streamUrl">url:</label>
<input type="text" style="co" id='streamUrl' value="http://127.0.0.1/index/api/webrtc?app=live&stream=test&type=play"> <input type="text" style="co" id='streamUrl' value="http://192.168.1.101/index/api/webrtc?app=live&stream=xiong&type=play">
</p> </p>
<p> <p>
<label for="simulcast">simulcast:</label> <label for="simulcast">simulcast:</label>
<input type="checkbox" id='simulcast' checked="checked"> <input type="checkbox" id='simulcast'>
</p> </p>
<p> <p>
<label for="useCamera">useCamera:</label> <label for="useCamera">useCamera:</label>
@ -46,14 +46,14 @@
</p> </p>
<p> <p>
<label for="method">method(play or push):</label> <label for="methond">methond(play or push):</label>
<input type="radio" name="method" value="push" >push <input type="radio" name="methond" value="push" >push
<input type="radio" name="method" value="play" checked = true>play <input type="radio" name="methond" value="play" checked = true>play
</p> </p>
<p> <p>
<label for="resolution">resolution:</label> <label for="resilution">resolution:</label>
<select id="resolution"> <select id="resilution">
</select> </select>
</p> </p>
@ -69,7 +69,20 @@
var recvOnly = true var recvOnly = true
var resArr = [] var resArr = []
document.getElementsByName("method").forEach((el,idx)=>{ var ishttps = 'https:' == document.location.protocol ? true : false
var isLocal = "file:" == document.location.protocol ? true : false
var url = document.location.protocol+"//"+window.location.host+"/index/api/webrtc?app=live&stream=test&type=play"
if(!ishttps && !isLocal){
alert('本demo需要在https的网站访问 (this demo must access in site of https)')
}
if(isLocal){
url = "http://127.0.0.1"+"/index/api/webrtc?app=live&stream=test&type=play"
}
document.getElementById('streamUrl').value = url
document.getElementsByName("methond").forEach((el,idx)=>{
el.onclick=function(e){ el.onclick=function(e){
if(el.value == "play") if(el.value == "play")
{ {
@ -91,14 +104,14 @@
opt = document.createElement('option'); opt = document.createElement('option');
opt.text = r.label +"("+r.width+"x"+r.height+")"; opt.text = r.label +"("+r.width+"x"+r.height+")";
opt.value = r; opt.value = r;
document.getElementById("resolution").add(opt,null) document.getElementById("resilution").add(opt,null)
//console.log(opt.text.match(/\d+/g)) //console.log(opt.text.match(/\d+/g))
}) })
function start_play(){ function start_play(){
let elr = document.getElementById("resolution"); let elr = document.getElementById("resilution");
let res = elr.options[elr.selectedIndex].text.match(/\d+/g); let res = elr.options[elr.selectedIndex].text.match(/\d+/g);
let h = parseInt(res.pop()); let h = parseInt(res.pop());
let w = parseInt(res.pop()); let w = parseInt(res.pop());
@ -127,9 +140,9 @@
console.log('播放成功',e.streams) console.log('播放成功',e.streams)
}); });
player.on(ZLMRTCClient.Events.WEBRTC_OFFER_ANSWER_EXCHANGE_FAILED,function(e) player.on(ZLMRTCClient.Events.WEBRTC_OFFER_ANWSER_EXCHANGE_FAILED,function(e)
{// offer answer 交换失败 {// offer anwser 交换失败
console.log('offer answer 交换失败',e) console.log('offer anwser 交换失败',e)
stop(); stop();
}); });
@ -139,7 +152,7 @@
document.getElementById('selfVideo').srcObject=s; document.getElementById('selfVideo').srcObject=s;
document.getElementById('selfVideo').muted = true; document.getElementById('selfVideo').muted = true;
//console.log('offer answer 交换失败',e) //console.log('offer anwser 交换失败',e)
}); });
player.on(ZLMRTCClient.Events.CAPTURE_STREAM_FAILED,function(s) player.on(ZLMRTCClient.Events.CAPTURE_STREAM_FAILED,function(s)
@ -152,7 +165,7 @@
function start() function start()
{ {
stop(); stop();
let elr = document.getElementById("resolution"); let elr = document.getElementById("resilution");
let res = elr.options[elr.selectedIndex].text.match(/\d+/g); let res = elr.options[elr.selectedIndex].text.match(/\d+/g);
let h = parseInt(res.pop()); let h = parseInt(res.pop());
let w = parseInt(res.pop()); let w = parseInt(res.pop());
@ -176,7 +189,7 @@
player.close(); player.close();
player = null; player = null;
var local = document.getElementById('selfVideo'); var local = document.getElementById('selfVideo');
local.removeAttribute('srcObject'); local.srcObject = null;
local.load(); local.load();
} }
} }