Chromium Code Reviews| 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 |