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

Side by Side Diff: chromecast/media/cma/backend/media_pipeline_backend_manager.cc

Issue 1858803002: [chromecast] Pass media task runner to MediaPipelineBackendManager. (Closed) Base URL: https://chromium.googlesource.com/chromium/src@master
Patch Set: Created 4 years, 8 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
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/cma/backend/media_pipeline_backend_manager.h" 5 #include "chromecast/media/cma/backend/media_pipeline_backend_manager.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/bind.h"
10 #include "base/lazy_instance.h"
11 #include "base/location.h"
12 #include "chromecast/media/base/media_message_loop.h"
13 #include "chromecast/media/cma/backend/media_pipeline_backend_wrapper.h" 9 #include "chromecast/media/cma/backend/media_pipeline_backend_wrapper.h"
14 #include "chromecast/public/cast_media_shlib.h" 10 #include "chromecast/public/cast_media_shlib.h"
15 11
16 namespace chromecast { 12 namespace chromecast {
17 namespace media { 13 namespace media {
18 14
19 namespace { 15 MediaPipelineBackendManager::MediaPipelineBackendManager(
16 scoped_refptr<base::SingleThreadTaskRunner> media_task_runner)
17 : media_task_runner_(std::move(media_task_runner)) {
18 }
20 19
21 base::LazyInstance<MediaPipelineBackendManager> g_instance = 20 MediaPipelineBackendManager::~MediaPipelineBackendManager() {
22 LAZY_INSTANCE_INITIALIZER; 21 }
23 22
24 } // namespace 23 scoped_ptr<MediaPipelineBackend>
25 24 MediaPipelineBackendManager::CreateMediaPipelineBackend(
26 // static
27 MediaPipelineBackend* MediaPipelineBackendManager::CreateMediaPipelineBackend(
28 const media::MediaPipelineDeviceParams& params) { 25 const media::MediaPipelineDeviceParams& params) {
29 DCHECK(MediaMessageLoop::GetTaskRunner()->BelongsToCurrentThread()); 26 DCHECK(media_task_runner_->BelongsToCurrentThread());
30 return CreateMediaPipelineBackend(params, 0); 27 return CreateMediaPipelineBackend(params, 0);
31 } 28 }
32 29
33 // static 30 scoped_ptr<MediaPipelineBackend>
34 MediaPipelineBackend* MediaPipelineBackendManager::CreateMediaPipelineBackend( 31 MediaPipelineBackendManager::CreateMediaPipelineBackend(
35 const media::MediaPipelineDeviceParams& params, 32 const media::MediaPipelineDeviceParams& params,
36 int stream_type) { 33 int stream_type) {
37 DCHECK(MediaMessageLoop::GetTaskRunner()->BelongsToCurrentThread()); 34 DCHECK(media_task_runner_->BelongsToCurrentThread());
38 MediaPipelineBackendManager* backend_manager = Get(); 35 scoped_ptr<MediaPipelineBackend> backend_ptr(new MediaPipelineBackendWrapper(
39 MediaPipelineBackendWrapper* backend_ptr = new MediaPipelineBackendWrapper( 36 make_scoped_ptr(
40 media::CastMediaShlib::CreateMediaPipelineBackend(params), stream_type, 37 media::CastMediaShlib::CreateMediaPipelineBackend(params)),
41 backend_manager->GetVolumeMultiplier(stream_type)); 38 stream_type, GetVolumeMultiplier(stream_type), this));
42 backend_manager->media_pipeline_backends_.push_back(backend_ptr); 39 media_pipeline_backends_.push_back(backend_ptr.get());
43 return backend_ptr; 40 return backend_ptr;
44 } 41 }
45 42
46 // static
47 void MediaPipelineBackendManager::OnMediaPipelineBackendDestroyed( 43 void MediaPipelineBackendManager::OnMediaPipelineBackendDestroyed(
48 const MediaPipelineBackend* backend) { 44 const MediaPipelineBackend* backend) {
49 DCHECK(MediaMessageLoop::GetTaskRunner()->BelongsToCurrentThread()); 45 DCHECK(media_task_runner_->BelongsToCurrentThread());
50 MediaPipelineBackendManager* backend_manager = Get(); 46 media_pipeline_backends_.erase(
51 backend_manager->media_pipeline_backends_.erase( 47 std::remove(media_pipeline_backends_.begin(),
52 std::remove(backend_manager->media_pipeline_backends_.begin(), 48 media_pipeline_backends_.end(), backend),
53 backend_manager->media_pipeline_backends_.end(), backend), 49 media_pipeline_backends_.end());
54 backend_manager->media_pipeline_backends_.end());
55 } 50 }
56 51
57 // static
58 void MediaPipelineBackendManager::SetVolumeMultiplier(int stream_type, 52 void MediaPipelineBackendManager::SetVolumeMultiplier(int stream_type,
59 float volume) { 53 float volume) {
60 DCHECK(MediaMessageLoop::GetTaskRunner()->BelongsToCurrentThread()); 54 DCHECK(media_task_runner_->BelongsToCurrentThread());
61 MediaPipelineBackendManager* backend_manager = Get();
62 volume = std::max(0.0f, std::min(volume, 1.0f)); 55 volume = std::max(0.0f, std::min(volume, 1.0f));
63 backend_manager->volume_by_stream_type_[stream_type] = volume; 56 volume_by_stream_type_[stream_type] = volume;
64 57
65 // Set volume for each open media pipeline backends. 58 // Set volume for each open media pipeline backends.
66 for (auto it = backend_manager->media_pipeline_backends_.begin(); 59 for (auto it = media_pipeline_backends_.begin();
67 it != backend_manager->media_pipeline_backends_.end(); it++) { 60 it != media_pipeline_backends_.end(); it++) {
68 MediaPipelineBackendWrapper* wrapper = 61 MediaPipelineBackendWrapper* wrapper =
69 static_cast<MediaPipelineBackendWrapper*>(*it); 62 static_cast<MediaPipelineBackendWrapper*>(*it);
70 if (wrapper->GetStreamType() == stream_type) 63 if (wrapper->GetStreamType() == stream_type)
71 wrapper->SetStreamTypeVolume(volume); 64 wrapper->SetStreamTypeVolume(volume);
72 } 65 }
73 } 66 }
74 67
75 // static
76 MediaPipelineBackendManager* MediaPipelineBackendManager::Get() {
77 return g_instance.Pointer();
78 }
79
80 MediaPipelineBackendManager::MediaPipelineBackendManager() {
81 }
82
83 MediaPipelineBackendManager::~MediaPipelineBackendManager() {
84 }
85
86 float MediaPipelineBackendManager::GetVolumeMultiplier(int stream_type) { 68 float MediaPipelineBackendManager::GetVolumeMultiplier(int stream_type) {
87 DCHECK(MediaMessageLoop::GetTaskRunner()->BelongsToCurrentThread()); 69 DCHECK(media_task_runner_->BelongsToCurrentThread());
88 MediaPipelineBackendManager* backend_manager = Get(); 70 auto it = volume_by_stream_type_.find(stream_type);
89 auto it = backend_manager->volume_by_stream_type_.find(stream_type); 71 if (it == volume_by_stream_type_.end()) {
90 if (it == backend_manager->volume_by_stream_type_.end()) {
91 return 1.0; 72 return 1.0;
92 } else { 73 } else {
93 return it->second; 74 return it->second;
94 } 75 }
95 } 76 }
96 77
97 } // namespace media 78 } // namespace media
98 } // namespace chromecast 79 } // namespace chromecast
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698