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

Side by Side Diff: chromecast/media/service/cast_renderer.cc

Issue 2491043003: MediaResource refactoring to support multiple streams (Closed)
Patch Set: Added a TODO about DemuxerStream enabled/set_enabled methods Created 3 years, 10 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
« no previous file with comments | « chromecast/media/cma/test/frame_segmenter_for_test.cc ('k') | media/base/demuxer_perftest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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/media/service/cast_renderer.h" 5 #include "chromecast/media/service/cast_renderer.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/single_thread_task_runner.h" 8 #include "base/single_thread_task_runner.h"
9 #include "chromecast/base/task_runner_impl.h" 9 #include "chromecast/base/task_runner_impl.h"
10 #include "chromecast/media/base/video_mode_switcher.h" 10 #include "chromecast/media/base/video_mode_switcher.h"
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
98 // Create pipeline. 98 // Create pipeline.
99 MediaPipelineClient pipeline_client; 99 MediaPipelineClient pipeline_client;
100 pipeline_client.error_cb = 100 pipeline_client.error_cb =
101 base::Bind(&CastRenderer::OnError, weak_factory_.GetWeakPtr()); 101 base::Bind(&CastRenderer::OnError, weak_factory_.GetWeakPtr());
102 pipeline_client.buffering_state_cb = base::Bind( 102 pipeline_client.buffering_state_cb = base::Bind(
103 &CastRenderer::OnBufferingStateChange, weak_factory_.GetWeakPtr()); 103 &CastRenderer::OnBufferingStateChange, weak_factory_.GetWeakPtr());
104 pipeline_.reset(new MediaPipelineImpl()); 104 pipeline_.reset(new MediaPipelineImpl());
105 pipeline_->SetClient(pipeline_client); 105 pipeline_->SetClient(pipeline_client);
106 pipeline_->Initialize(load_type, std::move(backend)); 106 pipeline_->Initialize(load_type, std::move(backend));
107 107
108 // TODO(servolk): Implement support for multiple streams. For now use the
109 // first enabled audio and video streams to preserve the existing behavior.
110 ::media::DemuxerStream* audio_stream =
111 media_resource->GetFirstStream(::media::DemuxerStream::AUDIO);
112 ::media::DemuxerStream* video_stream =
113 media_resource->GetFirstStream(::media::DemuxerStream::VIDEO);
114
108 // Initialize audio. 115 // Initialize audio.
109 ::media::DemuxerStream* audio_stream =
110 media_resource->GetStream(::media::DemuxerStream::AUDIO);
111 if (audio_stream) { 116 if (audio_stream) {
112 AvPipelineClient audio_client; 117 AvPipelineClient audio_client;
113 audio_client.wait_for_key_cb = base::Bind( 118 audio_client.wait_for_key_cb = base::Bind(
114 &CastRenderer::OnWaitingForDecryptionKey, weak_factory_.GetWeakPtr()); 119 &CastRenderer::OnWaitingForDecryptionKey, weak_factory_.GetWeakPtr());
115 audio_client.eos_cb = base::Bind(&CastRenderer::OnEnded, 120 audio_client.eos_cb = base::Bind(&CastRenderer::OnEnded,
116 weak_factory_.GetWeakPtr(), STREAM_AUDIO); 121 weak_factory_.GetWeakPtr(), STREAM_AUDIO);
117 audio_client.playback_error_cb = 122 audio_client.playback_error_cb =
118 base::Bind(&CastRenderer::OnError, weak_factory_.GetWeakPtr()); 123 base::Bind(&CastRenderer::OnError, weak_factory_.GetWeakPtr());
119 audio_client.statistics_cb = base::Bind(&CastRenderer::OnStatisticsUpdate, 124 audio_client.statistics_cb = base::Bind(&CastRenderer::OnStatisticsUpdate,
120 weak_factory_.GetWeakPtr()); 125 weak_factory_.GetWeakPtr());
121 std::unique_ptr<CodedFrameProvider> frame_provider(new DemuxerStreamAdapter( 126 std::unique_ptr<CodedFrameProvider> frame_provider(new DemuxerStreamAdapter(
122 task_runner_, media_task_runner_factory_, audio_stream)); 127 task_runner_, media_task_runner_factory_, audio_stream));
123 128
124 ::media::PipelineStatus status = 129 ::media::PipelineStatus status =
125 pipeline_->InitializeAudio(audio_stream->audio_decoder_config(), 130 pipeline_->InitializeAudio(audio_stream->audio_decoder_config(),
126 audio_client, std::move(frame_provider)); 131 audio_client, std::move(frame_provider));
127 if (status != ::media::PIPELINE_OK) { 132 if (status != ::media::PIPELINE_OK) {
128 init_cb.Run(status); 133 init_cb.Run(status);
129 return; 134 return;
130 } 135 }
131 audio_stream->EnableBitstreamConverter(); 136 audio_stream->EnableBitstreamConverter();
132 } 137 }
133 138
134 // Initialize video. 139 // Initialize video.
135 ::media::DemuxerStream* video_stream =
136 media_resource->GetStream(::media::DemuxerStream::VIDEO);
137 if (video_stream) { 140 if (video_stream) {
138 VideoPipelineClient video_client; 141 VideoPipelineClient video_client;
139 video_client.av_pipeline_client.wait_for_key_cb = base::Bind( 142 video_client.av_pipeline_client.wait_for_key_cb = base::Bind(
140 &CastRenderer::OnWaitingForDecryptionKey, weak_factory_.GetWeakPtr()); 143 &CastRenderer::OnWaitingForDecryptionKey, weak_factory_.GetWeakPtr());
141 video_client.av_pipeline_client.eos_cb = base::Bind( 144 video_client.av_pipeline_client.eos_cb = base::Bind(
142 &CastRenderer::OnEnded, weak_factory_.GetWeakPtr(), STREAM_VIDEO); 145 &CastRenderer::OnEnded, weak_factory_.GetWeakPtr(), STREAM_VIDEO);
143 video_client.av_pipeline_client.playback_error_cb = 146 video_client.av_pipeline_client.playback_error_cb =
144 base::Bind(&CastRenderer::OnError, weak_factory_.GetWeakPtr()); 147 base::Bind(&CastRenderer::OnError, weak_factory_.GetWeakPtr());
145 video_client.av_pipeline_client.statistics_cb = base::Bind( 148 video_client.av_pipeline_client.statistics_cb = base::Bind(
146 &CastRenderer::OnStatisticsUpdate, weak_factory_.GetWeakPtr()); 149 &CastRenderer::OnStatisticsUpdate, weak_factory_.GetWeakPtr());
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after
295 } 298 }
296 299
297 void CastRenderer::OnVideoOpacityChange(bool opaque) { 300 void CastRenderer::OnVideoOpacityChange(bool opaque) {
298 DCHECK(task_runner_->BelongsToCurrentThread()); 301 DCHECK(task_runner_->BelongsToCurrentThread());
299 DCHECK(opaque); 302 DCHECK(opaque);
300 client_->OnVideoOpacityChange(opaque); 303 client_->OnVideoOpacityChange(opaque);
301 } 304 }
302 305
303 } // namespace media 306 } // namespace media
304 } // namespace chromecast 307 } // namespace chromecast
OLDNEW
« no previous file with comments | « chromecast/media/cma/test/frame_segmenter_for_test.cc ('k') | media/base/demuxer_perftest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698