WebRTC getStat()API设置

Jer*_*Fox 7 statistics latency video-streaming webrtc

我正在尝试使用来自WebRTC的api的getStat()来查看它是否提供任何有用的信息度量延迟和其他视频流数据.问题是没有太多关于如何使用它的信息.即使是较旧的现有示例也非常罕见,但自那时起api发生了变化.

例如,我的设置:

peerconnection.getStats(function(stats) { 
                          console.log(stats); } ));
Run Code Online (Sandbox Code Playgroud)

这将返回具有2个函数的RTCStatsResponse对象

RTCStatsResponse {result: function, namedItem: function}
Run Code Online (Sandbox Code Playgroud)

尝试调用result()函数返回第一个对象的类型为"googLibjingleSession"的RTCStatsReport对象数组,并为第二个对象键入"googTrack".尝试调用时,其他nameItem函数未定义

[RTCStatsReport, RTCStatsReport]
Run Code Online (Sandbox Code Playgroud)

从可用的小信息(https://groups.google.com/forum/#!topic/discuss-webrtc/fpr4yn4-3sg),我将获得更多RTCStatObjects,其中包含比我目前更有用的信息.

有没有人有使用webrtc的getStats的经验?我相信我可能没有正确地做到这一点

fyc*_*cth 8

以下解决方案适合我.

创建对等连接

pc = new RTCPeerConnection(pc_config, pc_constraints);
Run Code Online (Sandbox Code Playgroud)

添加onaddstream处理程序

pc.onaddstream = onRemoteStreamAdded;
Run Code Online (Sandbox Code Playgroud)

处理程序本身

var onRemoteStreamAdded = function(event) {
        attachMediaStream(remoteVideo, event.stream);
        remoteStream = event.stream;

        getStats(pc);
    };
Run Code Online (Sandbox Code Playgroud)

注意从处理程序调用的getStats函数,该函数如下

function getStats(peer) {
    myGetStats(peer, function (results) {
        for (var i = 0; i < results.length; ++i) {
            var res = results[i];
            console.log(res);
        }

        setTimeout(function () {
            getStats(peer);
        }, 1000);
    });
}
Run Code Online (Sandbox Code Playgroud)

myGetStats函数是一个包装器,可以在不同的浏览器中实现通用;

function myGetStats(peer, callback) {
    if (!!navigator.mozGetUserMedia) {
        peer.getStats(
            function (res) {
                var items = [];
                res.forEach(function (result) {
                    items.push(result);
                });
                callback(items);
            },
            callback
        );
    } else {
        peer.getStats(function (res) {
            var items = [];
            res.result().forEach(function (result) {
                var item = {};
                result.names().forEach(function (name) {
                    item[name] = result.stat(name);
                });
                item.id = result.id;
                item.type = result.type;
                item.timestamp = result.timestamp;
                items.push(item);
            });
            callback(items);
        });
    }
};
Run Code Online (Sandbox Code Playgroud)

每秒它都会得到统计信息并将原始对象打印到控制台日志中.您可以解析日志,然后更改代码,获取必要的对象字段.

  • 谢谢你的未来.这些东西仍然没有在网上很好地记录 (3认同)