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/media/webmediaplayer_impl.h" | 5 #include "content/renderer/media/webmediaplayer_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <limits> | 8 #include <limits> |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
51 #include "media/base/text_renderer.h" | 51 #include "media/base/text_renderer.h" |
52 #include "media/base/video_frame.h" | 52 #include "media/base/video_frame.h" |
53 #include "media/filters/audio_renderer_impl.h" | 53 #include "media/filters/audio_renderer_impl.h" |
54 #include "media/filters/chunk_demuxer.h" | 54 #include "media/filters/chunk_demuxer.h" |
55 #include "media/filters/ffmpeg_audio_decoder.h" | 55 #include "media/filters/ffmpeg_audio_decoder.h" |
56 #include "media/filters/ffmpeg_demuxer.h" | 56 #include "media/filters/ffmpeg_demuxer.h" |
57 #include "media/filters/ffmpeg_video_decoder.h" | 57 #include "media/filters/ffmpeg_video_decoder.h" |
58 #include "media/filters/gpu_video_accelerator_factories.h" | 58 #include "media/filters/gpu_video_accelerator_factories.h" |
59 #include "media/filters/gpu_video_decoder.h" | 59 #include "media/filters/gpu_video_decoder.h" |
60 #include "media/filters/opus_audio_decoder.h" | 60 #include "media/filters/opus_audio_decoder.h" |
61 #include "media/filters/renderer_impl.h" | |
61 #include "media/filters/video_renderer_impl.h" | 62 #include "media/filters/video_renderer_impl.h" |
62 #include "media/filters/vpx_video_decoder.h" | 63 #include "media/filters/vpx_video_decoder.h" |
63 #include "third_party/WebKit/public/platform/WebContentDecryptionModule.h" | 64 #include "third_party/WebKit/public/platform/WebContentDecryptionModule.h" |
64 #include "third_party/WebKit/public/platform/WebMediaSource.h" | 65 #include "third_party/WebKit/public/platform/WebMediaSource.h" |
65 #include "third_party/WebKit/public/platform/WebRect.h" | 66 #include "third_party/WebKit/public/platform/WebRect.h" |
66 #include "third_party/WebKit/public/platform/WebSize.h" | 67 #include "third_party/WebKit/public/platform/WebSize.h" |
67 #include "third_party/WebKit/public/platform/WebString.h" | 68 #include "third_party/WebKit/public/platform/WebString.h" |
68 #include "third_party/WebKit/public/platform/WebURL.h" | 69 #include "third_party/WebKit/public/platform/WebURL.h" |
69 #include "third_party/WebKit/public/web/WebDocument.h" | 70 #include "third_party/WebKit/public/web/WebDocument.h" |
70 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 71 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
(...skipping 1024 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1095 if (!is_downloading && network_state_ == WebMediaPlayer::NetworkStateLoading) | 1096 if (!is_downloading && network_state_ == WebMediaPlayer::NetworkStateLoading) |
1096 SetNetworkState(WebMediaPlayer::NetworkStateIdle); | 1097 SetNetworkState(WebMediaPlayer::NetworkStateIdle); |
1097 else if (is_downloading && network_state_ == WebMediaPlayer::NetworkStateIdle) | 1098 else if (is_downloading && network_state_ == WebMediaPlayer::NetworkStateIdle) |
1098 SetNetworkState(WebMediaPlayer::NetworkStateLoading); | 1099 SetNetworkState(WebMediaPlayer::NetworkStateLoading); |
1099 media_log_->AddEvent( | 1100 media_log_->AddEvent( |
1100 media_log_->CreateBooleanEvent( | 1101 media_log_->CreateBooleanEvent( |
1101 media::MediaLogEvent::NETWORK_ACTIVITY_SET, | 1102 media::MediaLogEvent::NETWORK_ACTIVITY_SET, |
1102 "is_downloading_data", is_downloading)); | 1103 "is_downloading_data", is_downloading)); |
1103 } | 1104 } |
1104 | 1105 |
1106 // TODO(xhwang): Move this to a factory class so that we can create different | |
1107 // renderers. | |
1108 scoped_ptr<media::Renderer> WebMediaPlayerImpl::CreateRenderer() { | |
1109 media::SetDecryptorReadyCB set_decryptor_ready_cb = | |
1110 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::SetDecryptorReadyCB); | |
1111 | |
1112 // Create our audio decoders and renderer. | |
1113 ScopedVector<media::AudioDecoder> audio_decoders; | |
1114 | |
1115 media::LogCB log_cb = base::Bind(&LogMediaSourceError, media_log_); | |
1116 audio_decoders.push_back(new media::FFmpegAudioDecoder(media_loop_, log_cb)); | |
1117 audio_decoders.push_back(new media::OpusAudioDecoder(media_loop_)); | |
1118 | |
1119 scoped_ptr<media::AudioRenderer> audio_renderer(new media::AudioRendererImpl( | |
1120 media_loop_, | |
1121 audio_source_provider_.get(), | |
1122 audio_decoders.Pass(), | |
1123 set_decryptor_ready_cb, | |
1124 RenderThreadImpl::current()->GetAudioHardwareConfig())); | |
1125 | |
1126 // Create our video decoders and renderer. | |
1127 ScopedVector<media::VideoDecoder> video_decoders; | |
1128 | |
1129 if (gpu_factories_.get()) { | |
1130 video_decoders.push_back( | |
1131 new media::GpuVideoDecoder(gpu_factories_, media_log_)); | |
1132 } | |
1133 | |
1134 #if !defined(MEDIA_DISABLE_LIBVPX) | |
1135 video_decoders.push_back(new media::VpxVideoDecoder(media_loop_)); | |
1136 #endif // !defined(MEDIA_DISABLE_LIBVPX) | |
1137 | |
1138 video_decoders.push_back(new media::FFmpegVideoDecoder(media_loop_)); | |
1139 | |
1140 scoped_ptr<media::VideoRenderer> video_renderer( | |
1141 new media::VideoRendererImpl( | |
1142 media_loop_, | |
1143 video_decoders.Pass(), | |
1144 set_decryptor_ready_cb, | |
1145 base::Bind(&WebMediaPlayerImpl::FrameReady, base::Unretained(this)), | |
1146 true)); | |
1147 | |
1148 // Create renderer. | |
1149 scoped_ptr<media::Renderer> renderer(new media::RendererImpl( | |
1150 media_loop_, | |
1151 demuxer_.get(), | |
1152 audio_renderer.Pass(), | |
1153 video_renderer.Pass())); | |
1154 | |
1155 return renderer.Pass(); | |
damienv1
2014/08/06 21:43:47
nit: |renderer| not really needed here:
return sc
xhwang
2014/08/07 05:46:49
Will do.
xhwang
2014/08/22 19:11:30
Done.
| |
1156 } | |
1157 | |
1105 void WebMediaPlayerImpl::StartPipeline() { | 1158 void WebMediaPlayerImpl::StartPipeline() { |
1106 DCHECK(main_loop_->BelongsToCurrentThread()); | 1159 DCHECK(main_loop_->BelongsToCurrentThread()); |
1107 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); | 1160 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
1108 | 1161 |
1109 // Keep track if this is a MSE or non-MSE playback. | 1162 // Keep track if this is a MSE or non-MSE playback. |
1110 UMA_HISTOGRAM_BOOLEAN("Media.MSE.Playback", | 1163 UMA_HISTOGRAM_BOOLEAN("Media.MSE.Playback", |
1111 (load_type_ == LoadTypeMediaSource)); | 1164 (load_type_ == LoadTypeMediaSource)); |
1112 | 1165 |
1113 media::LogCB mse_log_cb; | 1166 media::LogCB mse_log_cb; |
1114 | 1167 |
(...skipping 16 matching lines...) Expand all Loading... | |
1131 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::OnDemuxerOpened), | 1184 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::OnDemuxerOpened), |
1132 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::OnNeedKey), | 1185 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::OnNeedKey), |
1133 mse_log_cb, | 1186 mse_log_cb, |
1134 true); | 1187 true); |
1135 demuxer_.reset(chunk_demuxer_); | 1188 demuxer_.reset(chunk_demuxer_); |
1136 } | 1189 } |
1137 | 1190 |
1138 scoped_ptr<media::FilterCollection> filter_collection( | 1191 scoped_ptr<media::FilterCollection> filter_collection( |
1139 new media::FilterCollection()); | 1192 new media::FilterCollection()); |
1140 filter_collection->SetDemuxer(demuxer_.get()); | 1193 filter_collection->SetDemuxer(demuxer_.get()); |
1141 | 1194 filter_collection->SetRenderer(CreateRenderer()); |
1142 media::SetDecryptorReadyCB set_decryptor_ready_cb = | |
1143 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::SetDecryptorReadyCB); | |
1144 | |
1145 // Create our audio decoders and renderer. | |
1146 ScopedVector<media::AudioDecoder> audio_decoders; | |
1147 audio_decoders.push_back(new media::FFmpegAudioDecoder(media_loop_, | |
1148 mse_log_cb)); | |
1149 audio_decoders.push_back(new media::OpusAudioDecoder(media_loop_)); | |
1150 | |
1151 scoped_ptr<media::AudioRenderer> audio_renderer(new media::AudioRendererImpl( | |
1152 media_loop_, | |
1153 audio_source_provider_.get(), | |
1154 audio_decoders.Pass(), | |
1155 set_decryptor_ready_cb, | |
1156 RenderThreadImpl::current()->GetAudioHardwareConfig())); | |
1157 filter_collection->SetAudioRenderer(audio_renderer.Pass()); | |
1158 | |
1159 // Create our video decoders and renderer. | |
1160 ScopedVector<media::VideoDecoder> video_decoders; | |
1161 | |
1162 if (gpu_factories_.get()) { | |
1163 video_decoders.push_back( | |
1164 new media::GpuVideoDecoder(gpu_factories_, media_log_)); | |
1165 } | |
1166 | |
1167 #if !defined(MEDIA_DISABLE_LIBVPX) | |
1168 video_decoders.push_back(new media::VpxVideoDecoder(media_loop_)); | |
1169 #endif // !defined(MEDIA_DISABLE_LIBVPX) | |
1170 | |
1171 video_decoders.push_back(new media::FFmpegVideoDecoder(media_loop_)); | |
1172 | |
1173 scoped_ptr<media::VideoRenderer> video_renderer( | |
1174 new media::VideoRendererImpl( | |
1175 media_loop_, | |
1176 video_decoders.Pass(), | |
1177 set_decryptor_ready_cb, | |
1178 base::Bind(&WebMediaPlayerImpl::FrameReady, base::Unretained(this)), | |
1179 true)); | |
1180 filter_collection->SetVideoRenderer(video_renderer.Pass()); | |
1181 | 1195 |
1182 if (cmd_line->HasSwitch(switches::kEnableInbandTextTracks)) { | 1196 if (cmd_line->HasSwitch(switches::kEnableInbandTextTracks)) { |
1183 scoped_ptr<media::TextRenderer> text_renderer( | 1197 scoped_ptr<media::TextRenderer> text_renderer( |
1184 new media::TextRenderer( | 1198 new media::TextRenderer( |
1185 media_loop_, | 1199 media_loop_, |
1186 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::OnAddTextTrack))); | 1200 BIND_TO_RENDER_LOOP(&WebMediaPlayerImpl::OnAddTextTrack))); |
1187 | 1201 |
1188 filter_collection->SetTextRenderer(text_renderer.Pass()); | 1202 filter_collection->SetTextRenderer(text_renderer.Pass()); |
1189 } | 1203 } |
1190 | 1204 |
(...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1337 compositor_task_runner_->PostTask(FROM_HERE, | 1351 compositor_task_runner_->PostTask(FROM_HERE, |
1338 base::Bind(&GetCurrentFrameAndSignal, | 1352 base::Bind(&GetCurrentFrameAndSignal, |
1339 base::Unretained(compositor_), | 1353 base::Unretained(compositor_), |
1340 &video_frame, | 1354 &video_frame, |
1341 &event)); | 1355 &event)); |
1342 event.Wait(); | 1356 event.Wait(); |
1343 return video_frame; | 1357 return video_frame; |
1344 } | 1358 } |
1345 | 1359 |
1346 } // namespace content | 1360 } // namespace content |
OLD | NEW |