|
|
|
@ -68,53 +68,52 @@
|
|
|
|
|
</footer>
|
|
|
|
|
</div>
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
var pc = null; // Global handler to do cleanup when replaying.
|
|
|
|
|
$(function(){
|
|
|
|
|
var sdk = null; // Global handler to do cleanup when republishing.
|
|
|
|
|
var startPublish = function() {
|
|
|
|
|
$('#rtc_media_player').show();
|
|
|
|
|
$(function(){
|
|
|
|
|
var sdk = null; // Global handler to do cleanup when republishing.
|
|
|
|
|
var startPublish = function() {
|
|
|
|
|
$('#rtc_media_player').show();
|
|
|
|
|
|
|
|
|
|
// Close PC when user replay.
|
|
|
|
|
if (sdk) {
|
|
|
|
|
sdk.close();
|
|
|
|
|
}
|
|
|
|
|
sdk = new SrsRtcPublisherAsync();
|
|
|
|
|
|
|
|
|
|
// User should set the stream when publish is done, @see https://webrtc.org/getting-started/media-devices
|
|
|
|
|
// However SRS SDK provides a consist API like https://webrtc.org/getting-started/remote-streams
|
|
|
|
|
$('#rtc_media_player').prop('srcObject', sdk.stream);
|
|
|
|
|
// Optional callback, SDK will add track to stream.
|
|
|
|
|
// sdk.ontrack = function (event) { console.log('Got track', event); sdk.stream.addTrack(event.track); };
|
|
|
|
|
// Close PC when user replay.
|
|
|
|
|
if (sdk) {
|
|
|
|
|
sdk.close();
|
|
|
|
|
}
|
|
|
|
|
sdk = new SrsRtcPublisherAsync();
|
|
|
|
|
|
|
|
|
|
// https://developer.mozilla.org/en-US/docs/Web/Media/Formats/WebRTC_codecs#getting_the_supported_codecs
|
|
|
|
|
sdk.pc.onicegatheringstatechange = function (event) {
|
|
|
|
|
if (sdk.pc.iceGatheringState === "complete") {
|
|
|
|
|
$('#acodecs').html(SrsRtcFormatSenders(sdk.pc.getSenders(), "audio"));
|
|
|
|
|
$('#vcodecs').html(SrsRtcFormatSenders(sdk.pc.getSenders(), "video"));
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
// User should set the stream when publish is done, @see https://webrtc.org/getting-started/media-devices
|
|
|
|
|
// However SRS SDK provides a consist API like https://webrtc.org/getting-started/remote-streams
|
|
|
|
|
$('#rtc_media_player').prop('srcObject', sdk.stream);
|
|
|
|
|
// Optional callback, SDK will add track to stream.
|
|
|
|
|
// sdk.ontrack = function (event) { console.log('Got track', event); sdk.stream.addTrack(event.track); };
|
|
|
|
|
|
|
|
|
|
// For example: webrtc://r.ossrs.net/live/livestream
|
|
|
|
|
var url = $("#txt_url").val();
|
|
|
|
|
sdk.publish(url).then(function(session){
|
|
|
|
|
$('#sessionid').html(session.sessionid);
|
|
|
|
|
$('#simulator-drop').attr('href', session.simulator + '?drop=1&username=' + session.sessionid);
|
|
|
|
|
}).catch(function (reason) {
|
|
|
|
|
sdk.close();
|
|
|
|
|
$('#rtc_media_player').hide();
|
|
|
|
|
console.error(reason);
|
|
|
|
|
});
|
|
|
|
|
// https://developer.mozilla.org/en-US/docs/Web/Media/Formats/WebRTC_codecs#getting_the_supported_codecs
|
|
|
|
|
sdk.pc.onicegatheringstatechange = function (event) {
|
|
|
|
|
if (sdk.pc.iceGatheringState === "complete") {
|
|
|
|
|
$('#acodecs').html(SrsRtcFormatSenders(sdk.pc.getSenders(), "audio"));
|
|
|
|
|
$('#vcodecs').html(SrsRtcFormatSenders(sdk.pc.getSenders(), "video"));
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$('#rtc_media_player').hide();
|
|
|
|
|
var query = parse_query_string();
|
|
|
|
|
srs_init_rtc("#txt_url", query);
|
|
|
|
|
// For example: webrtc://r.ossrs.net/live/livestream
|
|
|
|
|
var url = $("#txt_url").val();
|
|
|
|
|
sdk.publish(url).then(function(session){
|
|
|
|
|
$('#sessionid').html(session.sessionid);
|
|
|
|
|
$('#simulator-drop').attr('href', session.simulator + '?drop=1&username=' + session.sessionid);
|
|
|
|
|
}).catch(function (reason) {
|
|
|
|
|
sdk.close();
|
|
|
|
|
$('#rtc_media_player').hide();
|
|
|
|
|
console.error(reason);
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$("#btn_publish").click(startPublish);
|
|
|
|
|
if (query.autostart === 'true') {
|
|
|
|
|
startPublish();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
$('#rtc_media_player').hide();
|
|
|
|
|
var query = parse_query_string();
|
|
|
|
|
srs_init_rtc("#txt_url", query);
|
|
|
|
|
|
|
|
|
|
$("#btn_publish").click(startPublish);
|
|
|
|
|
if (query.autostart === 'true') {
|
|
|
|
|
startPublish();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
</body>
|
|
|
|
|
</html>
|
|
|
|
|