Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3140)

Unified Diff: chromecast/renderer/media/cma_media_renderer_factory.cc

Issue 814403002: [Chromecast] Add CmaMediaRendererFactory and IPC proxy components (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chromecast/renderer/media/cma_media_renderer_factory.cc
diff --git a/chromecast/renderer/media/cma_media_renderer_factory.cc b/chromecast/renderer/media/cma_media_renderer_factory.cc
new file mode 100644
index 0000000000000000000000000000000000000000..ee7543c147c40ddb18245f3e3dda943d0ad5e39c
--- /dev/null
+++ b/chromecast/renderer/media/cma_media_renderer_factory.cc
@@ -0,0 +1,40 @@
+// 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.
+
+#include "chromecast/renderer/media/cma_media_renderer_factory.h"
+
+#include "base/command_line.h"
+#include "chromecast/media/cma/filters/cma_renderer.h"
+#include "chromecast/renderer/media/media_pipeline_proxy.h"
+#include "content/public/renderer/render_thread.h"
+
+namespace chromecast {
+namespace media {
+
+CmaMediaRendererFactory::CmaMediaRendererFactory(int render_frame_id)
+ : render_frame_id_(render_frame_id) {
+}
+
+CmaMediaRendererFactory::~CmaMediaRendererFactory() {
+}
+
+scoped_ptr<::media::Renderer> CmaMediaRendererFactory::CreateRenderer(
+ const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner,
+ ::media::AudioRendererSink* audio_renderer_sink) {
+ // TODO(erickung): Need to provide right chromecast::media::LoadType.
gunsch 2014/12/20 22:41:33 Link to the crbug discussing this issue
erickung1 2014/12/21 11:10:47 Done.
+ chromecast::media::LoadType cma_load_type =
+ chromecast::media::kLoadTypeMediaSource;
+ scoped_ptr<chromecast::media::MediaPipeline> cma_media_pipeline(
+ new chromecast::cma::MediaPipelineProxy(
+ render_frame_id_,
+ content::RenderThread::Get()->GetIOMessageLoopProxy(),
+ cma_load_type));
+ // TODO(gunsch): investigate calling SetCdm here if available.
gunsch 2014/12/20 22:41:33 this TODO is obsolete due to xhwang@ having wired
erickung1 2014/12/21 11:10:47 Done.
+
+ return scoped_ptr<::media::Renderer>(
gunsch 2014/12/20 22:41:33 check this CL for "<::" ; it should always be "< :
erickung1 2014/12/21 11:10:46 Done.
+ new chromecast::media::CmaRenderer(cma_media_pipeline.Pass()));
+}
+
+} // namespace media
+} // namespace chromecast

Powered by Google App Engine
This is Rietveld 408576698