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

Side by Side Diff: media/base/audio_renderer_mixer.h

Issue 1942803002: Caching AudioOutputDevice instances in mixer manager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: First round of comments addressed Created 4 years, 7 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #ifndef MEDIA_BASE_AUDIO_RENDERER_MIXER_H_ 5 #ifndef MEDIA_BASE_AUDIO_RENDERER_MIXER_H_
6 #define MEDIA_BASE_AUDIO_RENDERER_MIXER_H_ 6 #define MEDIA_BASE_AUDIO_RENDERER_MIXER_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <map> 10 #include <map>
11 #include <memory> 11 #include <memory>
12 #include <string> 12 #include <string>
13 13
14 #include "base/macros.h" 14 #include "base/macros.h"
15 #include "base/synchronization/lock.h" 15 #include "base/synchronization/lock.h"
16 #include "base/time/time.h" 16 #include "base/time/time.h"
17 #include "media/base/audio_converter.h" 17 #include "media/base/audio_converter.h"
18 #include "media/base/audio_renderer_sink.h" 18 #include "media/base/audio_renderer_sink.h"
19 #include "media/base/loopback_audio_converter.h" 19 #include "media/base/loopback_audio_converter.h"
20 20
21 namespace media { 21 namespace media {
22 22
23 // Mixes a set of AudioConverter::InputCallbacks into a single output stream 23 // Mixes a set of AudioConverter::InputCallbacks into a single output stream
24 // which is funneled into a single shared AudioRendererSink; saving a bundle 24 // which is funneled into a single shared AudioRendererSink; saving a bundle
25 // on renderer side resources. 25 // on renderer side resources.
26 class MEDIA_EXPORT AudioRendererMixer 26 class MEDIA_EXPORT AudioRendererMixer
27 : NON_EXPORTED_BASE(public AudioRendererSink::RenderCallback) { 27 : NON_EXPORTED_BASE(public AudioRendererSink::RenderCallback) {
28 public: 28 public:
29 AudioRendererMixer(const AudioParameters& output_params, 29 AudioRendererMixer(const AudioParameters& output_params,
30 const scoped_refptr<AudioRendererSink>& sink); 30 scoped_refptr<media::AudioRendererSink> sink);
DaleCurtis 2016/05/17 19:13:48 Remove media:: this is already in media. Ditto bel
o1ka 2016/05/18 13:15:12 Done.
31 ~AudioRendererMixer() override; 31 ~AudioRendererMixer() override;
32 32
33 // Add or remove a mixer input from mixing; called by AudioRendererMixerInput. 33 // Add or remove a mixer input from mixing; called by AudioRendererMixerInput.
34 void AddMixerInput(const AudioParameters& input_params, 34 void AddMixerInput(const AudioParameters& input_params,
35 AudioConverter::InputCallback* input); 35 AudioConverter::InputCallback* input);
36 void RemoveMixerInput(const AudioParameters& input_params, 36 void RemoveMixerInput(const AudioParameters& input_params,
37 AudioConverter::InputCallback* input); 37 AudioConverter::InputCallback* input);
38 38
39 // Since errors may occur even when no inputs are playing, an error callback 39 // Since errors may occur even when no inputs are playing, an error callback
40 // must be registered separately from adding a mixer input. The same callback 40 // must be registered separately from adding a mixer input. The same callback
41 // must be given to both the functions. 41 // must be given to both the functions.
42 void AddErrorCallback(const base::Closure& error_cb); 42 void AddErrorCallback(const base::Closure& error_cb);
43 void RemoveErrorCallback(const base::Closure& error_cb); 43 void RemoveErrorCallback(const base::Closure& error_cb);
44 44
45 void set_pause_delay_for_testing(base::TimeDelta delay) { 45 void set_pause_delay_for_testing(base::TimeDelta delay) {
46 pause_delay_ = delay; 46 pause_delay_ = delay;
47 } 47 }
48 48
49 OutputDeviceInfo GetOutputDeviceInfo(); 49 OutputDeviceInfo GetOutputDeviceInfo();
50 50
51 const AudioRendererSink* sink_ptr() { return audio_sink_.get(); };
DaleCurtis 2016/05/17 19:13:48 Needed? for_testing?
o1ka 2016/05/18 13:15:12 Needed, I put it into the comment. Maybe you have
52
51 private: 53 private:
52 // Maps input sample rate to the dedicated converter. 54 // Maps input sample rate to the dedicated converter.
53 using AudioConvertersMap = 55 using AudioConvertersMap =
54 std::map<int, std::unique_ptr<LoopbackAudioConverter>>; 56 std::map<int, std::unique_ptr<LoopbackAudioConverter>>;
55 57
56 // AudioRendererSink::RenderCallback implementation. 58 // AudioRendererSink::RenderCallback implementation.
57 int Render(AudioBus* audio_bus, 59 int Render(AudioBus* audio_bus,
58 uint32_t frames_delayed, 60 uint32_t frames_delayed,
59 uint32_t frames_skipped) override; 61 uint32_t frames_skipped) override;
60 void OnRenderError() override; 62 void OnRenderError() override;
61 63
62 bool is_master_sample_rate(int sample_rate) { 64 bool is_master_sample_rate(int sample_rate) {
63 return sample_rate == output_params_.sample_rate(); 65 return sample_rate == output_params_.sample_rate();
64 } 66 }
65 67
66 // Output sink for this mixer. 68 // Output sink for this mixer.
67 scoped_refptr<AudioRendererSink> audio_sink_; 69 const scoped_refptr<media::AudioRendererSink> audio_sink_;
68 70
69 // Output parameters for this mixer. 71 // Output parameters for this mixer.
70 AudioParameters output_params_; 72 const AudioParameters output_params_;
71 73
72 // ---------------[ All variables below protected by |lock_| ]--------------- 74 // ---------------[ All variables below protected by |lock_| ]---------------
73 base::Lock lock_; 75 base::Lock lock_;
74 76
75 // List of error callbacks used by this mixer. 77 // List of error callbacks used by this mixer.
76 typedef std::list<base::Closure> ErrorCallbackList; 78 typedef std::list<base::Closure> ErrorCallbackList;
77 ErrorCallbackList error_callbacks_; 79 ErrorCallbackList error_callbacks_;
78 80
79 // Each of these converters mixes inputs with a given sample rate and 81 // Each of these converters mixes inputs with a given sample rate and
80 // resamples them to the output sample rate. Inputs not reqiuring resampling 82 // resamples them to the output sample rate. Inputs not reqiuring resampling
81 // go directly to |master_converter_|. 83 // go directly to |master_converter_|.
82 AudioConvertersMap converters_; 84 AudioConvertersMap converters_;
83 85
84 // Master converter which mixes all the outputs from |converters_| as well as 86 // Master converter which mixes all the outputs from |converters_| as well as
85 // mixer inputs that are in the output sample rate. 87 // mixer inputs that are in the output sample rate.
86 AudioConverter master_converter_; 88 AudioConverter master_converter_;
87 89
88 // Handles physical stream pause when no inputs are playing. For latency 90 // Handles physical stream pause when no inputs are playing. For latency
89 // reasons we don't want to immediately pause the physical stream. 91 // reasons we don't want to immediately pause the physical stream.
90 base::TimeDelta pause_delay_; 92 base::TimeDelta pause_delay_;
91 base::TimeTicks last_play_time_; 93 base::TimeTicks last_play_time_;
92 bool playing_; 94 bool playing_;
93 95
94 DISALLOW_COPY_AND_ASSIGN(AudioRendererMixer); 96 DISALLOW_COPY_AND_ASSIGN(AudioRendererMixer);
95 }; 97 };
96 98
97 } // namespace media 99 } // namespace media
98 100
99 #endif // MEDIA_BASE_AUDIO_RENDERER_MIXER_H_ 101 #endif // MEDIA_BASE_AUDIO_RENDERER_MIXER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698