X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsource.cpp;fp=source%2Fsource.cpp;h=df3063ce50e909c156b5d2322745d7d40f4eb6d5;hb=2964e0cbc2fd4d6b838cc5f0598db1318fb4c529;hp=c4bb6f8e1a8d415f03b3cd401b1caa36b8d3649c;hpb=641dea4e9e0dad7389d49e70234cf792174ff0e9;p=libs%2Fal.git diff --git a/source/source.cpp b/source/source.cpp index c4bb6f8..df3063c 100644 --- a/source/source.cpp +++ b/source/source.cpp @@ -16,66 +16,41 @@ Source::~Source() alDeleteSources(1, &id); } -void Source::attribute(ALenum attr, int v) -{ - alSourcei(id, attr, v); -} - -void Source::attribute(ALenum attr, float v) -{ - alSourcef(id, attr, v); -} - -void Source::attribute(ALenum attr, float v0, float v1, float v2) -{ - alSource3f(id, attr, v0, v1, v2); -} - -void Source::attribute(ALenum attr, const float *v) -{ - alSourcefv(id, attr, v); -} - -void Source::get_attribute(ALenum attr, int *v) const -{ - alGetSourcei(id, attr, v); -} - -void Source::get_attribute(ALenum attr, float *v) const -{ - alGetSourcef(id, attr, v); -} - SourceState Source::get_state() const { - int state; - get_attribute(AL_SOURCE_STATE, &state); + int state = INITIAL; + alGetSourcei(id, AL_SOURCE_STATE, &state); return static_cast(state); } void Source::set_position(float x, float y, float z) { - attribute(AL_POSITION, x, y, z); + alSource3f(id, AL_POSITION, x, y, z); +} + +void Source::set_velocity(float x, float y, float z) +{ + alSource3f(id, AL_VELOCITY, x, y, z); } void Source::set_looping(bool l) { - attribute(AL_LOOPING, l); + alSourcei(id, AL_LOOPING, l); } void Source::set_gain(float g) { - attribute(AL_GAIN, g); + alSourcef(id, AL_GAIN, g); } void Source::set_rolloff_factor(float f) { - attribute(AL_ROLLOFF_FACTOR, f); + alSourcef(id, AL_ROLLOFF_FACTOR, f); } void Source::set_buffer(const Buffer &buffer) { - attribute(AL_BUFFER, static_cast(buffer.get_id())); + alSourcei(id, AL_BUFFER, buffer.get_id()); } void Source::queue_buffers(const vector &buffers) @@ -110,20 +85,20 @@ void Source::unqueue_buffer(const Buffer &buffer) void Source::clear_buffers() { - attribute(AL_BUFFER, AL_NONE); + alSourcei(id, AL_BUFFER, AL_NONE); } unsigned Source::get_buffers_queued() const { int n = 0; - get_attribute(AL_BUFFERS_QUEUED, &n); + alGetSourceiv(id, AL_BUFFERS_QUEUED, &n); return n; } unsigned Source::get_buffers_processed() const { int n = 0; - get_attribute(AL_BUFFERS_PROCESSED, &n); + alGetSourceiv(id, AL_BUFFERS_PROCESSED, &n); return n; }