Commit 0d9aef70 authored by Antonio Gomes's avatar Antonio Gomes Committed by Commit Bot

Merge WebMediaStreamRendererFactory and MediaStreamRendererFactoryImpl

... into MediaStreamRendererFactory.

The implementation will now reside in media_stream_renderer_factory.cc|h.

BUG=704136, 919392
R=guidou@chromium.org, haraken@chromium.org

Change-Id: I6d254aaca5b42ed170ca84218770f80843ef7e3b
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2302918
Commit-Queue: Antonio Gomes <tonikitoo@igalia.com>
Reviewed-by: default avatarGuido Urdaneta <guidou@chromium.org>
Reviewed-by: default avatarKentaro Hara <haraken@chromium.org>
Cr-Commit-Position: refs/heads/master@{#789474}
parent 7194d494
...@@ -30,7 +30,6 @@ ...@@ -30,7 +30,6 @@
#include "third_party/blink/public/platform/web_audio_latency_hint.h" #include "third_party/blink/public/platform/web_audio_latency_hint.h"
#include "third_party/blink/public/platform/web_runtime_features.h" #include "third_party/blink/public/platform/web_runtime_features.h"
#include "third_party/blink/public/web/blink.h" #include "third_party/blink/public/web/blink.h"
#include "third_party/blink/public/web/modules/mediastream/web_media_stream_renderer_factory.h"
#include "third_party/blink/public/web/web_plugin_params.h" #include "third_party/blink/public/web/web_plugin_params.h"
#include "third_party/blink/public/web/web_testing_support.h" #include "third_party/blink/public/web/web_testing_support.h"
#include "ui/gfx/icc_profile.h" #include "ui/gfx/icc_profile.h"
......
...@@ -283,7 +283,6 @@ source_set("blink_headers") { ...@@ -283,7 +283,6 @@ source_set("blink_headers") {
"web/modules/mediastream/media_stream_video_sink.h", "web/modules/mediastream/media_stream_video_sink.h",
"web/modules/mediastream/media_stream_video_source.h", "web/modules/mediastream/media_stream_video_source.h",
"web/modules/mediastream/web_media_stream_device_observer.h", "web/modules/mediastream/web_media_stream_device_observer.h",
"web/modules/mediastream/web_media_stream_renderer_factory.h",
"web/modules/mediastream/web_media_stream_utils.h", "web/modules/mediastream/web_media_stream_utils.h",
"web/modules/mediastream/webmediaplayer_ms.h", "web/modules/mediastream/webmediaplayer_ms.h",
"web/modules/service_worker/web_service_worker_context_client.h", "web/modules/service_worker/web_service_worker_context_client.h",
......
...@@ -51,7 +51,7 @@ class WebLocalFrame; ...@@ -51,7 +51,7 @@ class WebLocalFrame;
class WebMediaPlayerClient; class WebMediaPlayerClient;
class WebMediaStreamAudioRenderer; class WebMediaStreamAudioRenderer;
class WebMediaPlayerMSCompositor; class WebMediaPlayerMSCompositor;
class WebMediaStreamRendererFactory; class MediaStreamRendererFactory;
class WebMediaStreamVideoRenderer; class WebMediaStreamVideoRenderer;
class WebString; class WebString;
class WebVideoFrameSubmitter; class WebVideoFrameSubmitter;
...@@ -277,7 +277,7 @@ class BLINK_MODULES_EXPORT WebMediaPlayerMS ...@@ -277,7 +277,7 @@ class BLINK_MODULES_EXPORT WebMediaPlayerMS
void SetGpuMemoryBufferVideoForTesting( void SetGpuMemoryBufferVideoForTesting(
media::GpuMemoryBufferVideoFramePool* gpu_memory_buffer_pool); media::GpuMemoryBufferVideoFramePool* gpu_memory_buffer_pool);
void SetMediaStreamRendererFactoryForTesting( void SetMediaStreamRendererFactoryForTesting(
std::unique_ptr<WebMediaStreamRendererFactory>); std::unique_ptr<MediaStreamRendererFactory>);
// Callback used to fulfill video.requestVideoFrameCallback() requests. // Callback used to fulfill video.requestVideoFrameCallback() requests.
void OnNewFramePresentedCallback(); void OnNewFramePresentedCallback();
...@@ -334,7 +334,7 @@ class BLINK_MODULES_EXPORT WebMediaPlayerMS ...@@ -334,7 +334,7 @@ class BLINK_MODULES_EXPORT WebMediaPlayerMS
std::unique_ptr<media::MediaLog> media_log_; std::unique_ptr<media::MediaLog> media_log_;
std::unique_ptr<WebMediaStreamRendererFactory> renderer_factory_; std::unique_ptr<MediaStreamRendererFactory> renderer_factory_;
const scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner_; const scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner_;
const scoped_refptr<base::SingleThreadTaskRunner> io_task_runner_; const scoped_refptr<base::SingleThreadTaskRunner> io_task_runner_;
......
...@@ -45,8 +45,8 @@ blink_modules_sources("mediastream") { ...@@ -45,8 +45,8 @@ blink_modules_sources("mediastream") {
"media_stream_event.h", "media_stream_event.h",
"media_stream_local_frame_wrapper.cc", "media_stream_local_frame_wrapper.cc",
"media_stream_local_frame_wrapper.h", "media_stream_local_frame_wrapper.h",
"media_stream_renderer_factory_impl.cc", "media_stream_renderer_factory.cc",
"media_stream_renderer_factory_impl.h", "media_stream_renderer_factory.h",
"media_stream_track.cc", "media_stream_track.cc",
"media_stream_track.h", "media_stream_track.h",
"media_stream_track_content_hint.h", "media_stream_track_content_hint.h",
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
#include "third_party/blink/renderer/modules/mediastream/media_stream_renderer_factory_impl.h" #include "third_party/blink/renderer/modules/mediastream/media_stream_renderer_factory.h"
#include <utility> #include <utility>
...@@ -47,19 +47,19 @@ void SendLogMessage(const WTF::String& message) { ...@@ -47,19 +47,19 @@ void SendLogMessage(const WTF::String& message) {
} // namespace } // namespace
MediaStreamRendererFactoryImpl::MediaStreamRendererFactoryImpl() {} MediaStreamRendererFactory::MediaStreamRendererFactory() {}
MediaStreamRendererFactoryImpl::~MediaStreamRendererFactoryImpl() {} MediaStreamRendererFactory::~MediaStreamRendererFactory() {}
scoped_refptr<WebMediaStreamVideoRenderer> scoped_refptr<WebMediaStreamVideoRenderer>
MediaStreamRendererFactoryImpl::GetVideoRenderer( MediaStreamRendererFactory::GetVideoRenderer(
const WebMediaStream& web_stream, const WebMediaStream& web_stream,
const WebMediaStreamVideoRenderer::RepaintCB& repaint_cb, const WebMediaStreamVideoRenderer::RepaintCB& repaint_cb,
scoped_refptr<base::SingleThreadTaskRunner> io_task_runner, scoped_refptr<base::SingleThreadTaskRunner> io_task_runner,
scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner) { scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner) {
DCHECK(!web_stream.IsNull()); DCHECK(!web_stream.IsNull());
DVLOG(1) << "MediaStreamRendererFactoryImpl::GetVideoRenderer stream:" DVLOG(1) << "MediaStreamRendererFactory::GetVideoRenderer stream:"
<< web_stream.Id().Utf8(); << web_stream.Id().Utf8();
MediaStreamDescriptor& descriptor = *web_stream; MediaStreamDescriptor& descriptor = *web_stream;
...@@ -76,7 +76,7 @@ MediaStreamRendererFactoryImpl::GetVideoRenderer( ...@@ -76,7 +76,7 @@ MediaStreamRendererFactoryImpl::GetVideoRenderer(
} }
scoped_refptr<WebMediaStreamAudioRenderer> scoped_refptr<WebMediaStreamAudioRenderer>
MediaStreamRendererFactoryImpl::GetAudioRenderer( MediaStreamRendererFactory::GetAudioRenderer(
const WebMediaStream& web_stream, const WebMediaStream& web_stream,
WebLocalFrame* web_frame, WebLocalFrame* web_frame,
const WebString& device_id, const WebString& device_id,
......
...@@ -2,14 +2,15 @@ ...@@ -2,14 +2,15 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
#ifndef THIRD_PARTY_BLINK_PUBLIC_WEB_MODULES_MEDIASTREAM_WEB_MEDIA_STREAM_RENDERER_FACTORY_H_ #ifndef THIRD_PARTY_BLINK_RENDERER_MODULES_MEDIASTREAM_MEDIA_STREAM_RENDERER_FACTORY_H_
#define THIRD_PARTY_BLINK_PUBLIC_WEB_MODULES_MEDIASTREAM_WEB_MEDIA_STREAM_RENDERER_FACTORY_H_ #define THIRD_PARTY_BLINK_RENDERER_MODULES_MEDIASTREAM_MEDIA_STREAM_RENDERER_FACTORY_H_
#include "base/memory/ref_counted.h" #include "base/macros.h"
#include "base/memory/scoped_refptr.h"
#include "third_party/blink/public/platform/modules/mediastream/web_media_stream_audio_renderer.h" #include "third_party/blink/public/platform/modules/mediastream/web_media_stream_audio_renderer.h"
#include "third_party/blink/public/platform/modules/mediastream/web_media_stream_video_renderer.h" #include "third_party/blink/public/platform/modules/mediastream/web_media_stream_video_renderer.h"
#include "third_party/blink/public/platform/web_common.h"
#include "third_party/blink/public/platform/web_string.h" #include "third_party/blink/public/platform/web_string.h"
#include "third_party/blink/renderer/modules/modules_export.h"
namespace base { namespace base {
class SingleThreadTaskRunner; class SingleThreadTaskRunner;
...@@ -20,29 +21,30 @@ namespace blink { ...@@ -20,29 +21,30 @@ namespace blink {
class WebMediaStream; class WebMediaStream;
class WebLocalFrame; class WebLocalFrame;
// WebMediaStreamRendererFactory is used by WebMediaPlayerMS to create audio and // MediaStreamRendererFactory is used by WebMediaPlayerMS to create audio
// video feeds from a MediaStream provided an URL. // and video feeds from a MediaStream provided an URL. The factory methods are
// The factory methods are virtual in order for Blink web tests to be able to // virtual in order for Blink web tests to be able to override them.
// override them. class MODULES_EXPORT MediaStreamRendererFactory {
class BLINK_MODULES_EXPORT WebMediaStreamRendererFactory {
public: public:
virtual ~WebMediaStreamRendererFactory() {} MediaStreamRendererFactory();
virtual ~MediaStreamRendererFactory();
// Returns a WebMediaStreamVideoRenderer that uses the given task runners.
// |io_task_runner| is used for passing video frames.
virtual scoped_refptr<WebMediaStreamVideoRenderer> GetVideoRenderer( virtual scoped_refptr<WebMediaStreamVideoRenderer> GetVideoRenderer(
const WebMediaStream& web_stream, const WebMediaStream& web_stream,
const WebMediaStreamVideoRenderer::RepaintCB& repaint_cb, const WebMediaStreamVideoRenderer::RepaintCB& repaint_cb,
scoped_refptr<base::SingleThreadTaskRunner> io_task_runner, scoped_refptr<base::SingleThreadTaskRunner> io_task_runner,
scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner) = 0; scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner);
virtual scoped_refptr<WebMediaStreamAudioRenderer> GetAudioRenderer( virtual scoped_refptr<WebMediaStreamAudioRenderer> GetAudioRenderer(
const WebMediaStream& web_stream, const WebMediaStream& web_stream,
WebLocalFrame* web_frame, WebLocalFrame* web_frame,
const WebString& device_id, const WebString& device_id,
base::RepeatingCallback<void()> on_render_error_callback) = 0; base::RepeatingCallback<void()> on_render_error_callback);
private:
DISALLOW_COPY_AND_ASSIGN(MediaStreamRendererFactory);
}; };
} // namespace blink } // namespace blink
#endif // THIRD_PARTY_BLINK_PUBLIC_WEB_MODULES_MEDIASTREAM_WEB_MEDIA_STREAM_RENDERER_FACTORY_H_ #endif // THIRD_PARTY_BLINK_RENDERER_MODULES_MEDIASTREAM_MEDIA_STREAM_RENDERER_FACTORY_H_
// Copyright 2014 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.
#ifndef THIRD_PARTY_BLINK_RENDERER_MODULES_MEDIASTREAM_MEDIA_STREAM_RENDERER_FACTORY_IMPL_H_
#define THIRD_PARTY_BLINK_RENDERER_MODULES_MEDIASTREAM_MEDIA_STREAM_RENDERER_FACTORY_IMPL_H_
#include "base/macros.h"
#include "third_party/blink/public/web/modules/mediastream/web_media_stream_renderer_factory.h"
namespace blink {
class MediaStreamRendererFactoryImpl : public WebMediaStreamRendererFactory {
public:
MediaStreamRendererFactoryImpl();
~MediaStreamRendererFactoryImpl() override;
scoped_refptr<WebMediaStreamVideoRenderer> GetVideoRenderer(
const WebMediaStream& web_stream,
const WebMediaStreamVideoRenderer::RepaintCB& repaint_cb,
scoped_refptr<base::SingleThreadTaskRunner> io_task_runner,
scoped_refptr<base::SingleThreadTaskRunner> main_render_task_runner)
override;
scoped_refptr<WebMediaStreamAudioRenderer> GetAudioRenderer(
const WebMediaStream& web_stream,
WebLocalFrame* web_frame,
const WebString& device_id,
base::RepeatingCallback<void()> on_render_error_callback) override;
private:
DISALLOW_COPY_AND_ASSIGN(MediaStreamRendererFactoryImpl);
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_RENDERER_MODULES_MEDIASTREAM_MEDIA_STREAM_RENDERER_FACTORY_IMPL_H_
...@@ -36,7 +36,7 @@ class LocalFrame; ...@@ -36,7 +36,7 @@ class LocalFrame;
// PeerConnection/WebRTC-sourced) MediaStreamAudioTracks to an audio output // PeerConnection/WebRTC-sourced) MediaStreamAudioTracks to an audio output
// device, reconciling differences in the rates of production and consumption of // device, reconciling differences in the rates of production and consumption of
// the audio data. Note that remote PeerConnection-sourced tracks are NOT // the audio data. Note that remote PeerConnection-sourced tracks are NOT
// rendered by this implementation (see WebMediaStreamRendererFactoryImpl). // rendered by this implementation (see MediaStreamRendererFactory).
// //
// This class uses AudioDeviceFactory to create media::AudioRendererSink and // This class uses AudioDeviceFactory to create media::AudioRendererSink and
// owns/manages their lifecycles. Output devices are automatically re-created // owns/manages their lifecycles. Output devices are automatically re-created
......
...@@ -35,7 +35,7 @@ ...@@ -35,7 +35,7 @@
#include "third_party/blink/public/web/modules/media/webmediaplayer_util.h" #include "third_party/blink/public/web/modules/media/webmediaplayer_util.h"
#include "third_party/blink/public/web/web_local_frame.h" #include "third_party/blink/public/web/web_local_frame.h"
#include "third_party/blink/renderer/modules/mediastream/media_stream_local_frame_wrapper.h" #include "third_party/blink/renderer/modules/mediastream/media_stream_local_frame_wrapper.h"
#include "third_party/blink/renderer/modules/mediastream/media_stream_renderer_factory_impl.h" #include "third_party/blink/renderer/modules/mediastream/media_stream_renderer_factory.h"
#include "third_party/blink/renderer/modules/mediastream/webmediaplayer_ms_compositor.h" #include "third_party/blink/renderer/modules/mediastream/webmediaplayer_ms_compositor.h"
#include "third_party/blink/renderer/platform/mediastream/media_stream_audio_track.h" #include "third_party/blink/renderer/platform/mediastream/media_stream_audio_track.h"
#include "third_party/blink/renderer/platform/mediastream/media_stream_component.h" #include "third_party/blink/renderer/platform/mediastream/media_stream_component.h"
...@@ -319,7 +319,7 @@ WebMediaPlayerMS::WebMediaPlayerMS( ...@@ -319,7 +319,7 @@ WebMediaPlayerMS::WebMediaPlayerMS(
paused_(true), paused_(true),
video_transformation_(media::kNoTransformation), video_transformation_(media::kNoTransformation),
media_log_(std::move(media_log)), media_log_(std::move(media_log)),
renderer_factory_(std::make_unique<MediaStreamRendererFactoryImpl>()), renderer_factory_(std::make_unique<MediaStreamRendererFactory>()),
main_render_task_runner_(std::move(main_render_task_runner)), main_render_task_runner_(std::move(main_render_task_runner)),
io_task_runner_(std::move(io_task_runner)), io_task_runner_(std::move(io_task_runner)),
compositor_task_runner_(std::move(compositor_task_runner)), compositor_task_runner_(std::move(compositor_task_runner)),
...@@ -1319,7 +1319,7 @@ void WebMediaPlayerMS::SetGpuMemoryBufferVideoForTesting( ...@@ -1319,7 +1319,7 @@ void WebMediaPlayerMS::SetGpuMemoryBufferVideoForTesting(
} }
void WebMediaPlayerMS::SetMediaStreamRendererFactoryForTesting( void WebMediaPlayerMS::SetMediaStreamRendererFactoryForTesting(
std::unique_ptr<WebMediaStreamRendererFactory> renderer_factory) { std::unique_ptr<MediaStreamRendererFactory> renderer_factory) {
renderer_factory_ = std::move(renderer_factory); renderer_factory_ = std::move(renderer_factory);
} }
......
...@@ -27,9 +27,9 @@ ...@@ -27,9 +27,9 @@
#include "third_party/blink/public/platform/web_media_player.h" #include "third_party/blink/public/platform/web_media_player.h"
#include "third_party/blink/public/platform/web_media_player_client.h" #include "third_party/blink/public/platform/web_media_player_client.h"
#include "third_party/blink/public/platform/web_media_player_source.h" #include "third_party/blink/public/platform/web_media_player_source.h"
#include "third_party/blink/public/web/modules/mediastream/web_media_stream_renderer_factory.h"
#include "third_party/blink/public/web/modules/mediastream/webmediaplayer_ms.h" #include "third_party/blink/public/web/modules/mediastream/webmediaplayer_ms.h"
#include "third_party/blink/public/web/web_local_frame.h" #include "third_party/blink/public/web/web_local_frame.h"
#include "third_party/blink/renderer/modules/mediastream/media_stream_renderer_factory.h"
#include "third_party/blink/renderer/modules/mediastream/webmediaplayer_ms_compositor.h" #include "third_party/blink/renderer/modules/mediastream/webmediaplayer_ms_compositor.h"
#include "third_party/blink/renderer/platform/scheduler/public/post_cross_thread_task.h" #include "third_party/blink/renderer/platform/scheduler/public/post_cross_thread_task.h"
#include "third_party/blink/renderer/platform/wtf/cross_thread_functional.h" #include "third_party/blink/renderer/platform/wtf/cross_thread_functional.h"
...@@ -440,7 +440,7 @@ class MockWebVideoFrameSubmitter : public WebVideoFrameSubmitter { ...@@ -440,7 +440,7 @@ class MockWebVideoFrameSubmitter : public WebVideoFrameSubmitter {
// The class is used to generate a MockVideoProvider in // The class is used to generate a MockVideoProvider in
// WebMediaPlayerMS::load(). // WebMediaPlayerMS::load().
class MockRenderFactory : public WebMediaStreamRendererFactory { class MockRenderFactory : public MediaStreamRendererFactory {
public: public:
MockRenderFactory( MockRenderFactory(
const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
...@@ -690,7 +690,7 @@ void WebMediaPlayerMSTest::InitializeWebMediaPlayerMS() { ...@@ -690,7 +690,7 @@ void WebMediaPlayerMSTest::InitializeWebMediaPlayerMS() {
WTF::Unretained(this)), WTF::Unretained(this)),
std::move(submitter_), surface_layer_mode); std::move(submitter_), surface_layer_mode);
player_->SetMediaStreamRendererFactoryForTesting( player_->SetMediaStreamRendererFactoryForTesting(
std::unique_ptr<WebMediaStreamRendererFactory>(render_factory_)); std::unique_ptr<MediaStreamRendererFactory>(render_factory_));
} }
MockMediaStreamVideoRenderer* WebMediaPlayerMSTest::LoadAndGetFrameProvider( MockMediaStreamVideoRenderer* WebMediaPlayerMSTest::LoadAndGetFrameProvider(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment