| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chromecast/browser/media/cast_mojo_media_client.h" | 5 #include "chromecast/browser/media/cast_mojo_media_client.h" |
| 6 | 6 |
| 7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
| 8 #include "chromecast/browser/media/cast_renderer.h" | 8 #include "chromecast/browser/media/cast_renderer.h" |
| 9 #include "media/base/cdm_factory.h" | 9 #include "media/base/cdm_factory.h" |
| 10 #include "media/base/media_log.h" | 10 #include "media/base/media_log.h" |
| 11 #include "media/base/renderer_factory.h" | 11 #include "media/base/renderer_factory.h" |
| 12 | 12 |
| 13 namespace chromecast { | 13 namespace chromecast { |
| 14 namespace media { | 14 namespace media { |
| 15 | 15 |
| 16 CastMojoMediaClient::CastMojoMediaClient( | 16 CastMojoMediaClient::CastMojoMediaClient( |
| 17 const CreateMediaPipelineBackendCB& create_backend_cb, | 17 const CreateMediaPipelineBackendCB& create_backend_cb, |
| 18 const CreateCdmFactoryCB& create_cdm_factory_cb) | 18 const CreateCdmFactoryCB& create_cdm_factory_cb, |
| 19 VideoResolutionPolicy* video_resolution_policy) |
| 19 : create_backend_cb_(create_backend_cb), | 20 : create_backend_cb_(create_backend_cb), |
| 20 create_cdm_factory_cb_(create_cdm_factory_cb) {} | 21 create_cdm_factory_cb_(create_cdm_factory_cb), |
| 22 video_resolution_policy_(video_resolution_policy) {} |
| 21 | 23 |
| 22 CastMojoMediaClient::~CastMojoMediaClient() {} | 24 CastMojoMediaClient::~CastMojoMediaClient() {} |
| 23 | 25 |
| 24 std::unique_ptr<::media::Renderer> CastMojoMediaClient::CreateRenderer( | 26 std::unique_ptr<::media::Renderer> CastMojoMediaClient::CreateRenderer( |
| 25 scoped_refptr<base::SingleThreadTaskRunner> media_task_runner, | 27 scoped_refptr<base::SingleThreadTaskRunner> media_task_runner, |
| 26 scoped_refptr<::media::MediaLog> media_log, | 28 scoped_refptr<::media::MediaLog> media_log, |
| 27 const std::string& audio_device_id) { | 29 const std::string& audio_device_id) { |
| 28 return base::MakeUnique<chromecast::media::CastRenderer>( | 30 return base::MakeUnique<chromecast::media::CastRenderer>( |
| 29 create_backend_cb_, std::move(media_task_runner), audio_device_id); | 31 create_backend_cb_, std::move(media_task_runner), audio_device_id, |
| 32 video_resolution_policy_); |
| 30 } | 33 } |
| 31 | 34 |
| 32 std::unique_ptr<::media::CdmFactory> CastMojoMediaClient::CreateCdmFactory( | 35 std::unique_ptr<::media::CdmFactory> CastMojoMediaClient::CreateCdmFactory( |
| 33 ::shell::mojom::InterfaceProvider* interface_provider) { | 36 ::shell::mojom::InterfaceProvider* interface_provider) { |
| 34 return create_cdm_factory_cb_.Run(); | 37 return create_cdm_factory_cb_.Run(); |
| 35 } | 38 } |
| 36 | 39 |
| 37 } // namespace media | 40 } // namespace media |
| 38 } // namespace chromecast | 41 } // namespace chromecast |
| OLD | NEW |