diff options
author | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-06 12:55:15 +0200 |
---|---|---|
committer | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-06 12:55:15 +0200 |
commit | 02d658a7ed92bacfdaed587102f0d2e5f6c5dc01 (patch) | |
tree | 1195a0a46b9ce4af470652fecd5c3a3a917c2c58 /src/crepe/api/AudioSource.h | |
parent | b649adda67ed52c2e3bdcd5aa2cb4b9b0954cf16 (diff) | |
parent | b5a5d9b1d4725f3001486c9bbd69263ed0918303 (diff) |
Merge branch 'loek/cleanup' into loek/scripts
Diffstat (limited to 'src/crepe/api/AudioSource.h')
-rw-r--r-- | src/crepe/api/AudioSource.h | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/crepe/api/AudioSource.h b/src/crepe/api/AudioSource.h new file mode 100644 index 0000000..2002d1a --- /dev/null +++ b/src/crepe/api/AudioSource.h @@ -0,0 +1,41 @@ +#pragma once + +#include <memory> + +#include "Asset.h" +#include "Component.h" + +namespace crepe { +class Sound; +} + +namespace crepe::api { + +//! Audio source component +class AudioSource : Component { +public: + AudioSource(std::unique_ptr<Asset> audio_clip); + virtual ~AudioSource() = default; + +public: + //! Start or resume this audio source + void play(); + void play(bool looping); + //! Stop this audio source + void stop(); + +public: + //! Sample file location + std::unique_ptr<Asset> audio_clip; + //! TODO: ????? + bool play_on_awake; + //! Repeat the current audio clip during playback + bool loop; + //! Normalized volume (0.0 - 1.0) + float volume; + +private: + std::unique_ptr<crepe::Sound> _sound; +}; + +} // namespace crepe::api |