2015-11-23 02:08:27 -08:00
|
|
|
#ifndef GAME_SOUND_LOUDNESS_H
|
|
|
|
#define GAME_SOUND_LOUDNESS_H
|
|
|
|
|
2016-06-27 20:54:42 +02:00
|
|
|
#include <deque>
|
2015-11-23 02:08:27 -08:00
|
|
|
#include <vector>
|
|
|
|
|
2014-07-29 00:26:26 +02:00
|
|
|
#include "sound_decoder.hpp"
|
|
|
|
|
|
|
|
namespace MWSound
|
|
|
|
{
|
|
|
|
|
2015-11-23 02:08:27 -08:00
|
|
|
class Sound_Loudness
|
|
|
|
{
|
|
|
|
float mSamplesPerSec;
|
2016-06-27 20:54:42 +02:00
|
|
|
int mSampleRate;
|
|
|
|
ChannelConfig mChannelConfig;
|
|
|
|
SampleType mSampleType;
|
2022-09-22 21:26:05 +03:00
|
|
|
|
2016-06-27 20:54:42 +02:00
|
|
|
// Loudness sample info
|
2015-11-23 02:08:27 -08:00
|
|
|
std::vector<float> mSamples;
|
2022-09-22 21:26:05 +03:00
|
|
|
|
2016-06-27 20:54:42 +02:00
|
|
|
std::deque<char> mQueue;
|
2022-09-22 21:26:05 +03:00
|
|
|
|
2015-11-23 02:08:27 -08:00
|
|
|
public:
|
2016-06-27 20:54:42 +02:00
|
|
|
/**
|
|
|
|
* @param samplesPerSecond How many loudness values per second of audio to compute.
|
|
|
|
* @param sampleRate the sample rate of the sound buffer
|
|
|
|
* @param chans channel layout of the buffer
|
|
|
|
* @param type sample type of the buffer
|
|
|
|
*/
|
|
|
|
Sound_Loudness(float samplesPerSecond, int sampleRate, ChannelConfig chans, SampleType type)
|
|
|
|
: mSamplesPerSec(samplesPerSecond)
|
|
|
|
, mSampleRate(sampleRate)
|
|
|
|
, mChannelConfig(chans)
|
|
|
|
, mSampleType(type)
|
|
|
|
{
|
|
|
|
}
|
2022-09-22 21:26:05 +03:00
|
|
|
|
2015-11-23 02:08:27 -08:00
|
|
|
/**
|
|
|
|
* Analyzes the energy (closely related to loudness) of a sound buffer.
|
|
|
|
* The buffer will be divided into segments according to \a valuesPerSecond,
|
|
|
|
* and for each segment a loudness value in the range of [0,1] will be computed.
|
2016-06-27 20:54:42 +02:00
|
|
|
* The computed values are then added to the mSamples vector. This method should be called continuously
|
|
|
|
* with chunks of audio until the whole audio file is processed.
|
|
|
|
* If the size of \a data does not exactly fit a number of loudness samples, the remainder
|
|
|
|
* will be kept in the mQueue and used in the next call to analyzeLoudness.
|
2015-11-23 02:08:27 -08:00
|
|
|
* @param data the sound buffer to analyze, containing raw samples
|
|
|
|
*/
|
2016-06-27 20:54:42 +02:00
|
|
|
void analyzeLoudness(const std::vector<char>& data);
|
2022-09-22 21:26:05 +03:00
|
|
|
|
2016-06-27 20:54:42 +02:00
|
|
|
/**
|
|
|
|
* Get loudness at a particular time. Before calling this, the stream has to be analyzed up to that point in
|
|
|
|
* time (see analyzeLoudness()).
|
|
|
|
*/
|
2015-11-23 02:08:27 -08:00
|
|
|
float getLoudnessAtTime(float sec) const;
|
|
|
|
};
|
2014-07-29 00:26:26 +02:00
|
|
|
|
|
|
|
}
|
2015-11-23 02:08:27 -08:00
|
|
|
|
|
|
|
#endif /* GAME_SOUND_LOUDNESS_H */
|