| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 CONTENT_RENDERER_MEDIA_MEDIA_STREAM_AUDIO_LEVEL_CALCULATOR_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_AUDIO_LEVEL_CALCULATOR_H_ |
| 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_AUDIO_LEVEL_CALCULATOR_H_ | 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_AUDIO_LEVEL_CALCULATOR_H_ |
| 7 | 7 |
| 8 #include "base/threading/thread_checker.h" | 8 #include "base/threading/thread_checker.h" |
| 9 | 9 |
| 10 namespace content { | 10 namespace content { |
| 11 | 11 |
| 12 // This class is used by the WebRtcLocalAudioTrack to calculate the level of | 12 // This class is used by the WebRtcLocalAudioTrack to calculate the level of |
| 13 // the audio signal. And the audio level will be eventually used by the volume | 13 // the audio signal. And the audio level will be eventually used by the volume |
| 14 // animation UI. | 14 // animation UI. |
| 15 // The algorithm used by this class is the same as how it is done in | 15 // The algorithm used by this class is the same as how it is done in |
| 16 // third_party/webrtc/voice_engine/level_indicator.cc. | 16 // third_party/webrtc/voice_engine/level_indicator.cc. |
| 17 class MediaStreamAudioLevelCalculator { | 17 class MediaStreamAudioLevelCalculator { |
| 18 public: | 18 public: |
| 19 MediaStreamAudioLevelCalculator(); | 19 MediaStreamAudioLevelCalculator(); |
| 20 ~MediaStreamAudioLevelCalculator(); | 20 ~MediaStreamAudioLevelCalculator(); |
| 21 | 21 |
| 22 // Calculates the signal level of the audio data. | 22 // Calculates the signal level of the audio data. |
| 23 // Returns the absolute value of the amplitude of the signal. | 23 // Returns the absolute value of the amplitude of the signal. |
| 24 // |force_report_nonzero_energy| is a flag forcing the calculator to |
| 25 // report nonzero energy even if the energy of the processed audio is zero. |
| 26 // Since |audio_data| is post processed data, and the audio processing might |
| 27 // zero all the audio data, when the caller detects the pre processed data |
| 28 // contain energy, it could pass |force_report_nonzero_energy| as true to |
| 29 // force calculator to report 1 as energy when |audio_data| is all zero. |
| 24 int Calculate(const int16* audio_data, int number_of_channels, | 30 int Calculate(const int16* audio_data, int number_of_channels, |
| 25 int number_of_frames); | 31 int number_of_frames, bool force_report_nonzero_energy); |
| 26 | 32 |
| 27 private: | 33 private: |
| 28 // Used to DCHECK that the constructor and Calculate() are always called on | 34 // Used to DCHECK that the constructor and Calculate() are always called on |
| 29 // the same audio thread. Note that the destructor will be called on a | 35 // the same audio thread. Note that the destructor will be called on a |
| 30 // different thread, which can be either the main render thread or a new | 36 // different thread, which can be either the main render thread or a new |
| 31 // audio thread where WebRtcLocalAudioTrack::OnSetFormat() is called. | 37 // audio thread where WebRtcLocalAudioTrack::OnSetFormat() is called. |
| 32 base::ThreadChecker thread_checker_; | 38 base::ThreadChecker thread_checker_; |
| 33 | 39 |
| 34 int counter_; | 40 int counter_; |
| 35 int max_amplitude_; | 41 int max_amplitude_; |
| 36 int level_; | 42 int level_; |
| 37 }; | 43 }; |
| 38 | 44 |
| 39 } // namespace content | 45 } // namespace content |
| 40 | 46 |
| 41 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_AUDIO_LEVEL_CALCULATOR_H_ | 47 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_AUDIO_LEVEL_CALCULATOR_H_ |
| OLD | NEW |