stop replaced track in PeerCall

This commit is contained in:
Bruno Windels 2022-07-07 15:36:30 +02:00
parent 206ac6e2dd
commit f187a51c97
2 changed files with 2 additions and 10 deletions

View file

@ -47,16 +47,7 @@ export class LocalMedia {
if (oldOriginalStream?.id === newStream?.id) { if (oldOriginalStream?.id === newStream?.id) {
return oldCloneStream; return oldCloneStream;
} else { } else {
const clonedStream = newStream?.clone(); return newStream?.clone();
// clonedStream.addEventListener("removetrack", evt => {
// console.log(`removing track ${evt.track.id} (${evt.track.kind}) from clonedStream ${clonedStream.id}`);
// });
// console.log("got cloned tracks", Array.from(clonedStream.getTracks()).map((t: MediaStreamTrack) => { return {kind: t.kind, id: t.id};}), "from new stream", Array.from(newStream.getTracks()).map((t: MediaStreamTrack) => { return {kind: t.kind, id: t.id};}));
// console.log("stopping old audio stream", getStreamAudioTrack(oldCloneStream)?.id);
// console.log("stopping old video stream", getStreamVideoTrack(oldCloneStream)?.id);
getStreamAudioTrack(oldCloneStream)?.stop();
getStreamVideoTrack(oldCloneStream)?.stop();
return clonedStream;
} }
} }
return new LocalMedia( return new LocalMedia(

View file

@ -1007,6 +1007,7 @@ export class PeerCall implements IDisposable {
if (streamToKeep !== stream) { if (streamToKeep !== stream) {
if (oldTrack) { if (oldTrack) {
streamToKeep.removeTrack(oldTrack); streamToKeep.removeTrack(oldTrack);
oldTrack.stop();
} }
if (newTrack) { if (newTrack) {
streamToKeep.addTrack(newTrack); streamToKeep.addTrack(newTrack);