| Index: media/base/audio_renderer_mixer.h
|
| diff --git a/media/base/audio_renderer_mixer.h b/media/base/audio_renderer_mixer.h
|
| index d293799266440e9885e37e0ef927ddde14c77bf8..75b7d85d6ec8f7e1e74e6f2d60008cbbcd081b6e 100644
|
| --- a/media/base/audio_renderer_mixer.h
|
| +++ b/media/base/audio_renderer_mixer.h
|
| @@ -6,7 +6,6 @@
|
| #define MEDIA_BASE_AUDIO_RENDERER_MIXER_H_
|
|
|
| #include <set>
|
| -#include <vector>
|
|
|
| #include "base/gtest_prod_util.h"
|
| #include "base/synchronization/lock.h"
|
| @@ -38,16 +37,14 @@ class MEDIA_EXPORT AudioRendererMixer
|
| FRIEND_TEST_ALL_PREFIXES(AudioRendererMixerTest, VectorFMACBenchmark);
|
|
|
| // AudioRendererSink::RenderCallback implementation.
|
| - virtual int Render(const std::vector<float*>& audio_data,
|
| - int number_of_frames,
|
| + virtual int Render(AudioBus* audio_bus,
|
| int audio_delay_milliseconds) OVERRIDE;
|
| virtual void OnRenderError() OVERRIDE;
|
|
|
| - // Handles mixing and volume adjustment. Renders |number_of_frames| into
|
| - // |audio_data|. When resampling is necessary, ProvideInput() will be called
|
| + // Handles mixing and volume adjustment. Fully fills |audio_bus| with mixed
|
| + // audio data. When resampling is necessary, ProvideInput() will be called
|
| // by MultiChannelResampler when more data is necessary.
|
| - void ProvideInput(const std::vector<float*>& audio_data,
|
| - int number_of_frames);
|
| + void ProvideInput(AudioBus* audio_bus);
|
|
|
| // Multiply each element of |src| (up to |len|) by |scale| and add to |dest|.
|
| static void VectorFMAC(const float src[], float scale, int len, float dest[]);
|
| @@ -68,8 +65,7 @@ class MEDIA_EXPORT AudioRendererMixer
|
| base::Lock mixer_inputs_lock_;
|
|
|
| // Vector for rendering audio data from each mixer input.
|
| - int mixer_input_audio_data_size_;
|
| - std::vector<float*> mixer_input_audio_data_;
|
| + scoped_ptr<AudioBus> mixer_input_audio_bus_;
|
|
|
| // Handles resampling post-mixing.
|
| scoped_ptr<MultiChannelResampler> resampler_;
|
|
|