Index: content/renderer/media/peer_connection_handler_base.cc |
diff --git a/content/renderer/media/peer_connection_handler_base.cc b/content/renderer/media/peer_connection_handler_base.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..cf82ffe7cd68f0c8c2f66f1e777c07574025dfb5 |
--- /dev/null |
+++ b/content/renderer/media/peer_connection_handler_base.cc |
@@ -0,0 +1,123 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "content/renderer/media/peer_connection_handler_base.h" |
+ |
+#include "base/logging.h" |
+#include "base/utf_string_conversions.h" |
+#include "content/renderer/media/media_stream_dependency_factory.h" |
+#include "content/renderer/media/media_stream_impl.h" |
+#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebMediaStreamDescriptor.h" |
+#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebMediaStreamSource.h" |
+#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebString.h" |
+ |
+PeerConnectionHandlerBase::PeerConnectionHandlerBase( |
+ MediaStreamImpl* msi, |
+ MediaStreamDependencyFactory* dependency_factory) |
+ : media_stream_impl_(msi), |
+ dependency_factory_(dependency_factory), |
+ message_loop_proxy_(base::MessageLoopProxy::current()) { |
+} |
+ |
+PeerConnectionHandlerBase::~PeerConnectionHandlerBase() { |
+} |
+ |
+bool PeerConnectionHandlerBase::HasStream(const std::string& stream_label) { |
+ webrtc::MediaStreamInterface* stream = |
+ native_peer_connection_->remote_streams()->find(stream_label); |
+ return stream != NULL; |
+} |
+ |
+void PeerConnectionHandlerBase::SetVideoRenderer( |
+ const std::string& stream_label, |
+ webrtc::VideoRendererWrapperInterface* renderer) { |
+ webrtc::MediaStreamInterface* stream = |
+ native_peer_connection_->remote_streams()->find(stream_label); |
+ webrtc::VideoTracks* video_tracks = stream->video_tracks(); |
+ // We assume there is only one enabled video track. |
+ for (size_t i = 0; i < video_tracks->count(); ++i) { |
+ webrtc::VideoTrackInterface* video_track = video_tracks->at(i); |
+ if (video_track->enabled()) { |
+ video_track->SetRenderer(renderer); |
+ return; |
+ } |
+ } |
+ DVLOG(1) << "No enabled video track."; |
+} |
+ |
+void PeerConnectionHandlerBase::AddStream( |
+ const WebKit::WebMediaStreamDescriptor& stream) { |
+ talk_base::scoped_refptr<webrtc::LocalMediaStreamInterface> native_stream = |
+ dependency_factory_->CreateLocalMediaStream(UTF16ToUTF8(stream.label())); |
+ WebKit::WebVector<WebKit::WebMediaStreamSource> source_vector; |
+ stream.sources(source_vector); |
+ |
+ // Get and add all tracks. |
+ for (size_t i = 0; i < source_vector.size(); ++i) { |
+ webrtc::MediaStreamTrackInterface* track = media_stream_impl_ |
+ ->GetLocalMediaStreamTrack(UTF16ToUTF8(source_vector[i].id())); |
+ DCHECK(track); |
+ if (source_vector[i].type() == WebKit::WebMediaStreamSource::TypeVideo) { |
+ native_stream->AddTrack(static_cast<webrtc::VideoTrackInterface*>(track)); |
+ } else { |
+ DCHECK(source_vector[i].type() == |
+ WebKit::WebMediaStreamSource::TypeAudio); |
+ native_stream->AddTrack(static_cast<webrtc::AudioTrackInterface*>(track)); |
+ } |
+ } |
+ |
+ native_peer_connection_->AddStream(native_stream); |
+} |
+ |
+void PeerConnectionHandlerBase::RemoveStream( |
+ const WebKit::WebMediaStreamDescriptor& stream) { |
+ talk_base::scoped_refptr<webrtc::StreamCollectionInterface> native_streams = |
+ native_peer_connection_->local_streams(); |
+ if (!native_streams) |
+ return; |
+ // TODO(perkj): Change libJingle PeerConnection::RemoveStream API to take a |
+ // label as input instead of stream and return bool. |
+ webrtc::LocalMediaStreamInterface* native_stream = |
+ static_cast<webrtc::LocalMediaStreamInterface*>(native_streams->find( |
+ UTF16ToUTF8(stream.label()))); |
+ DCHECK(native_stream); |
+ native_peer_connection_->RemoveStream(native_stream); |
+} |
+ |
+WebKit::WebMediaStreamDescriptor |
+PeerConnectionHandlerBase::CreateWebKitStreamDescriptor( |
+ webrtc::MediaStreamInterface* stream) { |
+ webrtc::AudioTracks* audio_tracks = stream->audio_tracks(); |
+ webrtc::VideoTracks* video_tracks = stream->video_tracks(); |
+ WebKit::WebVector<WebKit::WebMediaStreamSource> source_vector( |
+ audio_tracks->count() + video_tracks->count()); |
+ |
+ // Add audio tracks. |
+ size_t i = 0; |
+ for (; i < audio_tracks->count(); ++i) { |
+ webrtc::AudioTrackInterface* audio_track = audio_tracks->at(i); |
+ DCHECK(audio_track); |
+ source_vector[i].initialize( |
+ // TODO(grunell): Set id to something unique. |
+ UTF8ToUTF16(audio_track->label()), |
+ WebKit::WebMediaStreamSource::TypeAudio, |
+ UTF8ToUTF16(audio_track->label())); |
+ } |
+ |
+ // Add video tracks. |
+ for (i = 0; i < video_tracks->count(); ++i) { |
+ webrtc::VideoTrackInterface* video_track = video_tracks->at(i); |
+ DCHECK(video_track); |
+ source_vector[audio_tracks->count() + i].initialize( |
+ // TODO(grunell): Set id to something unique. |
+ UTF8ToUTF16(video_track->label()), |
+ WebKit::WebMediaStreamSource::TypeVideo, |
+ UTF8ToUTF16(video_track->label())); |
+ } |
+ |
+ WebKit::WebMediaStreamDescriptor descriptor; |
+ descriptor.initialize(UTF8ToUTF16(stream->label()), source_vector); |
+ |
+ return descriptor; |
+} |