12

我想访问 中的一些记录变量chrome://webrtc-internals/,但我在谷歌上没有找到任何东西——甚至没有我能看到的图表的描述。
我对packetsLost和尤其googCurrentDelayMs感兴趣googNacksSent

为什么我要访问 webrtc-internals
我正在编写一个共享视频流 (p2p)的谷歌浏览器应用程序。它使用peerjs与其他对等方共享流,而其他对等方又使用谷歌的webrtc实现。为了使我的应用程序完美,我需要知道何时发生大延迟。由于我可以看到登录延迟,chrome://webrtc-internals/我想知道是否可以通过 javascript 访问它。

我的猜测是chrome://webrtc-internals/-menu 没有 API。

4

2 回答 2

21

我找到了它 - 不得不爬过几个谷歌社区线程(线程 1线程2 ):

var peerjs = new Peer(...);  // initialize peerJS
var connections = peerjs.connections;

Connections 是一个对象:

Object {2e1c5694-e6ef-e1b2-22d5-84a3807961d4: Array[3]}
    2e1c5694-e6ef-e1b2-22d5-84a3807961d4: Array[3]
        0: DataConnection
        1: MediaConnection
        2: MediaConnection
        length: 3
    __proto__: Array[0]
__proto__: Object

看看这些连接对象中的任何一个:

var rtcPeerConn = connectionObject.pc; // RTCPeerConnection

rtcPeerConn.getStats(function callback(connStats){
    var rtcStatsReports = connStats.result() // array of available status-reports
    // each status-report object has many status variables, such as
    // googCurrentDelayMs. You need to iterate over all object and check 
    // their names to find the one status report you want
    rtcStatsReports[7].names() // returns all available variables for that report

    var googCurrentDelayMs = rtcStatsReports[7].stat('googCurrentDelayMs')
    console.log(googCurrentDelayMs) // finally - googCurrentDelayMs :-)
})
于 2014-06-05T21:18:43.630 回答
2

经过大量研究,这就是我设法使用 twilio SDK 获得 pc 的方式。

var rtcPeerConn =Twilio.Device.activeConnection();
rtcPeerConn.options.mediaStreamFactory.protocol.pc.getStats(function callback(report) {
                var rtcStatsReports = report.result();
                for (var i=0; i<rtcStatsReports.length; i++) {
                    var statNames = rtcStatsReports[i].names();
                    // filter the ICE stats
                    if (statNames.indexOf("transportId") > -1) {
                        var logs = "";
                        for (var j=0; j<statNames.length; j++) {
                            var statName = statNames[j];
                            var statValue = rtcStatsReports[i].stat(statName);
                            logs = logs + statName + ": " + statValue + ", ";
                        }
                        console.log(logs);
                    }
                }
            });

//计算errorRate Packetlost / packetent

var rtcPeerConn =Twilio.Device.activeConnection();
rtcPeerConn.options.mediaStreamFactory.protocol.pc.getStats(function callback(report) {
                var error, pcksent;
                var rtcStatsReports = report.result();
                for (var i=0; i<rtcStatsReports.length; i++) {
                    var statNames = rtcStatsReports[i].names();
                    // filter the ICE stats
                    if (statNames.indexOf("packetsSent") > -1) {
                        var logs = "";
                        for (var j=0; j<statNames.length; j++) {
                            var statName = statNames[j];
                            var statValue = rtcStatsReports[i].stat(statName);
                            if(statName=="packetsLost")
                              error= statValue;
                            if(statName =="packetsSent")
                              pcksent = statValue;
                            logs = logs +"n:" +statName + ": " + statValue + ", ";
                        }
                        console.log(error/pcksent);
                    }
                }

            });
于 2016-05-10T20:17:27.313 回答