From cbbbc9300a483fc9d8e76ccfc1425c1f3827bbf3 Mon Sep 17 00:00:00 2001 From: cnderrauber Date: Mon, 22 Apr 2024 12:53:36 +0800 Subject: [PATCH] Add recvonly transceiver for simulcast video Fix one of the layers can't send back video because the transceiver is used for receiving. --- examples/simulcast/main.go | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/examples/simulcast/main.go b/examples/simulcast/main.go index ded6bdfe07d..6054bf6a96f 100644 --- a/examples/simulcast/main.go +++ b/examples/simulcast/main.go @@ -64,14 +64,18 @@ func main() { } outputTracks["f"] = outputTrack - // Add this newly created track to the PeerConnection - if _, err = peerConnection.AddTrack(outputTracks["q"]); err != nil { + if _, err = peerConnection.AddTransceiverFromKind(webrtc.RTPCodecTypeVideo, webrtc.RTPTransceiverInit{Direction: webrtc.RTPTransceiverDirectionRecvonly}); err != nil { panic(err) } - if _, err = peerConnection.AddTrack(outputTracks["h"]); err != nil { + + // Add this newly created track to the PeerConnection to send back video + if _, err = peerConnection.AddTransceiverFromTrack(outputTracks["q"], webrtc.RTPTransceiverInit{Direction: webrtc.RTPTransceiverDirectionSendonly}); err != nil { + panic(err) + } + if _, err = peerConnection.AddTransceiverFromTrack(outputTracks["h"], webrtc.RTPTransceiverInit{Direction: webrtc.RTPTransceiverDirectionSendonly}); err != nil { panic(err) } - if _, err = peerConnection.AddTrack(outputTracks["f"]); err != nil { + if _, err = peerConnection.AddTransceiverFromTrack(outputTracks["f"], webrtc.RTPTransceiverInit{Direction: webrtc.RTPTransceiverDirectionSendonly}); err != nil { panic(err) }