Index: content/public/renderer/media_stream_source_api.cc |
diff --git a/content/public/renderer/media_stream_source_api.cc b/content/public/renderer/media_stream_source_api.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4d2a9d773ead10c0dfc58141963875dd3bac28b0 |
--- /dev/null |
+++ b/content/public/renderer/media_stream_source_api.cc |
@@ -0,0 +1,60 @@ |
+// Copyright 2015 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/public/renderer/media_stream_source_api.h" |
+ |
+#include "base/callback.h" |
+#include "base/strings/utf_string_conversions.h" |
+#include "content/renderer/media/media_stream_audio_source.h" |
+#include "content/renderer/media/media_stream_video_capturer_source.h" |
+#include "media/base/audio_capturer_source.h" |
+#include "media/base/video_capturer_source.h" |
+#include "third_party/WebKit/public/platform/WebMediaDeviceInfo.h" |
+#include "third_party/WebKit/public/platform/WebMediaStreamSource.h" |
+ |
+namespace content { |
+ |
+void InitializeVideoWebMediaStreamSource( |
+ scoped_refptr<media::VideoCapturerSource> source, |
+ blink::WebMediaStreamSource* webkit_source) { |
+ webkit_source->initialize(base::UTF8ToUTF16(""), |
+ blink::WebMediaStreamSource::TypeVideo, |
+ base::UTF8ToUTF16(""), |
+ true /* remote */, |
perkj_chrome
2015/02/09 14:50:27
Remote means that this is something you receive.
r
hubbe
2015/02/09 20:13:32
I've added and documented these arguments to the A
|
+ true /* readonly */); |
+ webkit_source->setExtraData( |
+ new content::MediaStreamVideoCapturerSource( |
perkj_chrome
2015/02/09 14:50:27
We had a few discussion regarding inheritance and
hubbe
2015/02/09 20:13:32
I started out with trying to do this, but MediaStr
|
+ StreamDeviceInfo(), |
perkj_chrome
2015/02/09 14:50:27
Humm, StreamDeviceInfo seems wrong here. Its only
hubbe
2015/02/09 20:13:32
Fixed the constructor to not require the device in
|
+ content::MediaStreamSource::SourceStoppedCallback(), |
+ source)); |
+} |
+ |
+void InitializeAudioWebMediaStreamSource( |
+ scoped_refptr<media::AudioCapturerSource> source, |
+ blink::WebMediaStreamSource* webkit_source) { |
+ webkit_source->initialize(base::UTF8ToUTF16(""), |
+ blink::WebMediaStreamSource::TypeAudio, |
+ base::UTF8ToUTF16(""), |
+ true /* remote */, |
+ true /* readonly */); |
+ MediaStreamAudioSource* audio_source( |
+ new MediaStreamAudioSource( |
+ -1, |
+ StreamDeviceInfo(), |
+ content::MediaStreamSource::SourceStoppedCallback(), |
+ RenderThreadImpl::current()->GetPeerConnectionDependencyFactory())); |
+ scoped_refptr<WebRtcAudioCapturer> capturer( |
+ WebRtcAudioCapturer::CreateCapturer( |
+ -1, |
perkj_chrome
2015/02/09 14:50:27
indentation
hubbe
2015/02/09 20:13:32
Done.
|
+ StreamDeviceInfo(), |
+ blink::WebMediaConstraints(), |
+ NULL, |
+ audio_source)); |
+ media::AudioParameters params; |
+ capturer->SetCapturerSource(source, params); |
+ audio_source->SetAudioCapturer(capturer); |
+ webkit_source->setExtraData(audio_source); |
+} |
+ |
+} // namespace content |