热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WebRTC对Simulcast的支持

最近在调研基于WebRTC的Simulcast的方案,发现WebRTC1.0的草案里面已经Simulcast的相关定义,并且举出了相关的例子。EXAMPLE15varsignalingChann

最近在调研基于WebRTC的Simulcast的方案,发现WebRTC 1.0的草案里面已经Simulcast的相关定义,并且举出了相关的例子。

EXAMPLE 15
var signalingChannel = new SignalingChannel();
var cOnfiguration= { "iceServers": [{ "urls": "stuns:stun.example.org" }] };
var pc;

// call start() to initiate
function start() {
pc = new RTCPeerConnection(configuration);

// let the "negotiationneeded" event trigger offer generation
pc.Onnegotiationneeded= function () {
pc.createOffer().then(function (offer) {
return pc.setLocalDescription(offer);
})
.then(function () {
// send the offer to the other peer
signalingChannel.send(JSON.stringify({ "desc": pc.localDescription }));
})
.catch(logError);
};

// get a local stream, show it in a self-view and add it to be sent
navigator.mediaDevices.getUserMedia({ "audio": true, "video": true })
.then(function (stream) {
selfView.srcObject = stream;
pc.addTransceiver(stream.getAudioTracks()[0], {direction: "sendonly"});
pc.addTransceiver(stream.getVideoTracks()[0], {
direction: "sendonly",
sendEncodings: [
{
rid: "f",
},
{
rid: "h",
scaleDownResolutionBy: 2.0
},
{
rid: "q",
scaleDownResolutionBy: 4.0
}
]
});
})
.catch(logError);
}

signalingChannel.Onmessage= function (evt) {
var message = JSON.parse(evt.data);
if (message.desc)
pc.setRemoteDescription(message.desc).catch(logError);
else
pc.addIceCandidate(message.candidate).catch(logError);
};

function logError(error) {
log(error.name + ": " + error.message);
}

既然标准里面已经有了Simulcast的相关接口,那么各个浏览器里面的WebRTC实现情况如何呢?通过一番搜索之后,发现目前能支持Simulcast的浏览器貌似只有Chrome和Firefox两款,而且只能使用VP8。

Chrome里面其实早就已经支持Simulcast,Google Hangouts里面就已经在使用。不过目前Chrome还不能使用WebRTC 1.0里面方法来启用,只能通过修改Local SDP的方式来开启,实现一个“SIM”的 ssrc group。SDP样式如下:

a=ssrc-group:SIM 2178216979 2295769805 636898760
a=ssrc-group:FID 2178216979 2643517961
a=ssrc-group:FID 2295769805 1534787773
a=ssrc-group:FID 636898760 1305495962
a=ssrc:2178216979 cname:localCname
a=ssrc:2178216979 msid:R6WoG3JzZEw8BVEBuy1XpTuUzzfSGIlr08Ro 541b12bc-754c-4c06-8367-481ec12e3192
a=ssrc:2295769805 cname:localCname
a=ssrc:2295769805 msid:R6WoG3JzZEw8BVEBuy1XpTuUzzfSGIlr08Ro 541b12bc-754c-4c06-8367-481ec12e3192
a=ssrc:636898760 cname:localCname
a=ssrc:636898760 msid:R6WoG3JzZEw8BVEBuy1XpTuUzzfSGIlr08Ro 541b12bc-754c-4c06-8367-481ec12e3192
a=ssrc:2643517961 cname:localCname
a=ssrc:2643517961 msid:R6WoG3JzZEw8BVEBuy1XpTuUzzfSGIlr08Ro 541b12bc-754c-4c06-8367-481ec12e3192
a=ssrc:1534787773 cname:localCname
a=ssrc:1534787773 msid:R6WoG3JzZEw8BVEBuy1XpTuUzzfSGIlr08Ro 541b12bc-754c-4c06-8367-481ec12e3192
a=ssrc:1305495962 cname:localCname
a=ssrc:1305495962 msid:R6WoG3JzZEw8BVEBuy1XpTuUzzfSGIlr08Ro 541b12bc-754c-4c06-8367-481ec12e3192

Firefox里面的实现看上去就是按照WebRTC 1.0定义的接口来实现的,与举例Example 15中类似。SDP样式如下:

a=simulcast: send rid=high;medium;low
a=ssrc:4279128183 cname:{7cc599d1-10d9-4d41-9e53-eb3e74ad54fa}
a=ssrc:1635836235 cname:{7cc599d1-10d9-4d41-9e53-eb3e74ad54fa}
a=ssrc:921425862 cname:{7cc599d1-10d9-4d41-9e53-eb3e74ad54fa}

看来目前要支持多浏览器的Simulcast的互通,WebRTC的服务器必须实现两种SDP的格式转换。Janus的Video Call Demo里面已经有了实现,可以参考:

https://janus.conf.meetecho.com/videocalltest.html?simulcast=true



推荐阅读
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文总结了在使用Ionic 5进行Android平台APK打包时遇到的问题,特别是针对QRScanner插件的改造。通过详细分析和提供具体的解决方法,帮助开发者顺利打包并优化应用性能。 ... [详细]
  • 本文探讨了如何在编程中正确处理包含空数组的 JSON 对象,提供了详细的代码示例和解决方案。 ... [详细]
author-avatar
手机用户2602900871
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有