Audaspace 1.5.0
A high level audio library.
Loading...
Searching...
No Matches
StreamBuffer.h
Go to the documentation of this file.
1/*******************************************************************************
2 * Copyright 2009-2016 Jörg Müller
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 ******************************************************************************/
16
17#pragma once
18
25#include "ISound.h"
27
29
30class Buffer;
31
37{
38private:
42 std::shared_ptr<Buffer> m_buffer;
43
47 Specs m_specs;
48
49 // delete copy constructor and operator=
50 StreamBuffer(const StreamBuffer&) = delete;
51 StreamBuffer& operator=(const StreamBuffer&) = delete;
52
53public:
60 StreamBuffer(std::shared_ptr<ISound> sound);
61
68 StreamBuffer(std::shared_ptr<Buffer> buffer, Specs specs);
69
74 std::shared_ptr<Buffer> getBuffer();
75
81
82 virtual std::shared_ptr<IReader> createReader();
83};
84
#define AUD_NAMESPACE_END
Closes the audaspace namespace aud.
Definition Audaspace.h:119
#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
The ISound interface.
Defines all important macros and basic data structures for stream format descriptions.
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 type of sound source and saves the necessary values for it.
Definition ISound.h:40
This sound creates a buffer out of a reader.
Definition StreamBuffer.h:37
StreamBuffer(std::shared_ptr< ISound > sound)
Creates the sound and reads the reader created by the sound supplied to the buffer.
StreamBuffer(std::shared_ptr< Buffer > buffer, Specs specs)
Creates the sound from an preexisting buffer.
std::shared_ptr< Buffer > getBuffer()
Returns the buffer to be streamed.
virtual std::shared_ptr< IReader > createReader()
Creates a reader for playback of the sound source.
Specs getSpecs()
Returns the specification of the buffer.
Specification of a sound source.
Definition Specification.h:119