826 lines
28 KiB
C
826 lines
28 KiB
C
|
#ifndef AL_AL_H
|
||
|
#define AL_AL_H
|
||
|
|
||
|
#ifdef ANDROID
|
||
|
#include <android/log.h>
|
||
|
#ifndef LOGI
|
||
|
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,"OpenAL",__VA_ARGS__)
|
||
|
#endif
|
||
|
#ifndef LOGE
|
||
|
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,"OpenAL",__VA_ARGS__)
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
#if defined(__cplusplus)
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
#if defined(AL_LIBTYPE_STATIC)
|
||
|
#define AL_API
|
||
|
#elif defined(_WIN32) && !defined(_XBOX)
|
||
|
#if defined(AL_BUILD_LIBRARY)
|
||
|
#define AL_API __declspec(dllexport)
|
||
|
#else
|
||
|
#define AL_API __declspec(dllimport)
|
||
|
#endif
|
||
|
#else
|
||
|
#if defined(AL_BUILD_LIBRARY) && defined(HAVE_GCC_VISIBILITY)
|
||
|
#define AL_API __attribute__((visibility("protected")))
|
||
|
#else
|
||
|
#define AL_API extern
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
#if defined(_WIN32)
|
||
|
#define AL_APIENTRY __cdecl
|
||
|
#else
|
||
|
#define AL_APIENTRY
|
||
|
#endif
|
||
|
|
||
|
#if defined(TARGET_OS_MAC) && TARGET_OS_MAC
|
||
|
#pragma export on
|
||
|
#endif
|
||
|
|
||
|
/*
|
||
|
* The OPENAL, ALAPI, ALAPIENTRY, AL_INVALID, AL_ILLEGAL_ENUM, and
|
||
|
* AL_ILLEGAL_COMMAND macros are deprecated, but are included for
|
||
|
* applications porting code from AL 1.0
|
||
|
*/
|
||
|
#define OPENAL
|
||
|
#define ALAPI AL_API
|
||
|
#define ALAPIENTRY AL_APIENTRY
|
||
|
#define AL_INVALID (-1)
|
||
|
#define AL_ILLEGAL_ENUM AL_INVALID_ENUM
|
||
|
#define AL_ILLEGAL_COMMAND AL_INVALID_OPERATION
|
||
|
|
||
|
#define AL_VERSION_1_0
|
||
|
#define AL_VERSION_1_1
|
||
|
|
||
|
|
||
|
/** 8-bit boolean */
|
||
|
typedef char ALboolean;
|
||
|
|
||
|
/** character */
|
||
|
typedef char ALchar;
|
||
|
|
||
|
/** signed 8-bit 2's complement integer */
|
||
|
typedef signed char ALbyte;
|
||
|
|
||
|
/** unsigned 8-bit integer */
|
||
|
typedef unsigned char ALubyte;
|
||
|
|
||
|
/** signed 16-bit 2's complement integer */
|
||
|
typedef short ALshort;
|
||
|
|
||
|
/** unsigned 16-bit integer */
|
||
|
typedef unsigned short ALushort;
|
||
|
|
||
|
/** signed 32-bit 2's complement integer */
|
||
|
typedef int ALint;
|
||
|
|
||
|
/** unsigned 32-bit integer */
|
||
|
typedef unsigned int ALuint;
|
||
|
|
||
|
/** non-negative 32-bit binary integer size */
|
||
|
typedef int ALsizei;
|
||
|
|
||
|
/** enumerated 32-bit value */
|
||
|
typedef int ALenum;
|
||
|
|
||
|
/** 32-bit IEEE754 floating-point */
|
||
|
typedef float ALfloat;
|
||
|
|
||
|
/** 64-bit IEEE754 floating-point */
|
||
|
typedef double ALdouble;
|
||
|
|
||
|
#ifdef OPENAL_FIXED_POINT
|
||
|
/* Apportable tries to define int64_t and int32_t if it thinks it is needed.
|
||
|
* But this is breaking in a complex project involving both pure C and C++
|
||
|
* something is triggering redefinition errors. The workaround seems to be just using stdint.h.
|
||
|
*/
|
||
|
#include <stdint.h>
|
||
|
/** Types and Macros for fixed-point math */
|
||
|
#ifndef INT64_MAX
|
||
|
typedef long long int64_t;
|
||
|
#define INT64_MAX 9223372036854775807LL
|
||
|
|
||
|
#endif
|
||
|
#ifndef INT32_MAX
|
||
|
typedef int int32_t;
|
||
|
#define INT32_MAX 2147483647
|
||
|
#endif
|
||
|
|
||
|
// FIXME(apportable) make this int32_t
|
||
|
typedef int64_t ALfp;
|
||
|
typedef int64_t ALdfp;
|
||
|
|
||
|
#define ONE (1<<OPENAL_FIXED_POINT_SHIFT)
|
||
|
#define TWO (2<<OPENAL_FIXED_POINT_SHIFT)
|
||
|
|
||
|
#define float2ALfp(x) ((ALfp)((x) * (1<<OPENAL_FIXED_POINT_SHIFT) + ((x)>=0 ? 0.5 : -0.5)))
|
||
|
#define ALfp2float(x) ((float)(x) / (1<<OPENAL_FIXED_POINT_SHIFT))
|
||
|
|
||
|
#define double2ALdfp(x) ((ALdfp)((x) * (1<<OPENAL_FIXED_POINT_SHIFT) + ((x)>=0 ? 0.5 : -0.5)))
|
||
|
#define ALdfp2double(x) ((double)(x) / (1<<OPENAL_FIXED_POINT_SHIFT))
|
||
|
|
||
|
#define int2ALfp(x) ((ALfp)(x) << OPENAL_FIXED_POINT_SHIFT)
|
||
|
#define ALfp2int(x) ((ALint)((x) >> OPENAL_FIXED_POINT_SHIFT))
|
||
|
|
||
|
#define int2ALdfp(x) ((ALdfp)(x) << OPENAL_FIXED_POINT_SHIFT)
|
||
|
#define ALdfp2int(x) ((ALint)((x) >> OPENAL_FIXED_POINT_SHIFT))
|
||
|
|
||
|
#define ALfpMult(x,y) ((ALfp)((((int64_t)(x))*((int64_t)(y)))>>OPENAL_FIXED_POINT_SHIFT))
|
||
|
#define ALfpDiv(x,y) ((ALfp)(((int64_t)(x) << OPENAL_FIXED_POINT_SHIFT) / (y)))
|
||
|
|
||
|
#define ALdfpMult(x,y) ALfpMult(x,y)
|
||
|
#define ALdfpDiv(x,y) ALfpDiv(x,y)
|
||
|
|
||
|
#define __isnan(x) (0)
|
||
|
#define __cos(x) (float2ALfp(cos(ALfp2float(x))))
|
||
|
#define __sin(x) (float2ALfp(sin(ALfp2float(x))))
|
||
|
#define __log10(x) (float2ALfp(log10(ALfp2float(x))))
|
||
|
#define __atan(x) (float2ALfp(atan(ALfp2float(x))))
|
||
|
|
||
|
#define toALfpConst(x) ((x)*(1<<OPENAL_FIXED_POINT_SHIFT))
|
||
|
|
||
|
#else
|
||
|
typedef float ALfp;
|
||
|
typedef double ALdfp;
|
||
|
|
||
|
#define float2ALfp(x) (x)
|
||
|
#define ALfp2float(x) (x)
|
||
|
|
||
|
#define double2ALdfp(x) (x)
|
||
|
#define ALdfp2double(x) (x)
|
||
|
|
||
|
#define int2ALfp(x) ((ALfp)(x))
|
||
|
#define ALfp2int(x) ((ALint)(x))
|
||
|
|
||
|
#define int2ALdfp(x) ((ALdfp)(x))
|
||
|
#define ALdfp2int(x) ((ALint)(x))
|
||
|
|
||
|
#define ALfpMult(x,y) ((x)*(y))
|
||
|
#define ALfpDiv(x,y) ((x)/(y))
|
||
|
|
||
|
#define ALdfpMult(x,y) ALfpMult((x),(y))
|
||
|
#define ALdfpDiv(x,y) ALfpDiv((x),(y))
|
||
|
|
||
|
#define __isnan(x) (0)
|
||
|
#define __cos(x) cos((x))
|
||
|
#define __sin(x) sin((x))
|
||
|
#define __log10(x) log10((x))
|
||
|
#define __atan(x) atan((x))
|
||
|
|
||
|
#define toALfpConst(x) (x)
|
||
|
|
||
|
#endif
|
||
|
|
||
|
/** void type (for opaque pointers only) */
|
||
|
typedef void ALvoid;
|
||
|
|
||
|
|
||
|
/* Enumerant values begin at column 50. No tabs. */
|
||
|
|
||
|
/* "no distance model" or "no buffer" */
|
||
|
#define AL_NONE 0
|
||
|
|
||
|
/* Boolean False. */
|
||
|
#define AL_FALSE 0
|
||
|
|
||
|
/** Boolean True. */
|
||
|
#define AL_TRUE 1
|
||
|
|
||
|
/** Indicate Source has relative coordinates. */
|
||
|
#define AL_SOURCE_RELATIVE 0x202
|
||
|
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Directional source, inner cone angle, in degrees.
|
||
|
* Range: [0-360]
|
||
|
* Default: 360
|
||
|
*/
|
||
|
#define AL_CONE_INNER_ANGLE 0x1001
|
||
|
|
||
|
/**
|
||
|
* Directional source, outer cone angle, in degrees.
|
||
|
* Range: [0-360]
|
||
|
* Default: 360
|
||
|
*/
|
||
|
#define AL_CONE_OUTER_ANGLE 0x1002
|
||
|
|
||
|
/**
|
||
|
* Specify the pitch to be applied at source.
|
||
|
* Range: [0.5-2.0]
|
||
|
* Default: 1.0
|
||
|
*/
|
||
|
#define AL_PITCH 0x1003
|
||
|
|
||
|
/**
|
||
|
* Specify the current location in three dimensional space.
|
||
|
* OpenAL, like OpenGL, uses a right handed coordinate system,
|
||
|
* where in a frontal default view X (thumb) points right,
|
||
|
* Y points up (index finger), and Z points towards the
|
||
|
* viewer/camera (middle finger).
|
||
|
* To switch from a left handed coordinate system, flip the
|
||
|
* sign on the Z coordinate.
|
||
|
* Listener position is always in the world coordinate system.
|
||
|
*/
|
||
|
#define AL_POSITION 0x1004
|
||
|
|
||
|
/** Specify the current direction. */
|
||
|
#define AL_DIRECTION 0x1005
|
||
|
|
||
|
/** Specify the current velocity in three dimensional space. */
|
||
|
#define AL_VELOCITY 0x1006
|
||
|
|
||
|
/**
|
||
|
* Indicate whether source is looping.
|
||
|
* Type: ALboolean?
|
||
|
* Range: [AL_TRUE, AL_FALSE]
|
||
|
* Default: FALSE.
|
||
|
*/
|
||
|
#define AL_LOOPING 0x1007
|
||
|
|
||
|
/**
|
||
|
* Indicate the buffer to provide sound samples.
|
||
|
* Type: ALuint.
|
||
|
* Range: any valid Buffer id.
|
||
|
*/
|
||
|
#define AL_BUFFER 0x1009
|
||
|
|
||
|
/**
|
||
|
* Indicate the gain (volume amplification) applied.
|
||
|
* Type: ALfloat.
|
||
|
* Range: ]0.0- ]
|
||
|
* A value of 1.0 means un-attenuated/unchanged.
|
||
|
* Each division by 2 equals an attenuation of -6dB.
|
||
|
* Each multiplicaton with 2 equals an amplification of +6dB.
|
||
|
* A value of 0.0 is meaningless with respect to a logarithmic
|
||
|
* scale; it is interpreted as zero volume - the channel
|
||
|
* is effectively disabled.
|
||
|
*/
|
||
|
#define AL_GAIN 0x100A
|
||
|
|
||
|
/*
|
||
|
* Indicate minimum source attenuation
|
||
|
* Type: ALfloat
|
||
|
* Range: [0.0 - 1.0]
|
||
|
*
|
||
|
* Logarthmic
|
||
|
*/
|
||
|
#define AL_MIN_GAIN 0x100D
|
||
|
|
||
|
/**
|
||
|
* Indicate maximum source attenuation
|
||
|
* Type: ALfloat
|
||
|
* Range: [0.0 - 1.0]
|
||
|
*
|
||
|
* Logarthmic
|
||
|
*/
|
||
|
#define AL_MAX_GAIN 0x100E
|
||
|
|
||
|
/**
|
||
|
* Indicate listener orientation.
|
||
|
*
|
||
|
* at/up
|
||
|
*/
|
||
|
#define AL_ORIENTATION 0x100F
|
||
|
|
||
|
/**
|
||
|
* Source state information.
|
||
|
*/
|
||
|
#define AL_SOURCE_STATE 0x1010
|
||
|
#define AL_INITIAL 0x1011
|
||
|
#define AL_PLAYING 0x1012
|
||
|
#define AL_PAUSED 0x1013
|
||
|
#define AL_STOPPED 0x1014
|
||
|
|
||
|
/**
|
||
|
* Buffer Queue params
|
||
|
*/
|
||
|
#define AL_BUFFERS_QUEUED 0x1015
|
||
|
#define AL_BUFFERS_PROCESSED 0x1016
|
||
|
|
||
|
/**
|
||
|
* Source buffer position information
|
||
|
*/
|
||
|
#define AL_SEC_OFFSET 0x1024
|
||
|
#define AL_SAMPLE_OFFSET 0x1025
|
||
|
#define AL_BYTE_OFFSET 0x1026
|
||
|
|
||
|
/*
|
||
|
* Source type (Static, Streaming or undetermined)
|
||
|
* Source is Static if a Buffer has been attached using AL_BUFFER
|
||
|
* Source is Streaming if one or more Buffers have been attached using alSourceQueueBuffers
|
||
|
* Source is undetermined when it has the NULL buffer attached
|
||
|
*/
|
||
|
#define AL_SOURCE_TYPE 0x1027
|
||
|
#define AL_STATIC 0x1028
|
||
|
#define AL_STREAMING 0x1029
|
||
|
#define AL_UNDETERMINED 0x1030
|
||
|
|
||
|
/** Sound samples: format specifier. */
|
||
|
#define AL_FORMAT_MONO8 0x1100
|
||
|
#define AL_FORMAT_MONO16 0x1101
|
||
|
#define AL_FORMAT_STEREO8 0x1102
|
||
|
#define AL_FORMAT_STEREO16 0x1103
|
||
|
|
||
|
/**
|
||
|
* source specific reference distance
|
||
|
* Type: ALfloat
|
||
|
* Range: 0.0 - +inf
|
||
|
*
|
||
|
* At 0.0, no distance attenuation occurs. Default is
|
||
|
* 1.0.
|
||
|
*/
|
||
|
#define AL_REFERENCE_DISTANCE 0x1020
|
||
|
|
||
|
/**
|
||
|
* source specific rolloff factor
|
||
|
* Type: ALfloat
|
||
|
* Range: 0.0 - +inf
|
||
|
*
|
||
|
*/
|
||
|
#define AL_ROLLOFF_FACTOR 0x1021
|
||
|
|
||
|
/**
|
||
|
* Directional source, outer cone gain.
|
||
|
*
|
||
|
* Default: 0.0
|
||
|
* Range: [0.0 - 1.0]
|
||
|
* Logarithmic
|
||
|
*/
|
||
|
#define AL_CONE_OUTER_GAIN 0x1022
|
||
|
|
||
|
/**
|
||
|
* Indicate distance above which sources are not
|
||
|
* attenuated using the inverse clamped distance model.
|
||
|
*
|
||
|
* Default: +inf
|
||
|
* Type: ALfloat
|
||
|
* Range: 0.0 - +inf
|
||
|
*/
|
||
|
#define AL_MAX_DISTANCE 0x1023
|
||
|
|
||
|
/**
|
||
|
* Sound samples: frequency, in units of Hertz [Hz].
|
||
|
* This is the number of samples per second. Half of the
|
||
|
* sample frequency marks the maximum significant
|
||
|
* frequency component.
|
||
|
*/
|
||
|
#define AL_FREQUENCY 0x2001
|
||
|
#define AL_BITS 0x2002
|
||
|
#define AL_CHANNELS 0x2003
|
||
|
#define AL_SIZE 0x2004
|
||
|
|
||
|
/**
|
||
|
* Buffer state.
|
||
|
*
|
||
|
* Not supported for public use (yet).
|
||
|
*/
|
||
|
#define AL_UNUSED 0x2010
|
||
|
#define AL_PENDING 0x2011
|
||
|
#define AL_PROCESSED 0x2012
|
||
|
|
||
|
|
||
|
/** Errors: No Error. */
|
||
|
#define AL_NO_ERROR AL_FALSE
|
||
|
|
||
|
/**
|
||
|
* Invalid Name paramater passed to AL call.
|
||
|
*/
|
||
|
#define AL_INVALID_NAME 0xA001
|
||
|
|
||
|
/**
|
||
|
* Invalid parameter passed to AL call.
|
||
|
*/
|
||
|
#define AL_INVALID_ENUM 0xA002
|
||
|
|
||
|
/**
|
||
|
* Invalid enum parameter value.
|
||
|
*/
|
||
|
#define AL_INVALID_VALUE 0xA003
|
||
|
|
||
|
/**
|
||
|
* Illegal call.
|
||
|
*/
|
||
|
#define AL_INVALID_OPERATION 0xA004
|
||
|
|
||
|
|
||
|
/**
|
||
|
* No mojo.
|
||
|
*/
|
||
|
#define AL_OUT_OF_MEMORY 0xA005
|
||
|
|
||
|
|
||
|
/** Context strings: Vendor Name. */
|
||
|
#define AL_VENDOR 0xB001
|
||
|
#define AL_VERSION 0xB002
|
||
|
#define AL_RENDERER 0xB003
|
||
|
#define AL_EXTENSIONS 0xB004
|
||
|
|
||
|
/** Global tweakage. */
|
||
|
|
||
|
/**
|
||
|
* Doppler scale. Default 1.0
|
||
|
*/
|
||
|
#define AL_DOPPLER_FACTOR 0xC000
|
||
|
|
||
|
/**
|
||
|
* Tweaks speed of propagation.
|
||
|
*/
|
||
|
#define AL_DOPPLER_VELOCITY 0xC001
|
||
|
|
||
|
/**
|
||
|
* Speed of Sound in units per second
|
||
|
*/
|
||
|
#define AL_SPEED_OF_SOUND 0xC003
|
||
|
|
||
|
/**
|
||
|
* Distance models
|
||
|
*
|
||
|
* used in conjunction with DistanceModel
|
||
|
*
|
||
|
* implicit: NONE, which disances distance attenuation.
|
||
|
*/
|
||
|
#define AL_DISTANCE_MODEL 0xD000
|
||
|
#define AL_INVERSE_DISTANCE 0xD001
|
||
|
#define AL_INVERSE_DISTANCE_CLAMPED 0xD002
|
||
|
#define AL_LINEAR_DISTANCE 0xD003
|
||
|
#define AL_LINEAR_DISTANCE_CLAMPED 0xD004
|
||
|
#define AL_EXPONENT_DISTANCE 0xD005
|
||
|
#define AL_EXPONENT_DISTANCE_CLAMPED 0xD006
|
||
|
|
||
|
/**
|
||
|
* Priority
|
||
|
*
|
||
|
* Apportable Extension.
|
||
|
* Used to prevent dynamic throttling of this source.
|
||
|
*
|
||
|
*/
|
||
|
#define AL_PRIORITY 0xE001
|
||
|
#define AL_PRIORITY_SLOTS 0xE002
|
||
|
/*
|
||
|
* Renderer State management
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alEnable( ALenum capability );
|
||
|
|
||
|
AL_API void AL_APIENTRY alDisable( ALenum capability );
|
||
|
|
||
|
AL_API ALboolean AL_APIENTRY alIsEnabled( ALenum capability );
|
||
|
|
||
|
|
||
|
/*
|
||
|
* State retrieval
|
||
|
*/
|
||
|
AL_API const ALchar* AL_APIENTRY alGetString( ALenum param );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetBooleanv( ALenum param, ALboolean* data );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetIntegerv( ALenum param, ALint* data );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetFloatv( ALenum param, ALfloat* data );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetDoublev( ALenum param, ALdouble* data );
|
||
|
|
||
|
AL_API ALboolean AL_APIENTRY alGetBoolean( ALenum param );
|
||
|
|
||
|
AL_API ALint AL_APIENTRY alGetInteger( ALenum param );
|
||
|
|
||
|
AL_API ALfloat AL_APIENTRY alGetFloat( ALenum param );
|
||
|
|
||
|
AL_API ALdouble AL_APIENTRY alGetDouble( ALenum param );
|
||
|
|
||
|
|
||
|
/*
|
||
|
* Error support.
|
||
|
* Obtain the most recent error generated in the AL state machine.
|
||
|
*/
|
||
|
AL_API ALenum AL_APIENTRY alGetError( void );
|
||
|
|
||
|
|
||
|
/*
|
||
|
* Extension support.
|
||
|
* Query for the presence of an extension, and obtain any appropriate
|
||
|
* function pointers and enum values.
|
||
|
*/
|
||
|
AL_API ALboolean AL_APIENTRY alIsExtensionPresent( const ALchar* extname );
|
||
|
|
||
|
AL_API void* AL_APIENTRY alGetProcAddress( const ALchar* fname );
|
||
|
|
||
|
AL_API ALenum AL_APIENTRY alGetEnumValue( const ALchar* ename );
|
||
|
|
||
|
|
||
|
/*
|
||
|
* LISTENER
|
||
|
* Listener represents the location and orientation of the
|
||
|
* 'user' in 3D-space.
|
||
|
*
|
||
|
* Properties include: -
|
||
|
*
|
||
|
* Gain AL_GAIN ALfloat
|
||
|
* Position AL_POSITION ALfloat[3]
|
||
|
* Velocity AL_VELOCITY ALfloat[3]
|
||
|
* Orientation AL_ORIENTATION ALfloat[6] (Forward then Up vectors)
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* Set Listener parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alListenerf( ALenum param, ALfloat value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alListener3f( ALenum param, ALfloat value1, ALfloat value2, ALfloat value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alListenerfv( ALenum param, const ALfloat* values );
|
||
|
|
||
|
AL_API void AL_APIENTRY alListeneri( ALenum param, ALint value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alListener3i( ALenum param, ALint value1, ALint value2, ALint value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alListeneriv( ALenum param, const ALint* values );
|
||
|
|
||
|
/*
|
||
|
* Get Listener parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alGetListenerf( ALenum param, ALfloat* value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetListener3f( ALenum param, ALfloat *value1, ALfloat *value2, ALfloat *value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetListenerfv( ALenum param, ALfloat* values );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetListeneri( ALenum param, ALint* value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetListener3i( ALenum param, ALint *value1, ALint *value2, ALint *value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetListeneriv( ALenum param, ALint* values );
|
||
|
|
||
|
|
||
|
/**
|
||
|
* SOURCE
|
||
|
* Sources represent individual sound objects in 3D-space.
|
||
|
* Sources take the PCM data provided in the specified Buffer,
|
||
|
* apply Source-specific modifications, and then
|
||
|
* submit them to be mixed according to spatial arrangement etc.
|
||
|
*
|
||
|
* Properties include: -
|
||
|
*
|
||
|
* Gain AL_GAIN ALfloat
|
||
|
* Min Gain AL_MIN_GAIN ALfloat
|
||
|
* Max Gain AL_MAX_GAIN ALfloat
|
||
|
* Position AL_POSITION ALfloat[3]
|
||
|
* Velocity AL_VELOCITY ALfloat[3]
|
||
|
* Direction AL_DIRECTION ALfloat[3]
|
||
|
* Head Relative Mode AL_SOURCE_RELATIVE ALint (AL_TRUE or AL_FALSE)
|
||
|
* Reference Distance AL_REFERENCE_DISTANCE ALfloat
|
||
|
* Max Distance AL_MAX_DISTANCE ALfloat
|
||
|
* RollOff Factor AL_ROLLOFF_FACTOR ALfloat
|
||
|
* Inner Angle AL_CONE_INNER_ANGLE ALint or ALfloat
|
||
|
* Outer Angle AL_CONE_OUTER_ANGLE ALint or ALfloat
|
||
|
* Cone Outer Gain AL_CONE_OUTER_GAIN ALint or ALfloat
|
||
|
* Pitch AL_PITCH ALfloat
|
||
|
* Looping AL_LOOPING ALint (AL_TRUE or AL_FALSE)
|
||
|
* MS Offset AL_MSEC_OFFSET ALint or ALfloat
|
||
|
* Byte Offset AL_BYTE_OFFSET ALint or ALfloat
|
||
|
* Sample Offset AL_SAMPLE_OFFSET ALint or ALfloat
|
||
|
* Attached Buffer AL_BUFFER ALint
|
||
|
* State (Query only) AL_SOURCE_STATE ALint
|
||
|
* Buffers Queued (Query only) AL_BUFFERS_QUEUED ALint
|
||
|
* Buffers Processed (Query only) AL_BUFFERS_PROCESSED ALint
|
||
|
*/
|
||
|
|
||
|
/* Create Source objects */
|
||
|
AL_API void AL_APIENTRY alGenSources( ALsizei n, ALuint* sources );
|
||
|
|
||
|
/* Delete Source objects */
|
||
|
AL_API void AL_APIENTRY alDeleteSources( ALsizei n, const ALuint* sources );
|
||
|
|
||
|
/* Verify a handle is a valid Source */
|
||
|
AL_API ALboolean AL_APIENTRY alIsSource( ALuint sid );
|
||
|
|
||
|
/*
|
||
|
* Set Source parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alSourcef( ALuint sid, ALenum param, ALfloat value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSource3f( ALuint sid, ALenum param, ALfloat value1, ALfloat value2, ALfloat value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSourcefv( ALuint sid, ALenum param, const ALfloat* values );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSourcei( ALuint sid, ALenum param, ALint value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSource3i( ALuint sid, ALenum param, ALint value1, ALint value2, ALint value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSourceiv( ALuint sid, ALenum param, const ALint* values );
|
||
|
|
||
|
/*
|
||
|
* Get Source parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alGetSourcef( ALuint sid, ALenum param, ALfloat* value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetSource3f( ALuint sid, ALenum param, ALfloat* value1, ALfloat* value2, ALfloat* value3);
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetSourcefv( ALuint sid, ALenum param, ALfloat* values );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetSourcei( ALuint sid, ALenum param, ALint* value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetSource3i( ALuint sid, ALenum param, ALint* value1, ALint* value2, ALint* value3);
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetSourceiv( ALuint sid, ALenum param, ALint* values );
|
||
|
|
||
|
|
||
|
/*
|
||
|
* Source vector based playback calls
|
||
|
*/
|
||
|
|
||
|
/* Play, replay, or resume (if paused) a list of Sources */
|
||
|
AL_API void AL_APIENTRY alSourcePlayv( ALsizei ns, const ALuint *sids );
|
||
|
|
||
|
/* Stop a list of Sources */
|
||
|
AL_API void AL_APIENTRY alSourceStopv( ALsizei ns, const ALuint *sids );
|
||
|
|
||
|
/* Rewind a list of Sources */
|
||
|
AL_API void AL_APIENTRY alSourceRewindv( ALsizei ns, const ALuint *sids );
|
||
|
|
||
|
/* Pause a list of Sources */
|
||
|
AL_API void AL_APIENTRY alSourcePausev( ALsizei ns, const ALuint *sids );
|
||
|
|
||
|
/*
|
||
|
* Source based playback calls
|
||
|
*/
|
||
|
|
||
|
/* Play, replay, or resume a Source */
|
||
|
AL_API void AL_APIENTRY alSourcePlay( ALuint sid );
|
||
|
|
||
|
/* Stop a Source */
|
||
|
AL_API void AL_APIENTRY alSourceStop( ALuint sid );
|
||
|
|
||
|
/* Rewind a Source (set playback postiton to beginning) */
|
||
|
AL_API void AL_APIENTRY alSourceRewind( ALuint sid );
|
||
|
|
||
|
/* Pause a Source */
|
||
|
AL_API void AL_APIENTRY alSourcePause( ALuint sid );
|
||
|
|
||
|
/*
|
||
|
* Source Queuing
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alSourceQueueBuffers( ALuint sid, ALsizei numEntries, const ALuint *bids );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSourceUnqueueBuffers( ALuint sid, ALsizei numEntries, ALuint *bids );
|
||
|
|
||
|
|
||
|
/**
|
||
|
* BUFFER
|
||
|
* Buffer objects are storage space for sample data.
|
||
|
* Buffers are referred to by Sources. One Buffer can be used
|
||
|
* by multiple Sources.
|
||
|
*
|
||
|
* Properties include: -
|
||
|
*
|
||
|
* Frequency (Query only) AL_FREQUENCY ALint
|
||
|
* Size (Query only) AL_SIZE ALint
|
||
|
* Bits (Query only) AL_BITS ALint
|
||
|
* Channels (Query only) AL_CHANNELS ALint
|
||
|
*/
|
||
|
|
||
|
/* Create Buffer objects */
|
||
|
AL_API void AL_APIENTRY alGenBuffers( ALsizei n, ALuint* buffers );
|
||
|
|
||
|
/* Delete Buffer objects */
|
||
|
AL_API void AL_APIENTRY alDeleteBuffers( ALsizei n, const ALuint* buffers );
|
||
|
|
||
|
/* Verify a handle is a valid Buffer */
|
||
|
AL_API ALboolean AL_APIENTRY alIsBuffer( ALuint bid );
|
||
|
|
||
|
/* Specify the data to be copied into a buffer */
|
||
|
AL_API void AL_APIENTRY alBufferData( ALuint bid, ALenum format, const ALvoid* data, ALsizei size, ALsizei freq );
|
||
|
|
||
|
/*
|
||
|
* Set Buffer parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alBufferf( ALuint bid, ALenum param, ALfloat value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alBuffer3f( ALuint bid, ALenum param, ALfloat value1, ALfloat value2, ALfloat value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alBufferfv( ALuint bid, ALenum param, const ALfloat* values );
|
||
|
|
||
|
AL_API void AL_APIENTRY alBufferi( ALuint bid, ALenum param, ALint value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alBuffer3i( ALuint bid, ALenum param, ALint value1, ALint value2, ALint value3 );
|
||
|
|
||
|
AL_API void AL_APIENTRY alBufferiv( ALuint bid, ALenum param, const ALint* values );
|
||
|
|
||
|
/*
|
||
|
* Get Buffer parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alGetBufferf( ALuint bid, ALenum param, ALfloat* value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetBuffer3f( ALuint bid, ALenum param, ALfloat* value1, ALfloat* value2, ALfloat* value3);
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetBufferfv( ALuint bid, ALenum param, ALfloat* values );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetBufferi( ALuint bid, ALenum param, ALint* value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetBuffer3i( ALuint bid, ALenum param, ALint* value1, ALint* value2, ALint* value3);
|
||
|
|
||
|
AL_API void AL_APIENTRY alGetBufferiv( ALuint bid, ALenum param, ALint* values );
|
||
|
|
||
|
|
||
|
/*
|
||
|
* Global Parameters
|
||
|
*/
|
||
|
AL_API void AL_APIENTRY alDopplerFactor( ALfloat value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alDopplerVelocity( ALfloat value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alSpeedOfSound( ALfloat value );
|
||
|
|
||
|
AL_API void AL_APIENTRY alDistanceModel( ALenum distanceModel );
|
||
|
|
||
|
/*
|
||
|
* Pointer-to-function types, useful for dynamically getting AL entry points.
|
||
|
*/
|
||
|
typedef void (AL_APIENTRY *LPALENABLE)( ALenum capability );
|
||
|
typedef void (AL_APIENTRY *LPALDISABLE)( ALenum capability );
|
||
|
typedef ALboolean (AL_APIENTRY *LPALISENABLED)( ALenum capability );
|
||
|
typedef const ALchar* (AL_APIENTRY *LPALGETSTRING)( ALenum param );
|
||
|
typedef void (AL_APIENTRY *LPALGETBOOLEANV)( ALenum param, ALboolean* data );
|
||
|
typedef void (AL_APIENTRY *LPALGETINTEGERV)( ALenum param, ALint* data );
|
||
|
typedef void (AL_APIENTRY *LPALGETFLOATV)( ALenum param, ALfloat* data );
|
||
|
typedef void (AL_APIENTRY *LPALGETDOUBLEV)( ALenum param, ALdouble* data );
|
||
|
typedef ALboolean (AL_APIENTRY *LPALGETBOOLEAN)( ALenum param );
|
||
|
typedef ALint (AL_APIENTRY *LPALGETINTEGER)( ALenum param );
|
||
|
typedef ALfloat (AL_APIENTRY *LPALGETFLOAT)( ALenum param );
|
||
|
typedef ALdouble (AL_APIENTRY *LPALGETDOUBLE)( ALenum param );
|
||
|
typedef ALenum (AL_APIENTRY *LPALGETERROR)( void );
|
||
|
typedef ALboolean (AL_APIENTRY *LPALISEXTENSIONPRESENT)(const ALchar* extname );
|
||
|
typedef void* (AL_APIENTRY *LPALGETPROCADDRESS)( const ALchar* fname );
|
||
|
typedef ALenum (AL_APIENTRY *LPALGETENUMVALUE)( const ALchar* ename );
|
||
|
typedef void (AL_APIENTRY *LPALLISTENERF)( ALenum param, ALfloat value );
|
||
|
typedef void (AL_APIENTRY *LPALLISTENER3F)( ALenum param, ALfloat value1, ALfloat value2, ALfloat value3 );
|
||
|
typedef void (AL_APIENTRY *LPALLISTENERFV)( ALenum param, const ALfloat* values );
|
||
|
typedef void (AL_APIENTRY *LPALLISTENERI)( ALenum param, ALint value );
|
||
|
typedef void (AL_APIENTRY *LPALLISTENER3I)( ALenum param, ALint value1, ALint value2, ALint value3 );
|
||
|
typedef void (AL_APIENTRY *LPALLISTENERIV)( ALenum param, const ALint* values );
|
||
|
typedef void (AL_APIENTRY *LPALGETLISTENERF)( ALenum param, ALfloat* value );
|
||
|
typedef void (AL_APIENTRY *LPALGETLISTENER3F)( ALenum param, ALfloat *value1, ALfloat *value2, ALfloat *value3 );
|
||
|
typedef void (AL_APIENTRY *LPALGETLISTENERFV)( ALenum param, ALfloat* values );
|
||
|
typedef void (AL_APIENTRY *LPALGETLISTENERI)( ALenum param, ALint* value );
|
||
|
typedef void (AL_APIENTRY *LPALGETLISTENER3I)( ALenum param, ALint *value1, ALint *value2, ALint *value3 );
|
||
|
typedef void (AL_APIENTRY *LPALGETLISTENERIV)( ALenum param, ALint* values );
|
||
|
typedef void (AL_APIENTRY *LPALGENSOURCES)( ALsizei n, ALuint* sources );
|
||
|
typedef void (AL_APIENTRY *LPALDELETESOURCES)( ALsizei n, const ALuint* sources );
|
||
|
typedef ALboolean (AL_APIENTRY *LPALISSOURCE)( ALuint sid );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEF)( ALuint sid, ALenum param, ALfloat value);
|
||
|
typedef void (AL_APIENTRY *LPALSOURCE3F)( ALuint sid, ALenum param, ALfloat value1, ALfloat value2, ALfloat value3 );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEFV)( ALuint sid, ALenum param, const ALfloat* values );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEI)( ALuint sid, ALenum param, ALint value);
|
||
|
typedef void (AL_APIENTRY *LPALSOURCE3I)( ALuint sid, ALenum param, ALint value1, ALint value2, ALint value3 );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEIV)( ALuint sid, ALenum param, const ALint* values );
|
||
|
typedef void (AL_APIENTRY *LPALGETSOURCEF)( ALuint sid, ALenum param, ALfloat* value );
|
||
|
typedef void (AL_APIENTRY *LPALGETSOURCE3F)( ALuint sid, ALenum param, ALfloat* value1, ALfloat* value2, ALfloat* value3);
|
||
|
typedef void (AL_APIENTRY *LPALGETSOURCEFV)( ALuint sid, ALenum param, ALfloat* values );
|
||
|
typedef void (AL_APIENTRY *LPALGETSOURCEI)( ALuint sid, ALenum param, ALint* value );
|
||
|
typedef void (AL_APIENTRY *LPALGETSOURCE3I)( ALuint sid, ALenum param, ALint* value1, ALint* value2, ALint* value3);
|
||
|
typedef void (AL_APIENTRY *LPALGETSOURCEIV)( ALuint sid, ALenum param, ALint* values );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEPLAYV)( ALsizei ns, const ALuint *sids );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCESTOPV)( ALsizei ns, const ALuint *sids );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEREWINDV)( ALsizei ns, const ALuint *sids );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEPAUSEV)( ALsizei ns, const ALuint *sids );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEPLAY)( ALuint sid );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCESTOP)( ALuint sid );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEREWIND)( ALuint sid );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEPAUSE)( ALuint sid );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEQUEUEBUFFERS)(ALuint sid, ALsizei numEntries, const ALuint *bids );
|
||
|
typedef void (AL_APIENTRY *LPALSOURCEUNQUEUEBUFFERS)(ALuint sid, ALsizei numEntries, ALuint *bids );
|
||
|
typedef void (AL_APIENTRY *LPALGENBUFFERS)( ALsizei n, ALuint* buffers );
|
||
|
typedef void (AL_APIENTRY *LPALDELETEBUFFERS)( ALsizei n, const ALuint* buffers );
|
||
|
typedef ALboolean (AL_APIENTRY *LPALISBUFFER)( ALuint bid );
|
||
|
typedef void (AL_APIENTRY *LPALBUFFERDATA)( ALuint bid, ALenum format, const ALvoid* data, ALsizei size, ALsizei freq );
|
||
|
typedef void (AL_APIENTRY *LPALBUFFERF)( ALuint bid, ALenum param, ALfloat value);
|
||
|
typedef void (AL_APIENTRY *LPALBUFFER3F)( ALuint bid, ALenum param, ALfloat value1, ALfloat value2, ALfloat value3 );
|
||
|
typedef void (AL_APIENTRY *LPALBUFFERFV)( ALuint bid, ALenum param, const ALfloat* values );
|
||
|
typedef void (AL_APIENTRY *LPALBUFFERI)( ALuint bid, ALenum param, ALint value);
|
||
|
typedef void (AL_APIENTRY *LPALBUFFER3I)( ALuint bid, ALenum param, ALint value1, ALint value2, ALint value3 );
|
||
|
typedef void (AL_APIENTRY *LPALBUFFERIV)( ALuint bid, ALenum param, const ALint* values );
|
||
|
typedef void (AL_APIENTRY *LPALGETBUFFERF)( ALuint bid, ALenum param, ALfloat* value );
|
||
|
typedef void (AL_APIENTRY *LPALGETBUFFER3F)( ALuint bid, ALenum param, ALfloat* value1, ALfloat* value2, ALfloat* value3);
|
||
|
typedef void (AL_APIENTRY *LPALGETBUFFERFV)( ALuint bid, ALenum param, ALfloat* values );
|
||
|
typedef void (AL_APIENTRY *LPALGETBUFFERI)( ALuint bid, ALenum param, ALint* value );
|
||
|
typedef void (AL_APIENTRY *LPALGETBUFFER3I)( ALuint bid, ALenum param, ALint* value1, ALint* value2, ALint* value3);
|
||
|
typedef void (AL_APIENTRY *LPALGETBUFFERIV)( ALuint bid, ALenum param, ALint* values );
|
||
|
typedef void (AL_APIENTRY *LPALDOPPLERFACTOR)( ALfloat value );
|
||
|
typedef void (AL_APIENTRY *LPALDOPPLERVELOCITY)( ALfloat value );
|
||
|
typedef void (AL_APIENTRY *LPALSPEEDOFSOUND)( ALfloat value );
|
||
|
typedef void (AL_APIENTRY *LPALDISTANCEMODEL)( ALenum distanceModel );
|
||
|
|
||
|
#if defined(TARGET_OS_MAC) && TARGET_OS_MAC
|
||
|
#pragma export off
|
||
|
#endif
|
||
|
|
||
|
#if defined(__cplusplus)
|
||
|
} /* extern "C" */
|
||
|
#endif
|
||
|
|
||
|
#endif /* AL_AL_H */
|