aboutsummaryrefslogtreecommitdiffstats
path: root/src/audio.cpp
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2019-10-01 20:50:28 -0400
committerClyne Sullivan <clyne@bitgloo.com>2019-10-01 20:50:28 -0400
commitaf39f2e08b0503db723ae707a5c7278d8c85f812 (patch)
treead6ab6e51e1a7e30d72a28e2bac51b210fd22f6c /src/audio.cpp
parentbebc6e955114a0907c43df9a9c00f22b1f743446 (diff)
Audio component loading, getting ready to play
Diffstat (limited to 'src/audio.cpp')
-rw-r--r--src/audio.cpp25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/audio.cpp b/src/audio.cpp
index 975cfce..8bb1413 100644
--- a/src/audio.cpp
+++ b/src/audio.cpp
@@ -20,13 +20,19 @@
#include "audio.hpp"
+#include <AL/alut.h>
+#include <iostream>
+
AudioSystem::AudioSystem(void) :
device(nullptr, [](ALCdevice *d) { alcCloseDevice(d); }),
context(nullptr, [](ALCcontext *c) { alcDestroyContext(c); }) {}
AudioSystem::~AudioSystem(void)
{
+ alutExit();
+
// Delete context before device
+ alcMakeContextCurrent(nullptr);
context.reset();
device.reset();
}
@@ -46,6 +52,9 @@ void AudioSystem::configure([[maybe_unused]] entityx::EntityManager& entities,
context.reset(alcCreateContext(device.get(), nullptr));
if (!alcMakeContextCurrent(context.get()))
return; // TODO Another uh oh
+
+ if (alutInitWithoutContext(nullptr, nullptr) != AL_TRUE)
+ return; // TODO Third uh oh
}
void AudioSystem::update([[maybe_unused]] entityx::EntityManager& entities,
@@ -56,10 +65,26 @@ void AudioSystem::update([[maybe_unused]] entityx::EntityManager& entities,
void AudioSystem::receive(const entityx::ComponentAddedEvent<Audio>& cae)
{
alGenSources(1, const_cast<ALuint*>(&cae.component->source));
+ //alGenBuffers(1, const_cast<ALuint*>(&cae.component->buffer));
+
+ if (auto buf = alutCreateBufferFromFile(cae.component->fileName.c_str());
+ buf != AL_NONE) {
+ const_cast<Audio*>(cae.component.get())->buffer = buf;
+ alSourcei(cae.component->source, AL_BUFFER, buf);
+
+ std::cout << "Loaded audio: " << cae.component->fileName << std::endl;
+ }
}
void AudioSystem::receive(const entityx::ComponentRemovedEvent<Audio>& cae)
{
+ alDeleteBuffers(1, &cae.component->buffer);
alDeleteSources(1, &cae.component->source);
}
+void AudioSystem::playSound(const Position& pos, const Audio& audio)
+{
+ alSource3f(audio.source, AL_POSITION, pos.x, pos.y, 0);
+ alSourcePlay(audio.source);
+}
+