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