41 std::shared_ptr<IReader> m_reader1;
46 std::shared_ptr<IReader> m_reader2;
64 SuperposeReader(std::shared_ptr<IReader> reader1, std::shared_ptr<IReader> reader2);
72 virtual void seek(
int position);
#define AUD_NAMESPACE_END
Closes the audaspace namespace aud.
Definition Audaspace.h:119
float sample_t
Sample type.(float samples)
Definition Audaspace.h:126
#define AUD_NAMESPACE_BEGIN
Opens the audaspace namespace aud.
Definition Audaspace.h:116
#define AUD_API
Used for exporting symbols in the shared library.
Definition Audaspace.h:93
This class is a simple buffer in RAM which is 32 Byte aligned and provides resize functionality.
Definition Buffer.h:34
This class represents a sound source as stream or as buffer which can be read for example by another ...
Definition IReader.h:35
This reader plays two readers with the same specs in parallel.
Definition SuperposeReader.h:36
virtual void seek(int position)
Seeks to a specific position in the source.
virtual int getPosition() const
Returns the position of the source as a sample count value.
virtual Specs getSpecs() const
Returns the specification of the reader.
virtual void read(int &length, bool &eos, sample_t *buffer)
Request to read the next length samples out of the source.
virtual ~SuperposeReader()
Destroys the reader.
virtual bool isSeekable() const
Tells whether the source provides seeking functionality or not.
SuperposeReader(std::shared_ptr< IReader > reader1, std::shared_ptr< IReader > reader2)
Creates a new superpose reader.
virtual int getLength() const
Returns an approximated length of the source in samples.
Specification of a sound source.
Definition Specification.h:119