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

Side by Side Diff: content/renderer/media/webmediaplayer_impl.cc

Issue 418143005: media: Introduce Renderer interface and RendererImpl. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix media/BUILD.gn Created 6 years, 4 months 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698