forked from mirror/openmw-tes3mp
Load sound loudness and store it with the Sound_Buffer
Still not used for say yet, thoughopenmw-38
parent
f4c22ec49e
commit
495e138907
@ -1,20 +1,38 @@
|
|||||||
|
#ifndef GAME_SOUND_LOUDNESS_H
|
||||||
|
#define GAME_SOUND_LOUDNESS_H
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include "sound_decoder.hpp"
|
#include "sound_decoder.hpp"
|
||||||
|
|
||||||
namespace MWSound
|
namespace MWSound
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
class Sound_Loudness {
|
||||||
* Analyzes the energy (closely related to loudness) of a sound buffer.
|
// Loudness sample info
|
||||||
* The buffer will be divided into segments according to \a valuesPerSecond,
|
float mSamplesPerSec;
|
||||||
* and for each segment a loudness value in the range of [0,1] will be computed.
|
std::vector<float> mSamples;
|
||||||
* @param data the sound buffer to analyze, containing raw samples
|
|
||||||
* @param sampleRate the sample rate of the sound buffer
|
public:
|
||||||
* @param chans channel layout of the buffer
|
Sound_Loudness() : mSamplesPerSec(0.0f) { }
|
||||||
* @param type sample type of the buffer
|
|
||||||
* @param out Will contain the output loudness values.
|
/**
|
||||||
* @param valuesPerSecond How many loudness values per second of audio to compute.
|
* Analyzes the energy (closely related to loudness) of a sound buffer.
|
||||||
*/
|
* The buffer will be divided into segments according to \a valuesPerSecond,
|
||||||
void analyzeLoudness (const std::vector<char>& data, int sampleRate, ChannelConfig chans, SampleType type,
|
* and for each segment a loudness value in the range of [0,1] will be computed.
|
||||||
std::vector<float>& out, float valuesPerSecond);
|
* @param data the sound buffer to analyze, containing raw samples
|
||||||
|
* @param sampleRate the sample rate of the sound buffer
|
||||||
|
* @param chans channel layout of the buffer
|
||||||
|
* @param type sample type of the buffer
|
||||||
|
* @param valuesPerSecond How many loudness values per second of audio to compute.
|
||||||
|
*/
|
||||||
|
void analyzeLoudness(const std::vector<char>& data, int sampleRate,
|
||||||
|
ChannelConfig chans, SampleType type,
|
||||||
|
float valuesPerSecond);
|
||||||
|
|
||||||
|
float getLoudnessAtTime(float sec) const;
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* GAME_SOUND_LOUDNESS_H */
|
||||||
|
@ -1,23 +0,0 @@
|
|||||||
#include "sound.hpp"
|
|
||||||
|
|
||||||
namespace MWSound
|
|
||||||
{
|
|
||||||
|
|
||||||
float Sound::getCurrentLoudness()
|
|
||||||
{
|
|
||||||
if (mLoudnessVector.empty())
|
|
||||||
return 0.f;
|
|
||||||
int index = static_cast<int>(getTimeOffset() * mLoudnessFPS);
|
|
||||||
|
|
||||||
index = std::max(0, std::min(index, int(mLoudnessVector.size()-1)));
|
|
||||||
|
|
||||||
return mLoudnessVector[index];
|
|
||||||
}
|
|
||||||
|
|
||||||
void Sound::setLoudnessVector(const std::vector<float> &loudnessVector, float loudnessFPS)
|
|
||||||
{
|
|
||||||
mLoudnessVector = loudnessVector;
|
|
||||||
mLoudnessFPS = loudnessFPS;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue