Provide read access to sound files. More...
#include <SFML/Audio/InputSoundFile.hpp>
Public Member Functions | |
InputSoundFile () | |
Default constructor. | |
~InputSoundFile () | |
Destructor. | |
bool | openFromFile (const std::string &filename) |
Open a sound file from the disk for reading. | |
bool | openFromMemory (const void *data, std::size_t sizeInBytes) |
Open a sound file in memory for reading. | |
bool | openFromStream (InputStream &stream) |
Open a sound file from a custom stream for reading. | |
Uint64 | getSampleCount () const |
Get the total number of audio samples in the file. | |
unsigned int | getChannelCount () const |
Get the number of channels used by the sound. | |
unsigned int | getSampleRate () const |
Get the sample rate of the sound. | |
Time | getDuration () const |
Get the total duration of the sound file. | |
Time | getTimeOffset () const |
Get the read offset of the file in time. | |
Uint64 | getSampleOffset () const |
Get the read offset of the file in samples. | |
void | seek (Uint64 sampleOffset) |
Change the current read position to the given sample offset. | |
void | seek (Time timeOffset) |
Change the current read position to the given time offset. | |
Uint64 | read (Int16 *samples, Uint64 maxCount) |
Read audio samples from the open file. | |
void | close () |
Close the current file. | |
Provide read access to sound files.
This class decodes audio samples from a sound file.
It is used internally by higher-level classes such as sf::SoundBuffer and sf::Music, but can also be useful if you want to process or analyze audio files without playing them, or if you want to implement your own version of sf::Music with more specific features.
Usage example:
Definition at line 47 of file InputSoundFile.hpp.
sf::InputSoundFile::InputSoundFile | ( | ) |
Default constructor.
sf::InputSoundFile::~InputSoundFile | ( | ) |
Destructor.
void sf::InputSoundFile::close | ( | ) |
Close the current file.
unsigned int sf::InputSoundFile::getChannelCount | ( | ) | const |
Get the number of channels used by the sound.
Time sf::InputSoundFile::getDuration | ( | ) | const |
Get the total duration of the sound file.
This function is provided for convenience, the duration is deduced from the other sound file attributes.
Uint64 sf::InputSoundFile::getSampleCount | ( | ) | const |
Get the total number of audio samples in the file.
Uint64 sf::InputSoundFile::getSampleOffset | ( | ) | const |
Get the read offset of the file in samples.
unsigned int sf::InputSoundFile::getSampleRate | ( | ) | const |
Get the sample rate of the sound.
Time sf::InputSoundFile::getTimeOffset | ( | ) | const |
Get the read offset of the file in time.
bool sf::InputSoundFile::openFromFile | ( | const std::string & | filename | ) |
Open a sound file from the disk for reading.
The supported audio formats are: WAV (PCM only), OGG/Vorbis, FLAC, MP3. The supported sample sizes for FLAC and WAV are 8, 16, 24 and 32 bit.
Because of minimp3_ex limitation, for MP3 files with big (>16kb) APEv2 tag, it may not be properly removed, tag data will be treated as MP3 data and there is a low chance of garbage decoded at the end of file. See also: https://github.com/lieff/minimp3
filename | Path of the sound file to load |
bool sf::InputSoundFile::openFromMemory | ( | const void * | data, |
std::size_t | sizeInBytes ) |
Open a sound file in memory for reading.
The supported audio formats are: WAV (PCM only), OGG/Vorbis, FLAC. The supported sample sizes for FLAC and WAV are 8, 16, 24 and 32 bit.
data | Pointer to the file data in memory |
sizeInBytes | Size of the data to load, in bytes |
bool sf::InputSoundFile::openFromStream | ( | InputStream & | stream | ) |
Open a sound file from a custom stream for reading.
The supported audio formats are: WAV (PCM only), OGG/Vorbis, FLAC. The supported sample sizes for FLAC and WAV are 8, 16, 24 and 32 bit.
stream | Source stream to read from |
Uint64 sf::InputSoundFile::read | ( | Int16 * | samples, |
Uint64 | maxCount ) |
Read audio samples from the open file.
samples | Pointer to the sample array to fill |
maxCount | Maximum number of samples to read |
void sf::InputSoundFile::seek | ( | Time | timeOffset | ) |
Change the current read position to the given time offset.
Using a time offset is handy but imprecise. If you need an accurate result, consider using the overload which takes a sample offset.
If the given time exceeds to total duration, this function jumps to the end of the sound file.
timeOffset | Time to jump to, relative to the beginning |
void sf::InputSoundFile::seek | ( | Uint64 | sampleOffset | ) |
Change the current read position to the given sample offset.
This function takes a sample offset to provide maximum precision. If you need to jump to a given time, use the other overload.
The sample offset takes the channels into account. If you have a time offset instead, you can easily find the corresponding sample offset with the following formula: timeInSeconds * sampleRate * channelCount
If the given offset exceeds to total number of samples, this function jumps to the end of the sound file.
sampleOffset | Index of the sample to jump to, relative to the beginning |