From 8d922b7347f73d99560ecabc122eae0a15a7f37d Mon Sep 17 00:00:00 2001 From: Kazuki Matsumoto <1132081+karasusan@users.noreply.github.com> Date: Wed, 5 Oct 2022 10:01:30 +0900 Subject: [PATCH] fix: Call GetStats multi times at the same time in StatsUI (#783) * wip * fix * dispose explicitly --- .../Samples~/Example/Stats/ShowStatsUI.cs | 117 +++++++++++------- 1 file changed, 75 insertions(+), 42 deletions(-) diff --git a/com.unity.renderstreaming/Samples~/Example/Stats/ShowStatsUI.cs b/com.unity.renderstreaming/Samples~/Example/Stats/ShowStatsUI.cs index 1adadabf8..d7219993a 100644 --- a/com.unity.renderstreaming/Samples~/Example/Stats/ShowStatsUI.cs +++ b/com.unity.renderstreaming/Samples~/Example/Stats/ShowStatsUI.cs @@ -103,60 +103,93 @@ private IEnumerator CollectStats() } } + List coroutines = new List(); + foreach (var sender in activeSenderList.Values.SelectMany(x => x)) { - var op = sender.GetStats(); - yield return op; - if (op.IsError) - { - continue; - } - - var report = op.Value; - if (lastSenderStats.TryGetValue(sender, out var statsDisplay)) - { - statsDisplay.display.text = CreateDisplayString(report, statsDisplay.lastReport); - statsDisplay.lastReport = report; - } - else - { - var text = Instantiate(baseText, displayParent); - text.text = ""; - text.gameObject.SetActive(true); - lastSenderStats[sender] = new StatsDisplay {display = text, lastReport = report}; - } + var coroutine = StartCoroutine(UpdateStats(sender)); + coroutines.Add(coroutine); } foreach (var receiver in activeReceiverList.Values.SelectMany(x => x)) { - var op = receiver.GetStats(); - yield return op; - - if (op.IsError) - { - continue; - } - - var report = op.Value; - if (lastReceiverStats.TryGetValue(receiver, out var statsDisplay)) - { - statsDisplay.display.text = CreateDisplayString(report, statsDisplay.lastReport); - statsDisplay.lastReport = report; - } - else - { - var text = Instantiate(baseText, displayParent); - text.text = ""; - text.gameObject.SetActive(true); - lastReceiverStats[receiver] = new StatsDisplay {display = text, lastReport = report}; - } + var coroutine = StartCoroutine(UpdateStats(receiver)); + coroutines.Add(coroutine); + } + foreach(var coroutine in coroutines) + { + yield return coroutine; } - var noStatsData = !lastSenderStats.Any() && !lastReceiverStats.Any(); baseText.gameObject.SetActive(noStatsData); } } + IEnumerator UpdateStats(RTCRtpReceiver receiver) + { + var op = receiver.GetStats(); + yield return op; + + if (op.IsError) + { + yield break; + } + + var report = op.Value; + if (report == null) + { + yield break; + } + + if (lastReceiverStats.TryGetValue(receiver, out var statsDisplay)) + { + var lastReport = statsDisplay.lastReport; + statsDisplay.display.text = CreateDisplayString(report, lastReport); + statsDisplay.lastReport = report; + lastReport.Dispose(); + } + else + { + var text = Instantiate(baseText, displayParent); + text.text = ""; + text.gameObject.SetActive(true); + lastReceiverStats[receiver] = new StatsDisplay { display = text, lastReport = report }; + } + } + + IEnumerator UpdateStats(RTCRtpSender sender) + { + var op = sender.GetStats(); + yield return op; + + + if (op.IsError) + { + yield break; + } + + var report = op.Value; + if (report == null) + { + yield break; + } + + if (lastSenderStats.TryGetValue(sender, out var statsDisplay)) + { + var lastReport = statsDisplay.lastReport; + statsDisplay.display.text = CreateDisplayString(report, lastReport); + statsDisplay.lastReport = report; + lastReport.Dispose(); + } + else + { + var text = Instantiate(baseText, displayParent); + text.text = ""; + text.gameObject.SetActive(true); + lastSenderStats[sender] = new StatsDisplay { display = text, lastReport = report }; + } + } + private void SetUpSenderBase(StreamSenderBase senderBase) { if (alreadySetupSenderList.Contains(senderBase))