RESOLVED FIXED 172831
A cloned MediaStreamTrack should mute independently other tracks using the same source
https://bugs.webkit.org/show_bug.cgi?id=172831
Summary A cloned MediaStreamTrack should mute independently other tracks using the sa...
Prerak Jain
Reported 2017-06-01 13:06:45 PDT
MediaStreamTrack clone API just clones the track but not the media source, as a result, if a track is muted/stopped it will mute/stop the media source and all the tracks associated with media source will be affected. A change in state of a track using a media source should not impact the other tracks using the same media source.
Attachments
Patch (58.28 KB, patch)
2017-06-16 16:15 PDT, youenn fablet
no flags
Patch (58.57 KB, patch)
2017-06-16 16:20 PDT, youenn fablet
no flags
Fixes build (62.77 KB, patch)
2017-06-16 16:57 PDT, youenn fablet
no flags
Fixing build again (68.58 KB, patch)
2017-06-16 17:25 PDT, youenn fablet
no flags
Radar WebKit Bug Importer
Comment 1 2017-06-01 13:16:57 PDT
youenn fablet
Comment 2 2017-06-01 13:18:04 PDT
(In reply to Prerak Jain from comment #0) > MediaStreamTrack clone API just clones the track but not the media source, > as a result, if a track is muted/stopped it will mute/stop the media source > and all the tracks associated with media source will be affected. A change > in state of a track using a media source should not impact the other tracks > using the same media source. There are things that can be done in terms of stopping/muting. If it comes to properties of the source (width, height, echo cancellation...), that may be harder.
youenn fablet
Comment 3 2017-06-16 16:15:37 PDT
youenn fablet
Comment 4 2017-06-16 16:20:25 PDT
Eric Carlson
Comment 5 2017-06-16 16:31:31 PDT
Comment on attachment 313153 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=313153&action=review > Source/WebCore/ChangeLog:11 > + Moving enabled handling in MediaStreamTrackPrivate instead of RealtimeMediaSource. Nit: "Moving enabled handling in" => "Move enabled handling to" > Source/WebCore/ChangeLog:13 > + Moving WebRTC and WebAudio customers of RealtimeMediaSource to MediaStreamTrackPrivate. > + Moving creation of WebAudio provider to MediaStreamTrackPrivate. Nit: "Moving" => "Move" > Source/WebCore/platform/mediastream/MediaStreamTrackPrivate.cpp:196 > mediaSample.setTrackID(id()); This isn't new to this patch, but sample can only have one "track ID" so I think we have a problem when a source is attached to more than one track.
youenn fablet
Comment 6 2017-06-16 16:40:05 PDT
> > Source/WebCore/platform/mediastream/MediaStreamTrackPrivate.cpp:196 > > mediaSample.setTrackID(id()); > > This isn't new to this patch, but sample can only have one "track ID" so I > think we have a problem when a source is attached to more than one track. I was wondering what was its actual use. It seems it is only used in SourceBuffer::sourceBufferPrivateDidReceiveSample. Maybe trackID should not be set in MediaSample but retrieved from the track or from another parameter.
youenn fablet
Comment 7 2017-06-16 16:57:43 PDT
Created attachment 313159 [details] Fixes build
youenn fablet
Comment 8 2017-06-16 17:25:20 PDT
Created attachment 313164 [details] Fixing build again
WebKit Commit Bot
Comment 9 2017-06-19 10:13:01 PDT
Comment on attachment 313164 [details] Fixing build again Clearing flags on attachment: 313164 Committed r218497: <http://trac.webkit.org/changeset/218497>
WebKit Commit Bot
Comment 10 2017-06-19 10:13:03 PDT
All reviewed patches have been landed. Closing bug.
youenn fablet
Comment 11 2017-07-10 13:30:47 PDT
*** Bug 174126 has been marked as a duplicate of this bug. ***
Note You need to log in before you can comment on or make changes to this bug.