Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(106)

Side by Side Diff: content/renderer/media/media_stream_track.cc

Issue 509873002: Refactor MediaStreamTrack video onmute event. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/renderer/media/media_stream_track.h" 5 #include "content/renderer/media/media_stream_track.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" 8 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h"
9 #include "third_party/libjingle/source/talk/app/webrtc/mediastreaminterface.h" 9 #include "third_party/libjingle/source/talk/app/webrtc/mediastreaminterface.h"
10 10
11 namespace content { 11 namespace content {
12 12
13 MediaStreamTrack* MediaStreamTrack::GetTrack( 13 MediaStreamTrack* MediaStreamTrack::GetTrack(
14 const blink::WebMediaStreamTrack& track) { 14 const blink::WebMediaStreamTrack& track) {
15 if (track.isNull()) 15 if (track.isNull())
16 return NULL; 16 return NULL;
17 return static_cast<MediaStreamTrack*>(track.extraData()); 17 return static_cast<MediaStreamTrack*>(track.extraData());
18 } 18 }
19 19
20 MediaStreamTrack::MediaStreamTrack( 20 MediaStreamTrack::MediaStreamTrack(
21 webrtc::MediaStreamTrackInterface* track, bool is_local_track) 21 webrtc::MediaStreamTrackInterface* track, bool is_local_track)
22 : track_(track), 22 : track_(track),
23 muted_state_(false), 23 is_local_track_(is_local_track) {
24 is_local_track_(is_local_track){
25 } 24 }
26 25
27 MediaStreamTrack::~MediaStreamTrack() { 26 MediaStreamTrack::~MediaStreamTrack() {
28 } 27 }
29 28
30 void MediaStreamTrack::SetEnabled(bool enabled) { 29 void MediaStreamTrack::SetEnabled(bool enabled) {
31 DCHECK(thread_checker_.CalledOnValidThread()); 30 DCHECK(thread_checker_.CalledOnValidThread());
32 if (track_) 31 if (track_)
33 track_->set_enabled(enabled); 32 track_->set_enabled(enabled);
34 } 33 }
35 34
36 void MediaStreamTrack::SetMutedState(bool muted_state) {
37 DCHECK(thread_checker_.CalledOnValidThread());
38 muted_state_ = muted_state;
39 }
40
41 bool MediaStreamTrack::GetMutedState(void) const {
42 DCHECK(thread_checker_.CalledOnValidThread());
43 return muted_state_;
44 }
45
46 void MediaStreamTrack::Stop() { 35 void MediaStreamTrack::Stop() {
47 DCHECK(thread_checker_.CalledOnValidThread()); 36 DCHECK(thread_checker_.CalledOnValidThread());
48 // Stop means that a track should be stopped permanently. But 37 // Stop means that a track should be stopped permanently. But
49 // since there is no proper way of doing that on a remote track, we can 38 // since there is no proper way of doing that on a remote track, we can
50 // at least disable the track. Blink will not call down to the content layer 39 // at least disable the track. Blink will not call down to the content layer
51 // after a track has been stopped. 40 // after a track has been stopped.
52 if (track_) 41 if (track_)
53 track_->set_enabled(false); 42 track_->set_enabled(false);
54 } 43 }
55 44
56 webrtc::AudioTrackInterface* MediaStreamTrack::GetAudioAdapter() { 45 webrtc::AudioTrackInterface* MediaStreamTrack::GetAudioAdapter() {
57 DCHECK(thread_checker_.CalledOnValidThread()); 46 DCHECK(thread_checker_.CalledOnValidThread());
58 return static_cast<webrtc::AudioTrackInterface*>(track_.get()); 47 return static_cast<webrtc::AudioTrackInterface*>(track_.get());
59 } 48 }
60 49
61 } // namespace content 50 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698