OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/renderer/render_frame_impl.h" | 5 #include "content/renderer/render_frame_impl.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <string> | 8 #include <string> |
9 #include <utility> | 9 #include <utility> |
10 #include <vector> | 10 #include <vector> |
(...skipping 266 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
277 #if !defined(ENABLE_MOJO_RENDERER) || \ | 277 #if !defined(ENABLE_MOJO_RENDERER) || \ |
278 BUILDFLAG(ENABLE_RUNTIME_MEDIA_RENDERER_SELECTION) | 278 BUILDFLAG(ENABLE_RUNTIME_MEDIA_RENDERER_SELECTION) |
279 #include "media/renderers/default_renderer_factory.h" // nogncheck | 279 #include "media/renderers/default_renderer_factory.h" // nogncheck |
280 #endif | 280 #endif |
281 | 281 |
282 #if defined(ENABLE_MOJO_AUDIO_DECODER) || defined(ENABLE_MOJO_VIDEO_DECODER) | 282 #if defined(ENABLE_MOJO_AUDIO_DECODER) || defined(ENABLE_MOJO_VIDEO_DECODER) |
283 #include "media/mojo/clients/mojo_decoder_factory.h" // nogncheck | 283 #include "media/mojo/clients/mojo_decoder_factory.h" // nogncheck |
284 #endif | 284 #endif |
285 | 285 |
286 #if BUILDFLAG(ENABLE_MEDIA_REMOTING) | 286 #if BUILDFLAG(ENABLE_MEDIA_REMOTING) |
287 #include "media/remoting/adaptive_renderer_factory.h" // nogncheck | 287 #include "media/remoting/courier_renderer_factory.h" // nogncheck |
288 #include "media/remoting/remoting_cdm_controller.h" // nogncheck | 288 #include "media/remoting/remoting_cdm_controller.h" // nogncheck |
289 #include "media/remoting/remoting_cdm_factory.h" // nogncheck | 289 #include "media/remoting/remoting_cdm_factory.h" // nogncheck |
290 #include "media/remoting/renderer_controller.h" // nogncheck | 290 #include "media/remoting/renderer_controller.h" // nogncheck |
291 #include "media/remoting/shared_session.h" // nogncheck | 291 #include "media/remoting/shared_session.h" // nogncheck |
292 #include "media/remoting/sink_availability_observer.h" // nogncheck | 292 #include "media/remoting/sink_availability_observer.h" // nogncheck |
293 #endif | 293 #endif |
294 | 294 |
295 using base::Time; | 295 using base::Time; |
296 using base::TimeDelta; | 296 using base::TimeDelta; |
297 using blink::WebCachePolicy; | 297 using blink::WebCachePolicy; |
(...skipping 2651 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2949 #else | 2949 #else |
2950 media_renderer_factory = base::MakeUnique<media::DefaultRendererFactory>( | 2950 media_renderer_factory = base::MakeUnique<media::DefaultRendererFactory>( |
2951 media_log.get(), GetDecoderFactory(), | 2951 media_log.get(), GetDecoderFactory(), |
2952 base::Bind(&RenderThreadImpl::GetGpuFactories, | 2952 base::Bind(&RenderThreadImpl::GetGpuFactories, |
2953 base::Unretained(render_thread))); | 2953 base::Unretained(render_thread))); |
2954 | 2954 |
2955 factory_type = media::RendererFactorySelector::FactoryType::DEFAULT; | 2955 factory_type = media::RendererFactorySelector::FactoryType::DEFAULT; |
2956 #endif // defined(ENABLE_MOJO_RENDERER) | 2956 #endif // defined(ENABLE_MOJO_RENDERER) |
2957 | 2957 |
2958 #if BUILDFLAG(ENABLE_MEDIA_REMOTING) | 2958 #if BUILDFLAG(ENABLE_MEDIA_REMOTING) |
2959 media_renderer_factory = | 2959 auto courier_factory = |
2960 base::MakeUnique<media::remoting::AdaptiveRendererFactory>( | 2960 base::MakeUnique<media::remoting::CourierRendererFactory>( |
2961 std::move(media_renderer_factory), std::move(remoting_controller)); | 2961 std::move(remoting_controller)); |
2962 | 2962 |
2963 factory_type = media::RendererFactorySelector::FactoryType::ADAPTIVE; | 2963 // base::Unretained is safe here because |factory_selector| owns |
| 2964 // |courier_factory|. |
| 2965 factory_selector->SetQueryIsRemotingActiveCB( |
| 2966 base::Bind(&media::remoting::CourierRendererFactory::IsRemotingActive, |
| 2967 base::Unretained(courier_factory.get()))); |
| 2968 |
| 2969 factory_selector->AddFactory( |
| 2970 media::RendererFactorySelector::FactoryType::COURIER, |
| 2971 std::move(courier_factory)); |
2964 #endif | 2972 #endif |
2965 | 2973 |
2966 if (!url_index_.get() || url_index_->frame() != frame_) | 2974 if (!url_index_.get() || url_index_->frame() != frame_) |
2967 url_index_.reset(new media::UrlIndex(frame_)); | 2975 url_index_.reset(new media::UrlIndex(frame_)); |
2968 | 2976 |
2969 factory_selector->AddFactory(factory_type, std::move(media_renderer_factory)); | 2977 factory_selector->AddFactory(factory_type, std::move(media_renderer_factory)); |
2970 factory_selector->SetBaseFactoryType(factory_type); | 2978 factory_selector->SetBaseFactoryType(factory_type); |
2971 | 2979 |
2972 std::unique_ptr<media::WebMediaPlayerParams> params( | 2980 std::unique_ptr<media::WebMediaPlayerParams> params( |
2973 new media::WebMediaPlayerParams( | 2981 new media::WebMediaPlayerParams( |
(...skipping 4094 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
7068 policy(info.default_policy), | 7076 policy(info.default_policy), |
7069 replaces_current_history_item(info.replaces_current_history_item), | 7077 replaces_current_history_item(info.replaces_current_history_item), |
7070 history_navigation_in_new_child_frame( | 7078 history_navigation_in_new_child_frame( |
7071 info.is_history_navigation_in_new_child_frame), | 7079 info.is_history_navigation_in_new_child_frame), |
7072 client_redirect(info.is_client_redirect), | 7080 client_redirect(info.is_client_redirect), |
7073 cache_disabled(info.is_cache_disabled), | 7081 cache_disabled(info.is_cache_disabled), |
7074 form(info.form), | 7082 form(info.form), |
7075 source_location(info.source_location) {} | 7083 source_location(info.source_location) {} |
7076 | 7084 |
7077 } // namespace content | 7085 } // namespace content |
OLD | NEW |