Index: content/renderer/media/webrtc/webrtc_media_stream_adapter.cc |
diff --git a/content/renderer/media/webrtc/webrtc_media_stream_adapter.cc b/content/renderer/media/webrtc/webrtc_media_stream_adapter.cc |
index 4f5d8347f98068b07e5e0a6aae9514752f4b3592..b55575942ae5180b1b780e7e2a44b0d7f9cae52d 100644 |
--- a/content/renderer/media/webrtc/webrtc_media_stream_adapter.cc |
+++ b/content/renderer/media/webrtc/webrtc_media_stream_adapter.cc |
@@ -4,12 +4,15 @@ |
#include "content/renderer/media/webrtc/webrtc_media_stream_adapter.h" |
+#include "base/bind.h" |
#include "base/logging.h" |
-#include "content/renderer/media/media_stream_audio_source.h" |
#include "content/renderer/media/media_stream_audio_track.h" |
#include "content/renderer/media/media_stream_track.h" |
#include "content/renderer/media/webrtc/media_stream_video_webrtc_sink.h" |
#include "content/renderer/media/webrtc/peer_connection_dependency_factory.h" |
+#include "content/renderer/media/webrtc/peer_connection_remote_audio_source.h" |
+#include "content/renderer/media/webrtc/processed_local_audio_track.h" |
+#include "content/renderer/media/webrtc/webrtc_local_audio_track_adapter.h" |
#include "third_party/WebKit/public/platform/WebMediaStreamSource.h" |
#include "third_party/WebKit/public/platform/WebMediaStreamTrack.h" |
#include "third_party/WebKit/public/platform/WebString.h" |
@@ -78,27 +81,34 @@ void WebRtcMediaStreamAdapter::CreateAudioTrack( |
DCHECK_EQ(track.source().type(), blink::WebMediaStreamSource::TypeAudio); |
// A media stream is connected to a peer connection, enable the |
// peer connection mode for the sources. |
- MediaStreamAudioTrack* native_track = MediaStreamAudioTrack::GetTrack(track); |
+ MediaStreamAudioTrack* native_track = MediaStreamAudioTrack::Get(track); |
if (!native_track) { |
DLOG(ERROR) << "No native track for blink audio track."; |
return; |
} |
- webrtc::AudioTrackInterface* audio_track = native_track->GetAudioAdapter(); |
- if (!audio_track) { |
- DLOG(ERROR) << "Audio track doesn't support webrtc."; |
- return; |
- } |
- |
- if (native_track->is_local_track()) { |
- const blink::WebMediaStreamSource& source = track.source(); |
- MediaStreamAudioSource* audio_source = |
- static_cast<MediaStreamAudioSource*>(source.extraData()); |
- if (audio_source && audio_source->GetAudioCapturer().get()) |
- audio_source->GetAudioCapturer()->EnablePeerConnectionMode(); |
+ // If we have an instance of ProcessedLocalAudioTrack or |
+ // PeerConnectionRemoteAudioTrack, use its webrtc::AudioTrackInterface |
+ // implementation. Otherwise, create a place-holder instance for tracks |
+ // providing audio data from other sources. |
+ scoped_refptr<webrtc::AudioTrackInterface> track_interface; |
+ if (ProcessedLocalAudioTrack* local_rtc_track = |
+ ProcessedLocalAudioTrack::From(native_track)) { |
+ track_interface = local_rtc_track->adapter(); |
+ } else if (PeerConnectionRemoteAudioTrack* remote_pc_track = |
+ PeerConnectionRemoteAudioTrack::From(native_track)) { |
+ track_interface = remote_pc_track->track_interface(); |
+ } else { |
+ const scoped_refptr<WebRtcLocalAudioTrackAdapter> adapter = |
+ WebRtcLocalAudioTrackAdapter::Create( |
+ track.id().utf8(), nullptr, factory_->GetWebRtcSignalingThread()); |
+ adapter->SetMediaStreamAudioTrack(native_track); |
+ native_track->AddStopObserver( |
+ base::Bind(&WebRtcLocalAudioTrackAdapter::SetMediaStreamAudioTrack, |
+ adapter, nullptr)); |
+ track_interface = adapter; |
} |
- |
- webrtc_media_stream_->AddTrack(audio_track); |
+ webrtc_media_stream_->AddTrack(track_interface.get()); |
} |
void WebRtcMediaStreamAdapter::CreateVideoTrack( |