A specialised type of AudioFormatReader that uses a MemoryMappedFile to read directly from an audio file. More...
Public Member Functions | |
const File & | getFile () const noexcept |
Returns the file that is being mapped. | |
bool | mapEntireFile () |
Attempts to map the entire file into memory. | |
virtual bool | mapSectionOfFile (Range< int64 > samplesToMap) |
Attempts to map a section of the file into memory. | |
Range< int64 > | getMappedSection () const noexcept |
Returns the sample range that's currently memory-mapped and available for reading. | |
void | touchSample (int64 sample) const noexcept |
Touches the memory for the given sample, to force it to be loaded into active memory. | |
virtual void | getSample (int64 sampleIndex, float *result) const noexcept=0 |
Returns the samples for all channels at a given sample position. | |
size_t | getNumBytesUsed () const |
Returns the number of bytes currently being mapped. | |
![]() | |
virtual | ~AudioFormatReader () |
Destructor. | |
const String & | getFormatName () const noexcept |
Returns a description of what type of format this is. | |
bool | read (float *const *destChannels, int numDestChannels, int64 startSampleInSource, int numSamplesToRead) |
Reads samples from the stream. | |
bool | read (int *const *destChannels, int numDestChannels, int64 startSampleInSource, int numSamplesToRead, bool fillLeftoverChannelsWithCopies) |
Reads samples from the stream. | |
bool | read (AudioBuffer< float > *buffer, int startSampleInDestBuffer, int numSamples, int64 readerStartSample, bool useReaderLeftChan, bool useReaderRightChan) |
Fills a section of an AudioBuffer from this reader. | |
virtual void | readMaxLevels (int64 startSample, int64 numSamples, Range< float > *results, int numChannelsToRead) |
Finds the highest and lowest sample levels from a section of the audio stream. | |
virtual void | readMaxLevels (int64 startSample, int64 numSamples, float &lowestLeft, float &highestLeft, float &lowestRight, float &highestRight) |
Finds the highest and lowest sample levels from a section of the audio stream. | |
int64 | searchForLevel (int64 startSample, int64 numSamplesToSearch, double magnitudeRangeMinimum, double magnitudeRangeMaximum, int minimumConsecutiveSamples) |
Scans the source looking for a sample whose magnitude is in a specified range. | |
virtual AudioChannelSet | getChannelLayout () |
Get the channel layout of the audio stream. | |
virtual bool | readSamples (int *const *destChannels, int numDestChannels, int startOffsetInDestBuffer, int64 startSampleInFile, int numSamples)=0 |
Subclasses must implement this method to perform the low-level read operation. | |
Protected Member Functions | |
MemoryMappedAudioFormatReader (const File &file, const AudioFormatReader &details, int64 dataChunkStart, int64 dataChunkLength, int bytesPerFrame) | |
Creates an MemoryMappedAudioFormatReader object. | |
int64 | sampleToFilePos (int64 sample) const noexcept |
Converts a sample index to a byte position in the file. | |
int64 | filePosToSample (int64 filePos) const noexcept |
Converts a byte position in the file to a sample index. | |
const void * | sampleToPointer (int64 sample) const noexcept |
Converts a sample index to a pointer to the mapped file memory. | |
template<typename SampleType, typename Endianness> | |
Range< float > | scanMinAndMaxInterleaved (int channel, int64 startSampleInFile, int64 numSamples) const noexcept |
Used by AudioFormatReader subclasses to scan for min/max ranges in interleaved data. | |
![]() | |
AudioFormatReader (InputStream *sourceStream, const String &formatName) | |
Creates an AudioFormatReader object. | |
Protected Attributes | |
File | file |
Range< int64 > | mappedSection |
std::unique_ptr< MemoryMappedFile > | map |
int64 | dataChunkStart |
int64 | dataLength |
int | bytesPerFrame |
Additional Inherited Members | |
![]() | |
double | sampleRate = 0 |
The sample-rate of the stream. | |
unsigned int | bitsPerSample = 0 |
The number of bits per sample, e.g. | |
int64 | lengthInSamples = 0 |
The total number of samples in the audio stream. | |
unsigned int | numChannels = 0 |
The total number of channels in the audio stream. | |
bool | usesFloatingPointData = false |
Indicates whether the data is floating-point or fixed. | |
StringPairArray | metadataValues |
A set of metadata values that the reader has pulled out of the stream. | |
InputStream * | input |
The input stream, for use by subclasses. | |
![]() | |
static void | clearSamplesBeyondAvailableLength (int *const *destChannels, int numDestChannels, int startOffsetInDestBuffer, int64 startSampleInFile, int &numSamples, int64 fileLengthInSamples) |
Used by AudioFormatReader subclasses to clear any parts of the data blocks that lie beyond the end of their available length. | |
A specialised type of AudioFormatReader that uses a MemoryMappedFile to read directly from an audio file.
This allows for incredibly fast random-access to sample data in the mapped region of the file, but not all audio formats support it - see AudioFormat::createMemoryMappedReader().
Note that before reading samples from a MemoryMappedAudioFormatReader, you must first call mapEntireFile() or mapSectionOfFile() to ensure that the region you want to read has been mapped.
|
protected |
Creates an MemoryMappedAudioFormatReader object.
Note that before attempting to read any data, you must call mapEntireFile() or mapSectionOfFile() to ensure that the region you want to read has been mapped.
References AudioFormatReader::AudioFormatReader(), bytesPerFrame, dataChunkStart, and file.
|
noexcept |
Returns the file that is being mapped.
References file.
bool MemoryMappedAudioFormatReader::mapEntireFile | ( | ) |
Attempts to map the entire file into memory.
Attempts to map a section of the file into memory.
Returns the sample range that's currently memory-mapped and available for reading.
References mappedSection.
|
noexcept |
Touches the memory for the given sample, to force it to be loaded into active memory.
|
pure virtualnoexcept |
Returns the samples for all channels at a given sample position.
The result array must be large enough to hold a value for each channel that this reader contains.
size_t MemoryMappedAudioFormatReader::getNumBytesUsed | ( | ) | const |
Returns the number of bytes currently being mapped.
References map.
Converts a sample index to a byte position in the file.
References bytesPerFrame, and dataChunkStart.
Referenced by sampleToPointer().
Converts a byte position in the file to a sample index.
References bytesPerFrame, and dataChunkStart.
|
protectednoexcept |
Converts a sample index to a pointer to the mapped file memory.
References addBytesToPointer(), map, and sampleToFilePos().
Referenced by scanMinAndMaxInterleaved().
|
protectednoexcept |
Used by AudioFormatReader subclasses to scan for min/max ranges in interleaved data.
References addBytesToPointer(), AudioFormatReader::bitsPerSample, AudioFormatReader::numChannels, and sampleToPointer().
|
protected |
Referenced by getFile(), and MemoryMappedAudioFormatReader().
Referenced by getMappedSection().
|
protected |
Referenced by getNumBytesUsed(), and sampleToPointer().
|
protected |
Referenced by filePosToSample(), MemoryMappedAudioFormatReader(), and sampleToFilePos().
|
protected |
|
protected |
Referenced by filePosToSample(), MemoryMappedAudioFormatReader(), and sampleToFilePos().