2008-01-16 19:43:52 +01:00
#region - - - OpenTK . OpenAL License - - -
/ * EfxFunctions . cs
* C headers : \ OpenAL 1.1 SDK \ include \ "efx.h" , "efx-creative.h" , "Efx-Util.h"
* Spec : Effects Extension Guide . pdf ( bundled with OpenAL SDK )
* Copyright ( c ) 2008 Christoph Brandtner and Stefanos Apostolopoulos
* See license . txt for license details
* http : //www.OpenTK.net */
#endregion
using System ;
using System.Runtime.InteropServices ;
2008-01-18 19:35:43 +01:00
using OpenTK.Math ;
2008-01-16 19:43:52 +01:00
namespace OpenTK.OpenAL
{
2008-01-18 14:32:51 +01:00
public partial class EfxExtension
2008-01-16 19:43:52 +01:00
{
2008-01-18 14:32:51 +01:00
#region Effect Object
#region alGenEffects
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGENEFFECTS)( ALsizei n, ALuint* effects );
2008-01-17 21:55:56 +01:00
[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGenEffects ( int n , [ Out ] uint * effects ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
private Delegate_alGenEffects Imported_alGenEffects ;
2008-01-18 18:24:39 +01:00
/// <summary>The alGenEffects function is used to create one or more Effect objects. An Effect object stores an effect type and a set of parameter values to control that Effect. In order to use an Effect it must be attached to an Auxiliary Effect Slot object</summary>
/// <remarks>After creation an Effect has no type (AL_EFFECT_NULL), so before it can be used to store a set of parameters, the application must specify what type of effect should be stored in the object, using alEffecti.</remarks>
/// <param name="n">Number of Effects to be created.</param>
/// <param name="effects">Pointer addressing sufficient memory to store n Effect object identifiers.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public void GenEffects ( int n , out uint effects )
2008-01-18 14:32:51 +01:00
{
unsafe
{
2008-01-18 18:24:39 +01:00
fixed ( uint * ptr = & effects )
2008-01-18 14:32:51 +01:00
{
Imported_alGenEffects ( n , ptr ) ;
2008-01-18 18:24:39 +01:00
effects = * ptr ;
2008-01-18 14:32:51 +01:00
}
}
}
[CLSCompliant(false)]
/// <summary>This function generates only one Effect.</summary>
2008-01-18 18:24:39 +01:00
/// <param name="effect">Storage UInt32 for the new effect name/handle.</param>
public void GenEffects ( out uint effect )
2008-01-18 14:32:51 +01:00
{
unsafe
{
2008-01-18 18:24:39 +01:00
fixed ( uint * ptr = & effect )
2008-01-18 14:32:51 +01:00
{
Imported_alGenEffects ( 1 , ptr ) ;
}
}
}
#endregion alGenEffects
#region alDeleteEffects
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALDELETEEFFECTS)( ALsizei n, ALuint* effects );
2008-01-17 21:55:56 +01:00
[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alDeleteEffects ( int n , [ In ] uint * effects ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
private Delegate_alDeleteEffects Imported_alDeleteEffects ;
2008-01-18 18:24:39 +01:00
/// <summary>The alDeleteEffects function is used to delete and free resources for Effect objects previously created with alGenEffects.</summary>
/// <param name="n">Number of Effects to be deleted.</param>
/// <param name="effects">Pointer to n Effect object identifiers.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public void DeleteEffects ( int n , ref uint [ ] effects )
2008-01-18 14:32:51 +01:00
{
unsafe
{
2008-01-18 18:24:39 +01:00
fixed ( uint * ptr = effects )
2008-01-18 14:32:51 +01:00
{
Imported_alDeleteEffects ( n , ptr ) ;
}
}
}
/// <summary>This function deletes one Effect only.</summary>
2008-01-18 18:24:39 +01:00
/// <param name="effect">Pointer to an effect name/handle identifying the Effect Object to be deleted.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public void DeleteEffects ( ref uint effect )
2008-01-18 14:32:51 +01:00
{
unsafe
{
2008-01-18 18:24:39 +01:00
fixed ( uint * ptr = & effect )
2008-01-18 14:32:51 +01:00
{
Imported_alDeleteEffects ( 1 , ptr ) ;
}
}
}
#endregion alDeleteEffects
#region alIsEffect
2008-01-16 19:43:52 +01:00
// typedef ALboolean (__cdecl *LPALISEFFECT)( ALuint eid );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate bool Delegate_alIsEffect ( uint eid ) ;
2008-01-18 14:32:51 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alIsEffect Imported_alIsEffect ;
/// <summary>The alIsEffect function is used to determine if an object identifier is a valid Effect object.</summary>
/// <param name="eid">Effect identifier to validate.</param>
/// <returns>True if the identifier is a valid Effect, False otherwise.</returns>
2008-01-20 20:00:03 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public bool IsEffect ( uint eid )
{
return Imported_alIsEffect ( eid ) ;
}
2008-01-18 14:32:51 +01:00
#endregion alIsEffect
#region alEffecti
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALEFFECTI)( ALuint eid, ALenum param, ALint value);
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate void Delegate_alEffecti ( uint eid , Enums . EfxEffecti param , int value ) ;
2008-01-18 14:32:51 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alEffecti Imported_alEffecti ;
2008-01-18 14:32:51 +01:00
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to set integer properties on Effect objects.</summary>
/// <param name="eid">Effect object identifier.</param>
/// <param name="param">Effect property to set.</param>
/// <param name="value">Integer value.</param>
[CLSCompliant(false)]
public void Effect ( uint eid , Enums . EfxEffecti param , int value )
{
Imported_alEffecti ( eid , param , value ) ;
}
/// <summary>(Helper) internally calls alEffecti(eid,Enums.EfxEffecti.EffectType,(int) type)</summary>
/// <param name="eid">Effect id.</param>
/// <param name="type">Effect type.</param>
[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
public void BindEffect ( uint eid , Enums . EfxEffectType type )
{
2008-01-18 18:24:39 +01:00
Imported_alEffecti ( eid , Enums . EfxEffecti . EffectType , ( int ) type ) ;
2008-01-18 14:32:51 +01:00
}
#endregion alEffecti
#region alEffectf
2008-01-17 18:05:19 +01:00
2008-01-17 00:57:54 +01:00
// typedef void (__cdecl *LPALEFFECTF)( ALuint eid, ALenum param, ALfloat value);
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate void Delegate_alEffectf ( uint eid , Enums . EfxEffectf param , float value ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alEffectf Imported_alEffectf ;
2008-01-18 14:32:51 +01:00
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to set floating point properties on Effect objects.</summary>
/// <param name="eid">Effect object identifier.</param>
/// <param name="param">Effect property to set.</param>
/// <param name="value">Floating point value.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public void Effect ( uint eid , Enums . EfxEffectf param , float value )
{
Imported_alEffectf ( eid , param , value ) ;
}
2008-01-18 14:32:51 +01:00
#endregion alEffectf
2008-01-18 19:35:43 +01:00
#region alEffectfv
[CLSCompliant(false)]
unsafe private delegate void Delegate_alEffectfv ( uint eid , Enums . EfxEffect3f param , [ In ] float * values ) ;
// typedef void (__cdecl *LPALEFFECTFV)( ALuint eid, ALenum param, ALfloat* values );
[CLSCompliant(false)]
private Delegate_alEffectfv Imported_alEffectfv ;
[CLSCompliant(false)]
public void Effect ( uint eid , Enums . EfxEffect3f param , ref Vector3 values )
{
unsafe
{
fixed ( float * ptr = & values . X )
{
Imported_alEffectfv ( eid , param , ptr ) ;
}
}
}
#endregion alEffectfv
2008-01-18 14:32:51 +01:00
#region alGetEffecti
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETEFFECTI)( ALuint eid, ALenum pname, ALint* value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGetEffecti ( uint eid , Enums . EfxEffecti pname , [ Out ] int * value ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
private Delegate_alGetEffecti Imported_alGetEffecti ;
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to retrieve integer properties from Effect objects.</summary>
/// <param name="eid">Effect object identifier.</param>
/// <param name="pname">Effect property to retrieve.</param>
/// <param name="value">Address where integer value will be stored.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
public void GetEffect ( uint eid , Enums . EfxEffecti pname , out int value )
{
unsafe
{
fixed ( int * ptr = & value )
{
Imported_alGetEffecti ( eid , pname , ptr ) ;
}
}
}
#endregion alGetEffecti
#region alGetEffectf
2008-01-17 18:05:19 +01:00
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETEFFECTF)( ALuint eid, ALenum pname, ALfloat* value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGetEffectf ( uint eid , Enums . EfxEffectf pname , [ Out ] float * value ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
private Delegate_alGetEffectf Imported_alGetEffectf ;
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to retrieve floating point properties from Effect objects.</summary>
/// <param name="eid">Effect object identifier.</param>
/// <param name="pname">Effect property to retrieve.</param>
/// <param name="value">Address where floating point value will be stored.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
public void GetEffect ( uint eid , Enums . EfxEffectf pname , out float value )
{
unsafe
{
fixed ( float * ptr = & value )
{
Imported_alGetEffectf ( eid , pname , ptr ) ;
}
}
}
#endregion alGetEffectf
2008-01-17 18:05:19 +01:00
2008-01-18 19:35:43 +01:00
#region alGetEffectfv
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 19:35:43 +01:00
unsafe private delegate void Delegate_alGetEffectfv ( uint eid , Enums . EfxEffect3f param , [ Out ] float * values ) ;
// typedef void (__cdecl *LPALGETEFFECTFV)( ALuint eid, ALenum pname, ALfloat* values );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 19:35:43 +01:00
private Delegate_alGetEffectfv Imported_alGetEffectfv ;
[CLSCompliant(false)]
public void GetEffect ( uint eid , Enums . EfxEffect3f param , out Vector3 values )
{
unsafe
{
fixed ( float * ptr = & values . X )
{
Imported_alGetEffectfv ( eid , param , ptr ) ;
values . X = ptr [ 0 ] ;
values . Y = ptr [ 1 ] ;
values . Z = ptr [ 2 ] ;
}
}
}
#endregion alGetEffectfv
2008-01-17 20:02:37 +01:00
// Not used:
// typedef void (__cdecl *LPALEFFECTIV)( ALuint eid, ALenum param, ALint* values );
// typedef void (__cdecl *LPALGETEFFECTIV)( ALuint eid, ALenum pname, ALint* values );
2008-01-16 19:43:52 +01:00
2008-01-18 14:32:51 +01:00
#endregion Effect Object
#region Filter Object
2008-01-16 19:43:52 +01:00
2008-01-18 16:50:58 +01:00
#region alGenFilters
2008-01-17 18:05:19 +01:00
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGENFILTERS)( ALsizei n, ALuint* filters );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGenFilters ( int n , [ Out ] uint * filters ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alGenFilters Imported_alGenFilters ;
2008-01-18 18:24:39 +01:00
/// <summary>The alGenFilters function is used to create one or more Filter objects. A Filter object stores a filter type and a set of parameter values to control that Filter. Filter objects can be attached to Sources as Direct Filters or Auxiliary Send Filters.</summary>
2008-01-18 18:33:07 +01:00
/// <remarks>After creation a Filter has no type (AL_FILTER_NULL), so before it can be used to store a set of parameters, the application must specify what type of filter should be stored in the object, using alFilteri.</remarks>
2008-01-18 18:24:39 +01:00
/// <param name="n">Number of Filters to be created.</param>
/// <param name="filters">Pointer addressing sufficient memory to store n Filter object identifiers.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void GenFilters ( int n , out uint filters )
{
unsafe
{
fixed ( uint * ptr = & filters )
{
Imported_alGenFilters ( n , ptr ) ;
filters = * ptr ;
}
}
}
[CLSCompliant(false)]
/// <summary>This function generates only one Filter.</summary>
2008-01-18 18:24:39 +01:00
/// <param name="filter">Storage UInt32 for the new filter name/handle.</param>
2008-01-18 16:50:58 +01:00
public void GenFilters ( out uint filter )
{
unsafe
{
fixed ( uint * ptr = & filter )
{
Imported_alGenFilters ( 1 , ptr ) ;
}
}
}
#endregion alGenFilters
#region alDeleteFilters
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALDELETEFILTERS)( ALsizei n, ALuint* filters );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alDeleteFilters ( int n , [ In ] uint * filters ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alDeleteFilters Imported_alDeleteFilters ;
2008-01-18 18:24:39 +01:00
/// <summary>The alDeleteFilters function is used to delete and free resources for Filter objects previously created with alGenFilters.</summary>
/// <param name="n">Number of Filters to be deleted.</param>
/// <param name="filters">Pointer to n Filter object identifiers.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void DeleteFilters ( int n , ref uint [ ] filters )
{
unsafe
{
fixed ( uint * ptr = filters )
{
2008-01-19 15:18:34 +01:00
Imported_alDeleteFilters ( n , ptr ) ;
2008-01-18 16:50:58 +01:00
}
}
}
/// <summary>This function deletes one Filter only.</summary>
2008-01-18 18:24:39 +01:00
/// <param name="filter">Pointer to an filter name/handle identifying the Filter Object to be deleted.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void DeleteFilters ( ref uint filter )
{
unsafe
{
fixed ( uint * ptr = & filter )
{
2008-01-19 15:18:34 +01:00
Imported_alDeleteFilters ( 1 , ptr ) ;
2008-01-18 16:50:58 +01:00
}
}
}
#endregion alDeleteFilters
#region alIsFilter
2008-01-16 19:43:52 +01:00
// typedef ALboolean (__cdecl *LPALISFILTER)( ALuint fid );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate bool Delegate_alIsFilter ( uint fid ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alIsFilter Imported_alIsFilter ;
/// <summary>The alIsFilter function is used to determine if an object identifier is a valid Filter object.</summary>
/// <param name="fid">Effect identifier to validate.</param>
/// <returns>True if the identifier is a valid Filter, False otherwise.</returns>
[CLSCompliant(false)]
public bool IsFilter ( uint fid )
{
return Imported_alIsFilter ( fid ) ;
}
2008-01-18 16:50:58 +01:00
#endregion alIsFilter
#region alFilteri
2008-01-17 20:02:37 +01:00
// typedef void (__cdecl *LPALFILTERI)( ALuint fid, ALenum param, ALint value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate void Delegate_alFilteri ( uint fid , Enums . EfxFilteri param , int value ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alFilteri Imported_alFilteri ;
2008-01-16 19:43:52 +01:00
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to set integer properties on Filter objects.</summary>
/// <param name="fid">Filter object identifier.</param>
/// <param name="param">Effect property to set.</param>
/// <param name="value">Integer value.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public void Filter ( uint fid , Enums . EfxFilteri param , int value )
{
Imported_alFilteri ( fid , param , value ) ;
}
2008-01-18 16:50:58 +01:00
2008-01-18 18:24:39 +01:00
#endregion alFilteri ( uint fid , Enums . EfxFilteri param , int value )
2008-01-18 16:50:58 +01:00
#region alFilterf
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALFILTERF)( ALuint fid, ALenum param, ALfloat value);
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate void Delegate_alFilterf ( uint fid , Enums . EfxFilterf param , float value ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alFilterf Imported_alFilterf ;
/// <summary>This function is used to set floating point properties on Filter objects.</summary>
/// <param name="fid">Filter object identifier.</param>
/// <param name="param">Effect property to set.</param>
/// <param name="value">Floating point value.</param>
[CLSCompliant(false)]
public void Filter ( uint fid , Enums . EfxFilterf param , float value )
{
Imported_alFilterf ( fid , param , value ) ;
}
2008-01-18 16:50:58 +01:00
#endregion alFilterf
#region alGetFilteri
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETFILTERI)( ALuint fid, ALenum pname, ALint* value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGetFilteri ( uint fid , Enums . EfxFilteri pname , [ Out ] int * value ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alGetFilteri Imported_alGetFilteri ;
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to retrieve integer properties from Filter objects.</summary>
/// <param name="fid">Filter object identifier.</param>
/// <param name="pname">Effect property to retrieve.</param>
/// <param name="value">Address where integer value will be stored.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void GetFilter ( uint fid , Enums . EfxFilteri pname , out int value )
{
unsafe
{
fixed ( int * ptr = & value )
{
Imported_alGetFilteri ( fid , pname , ptr ) ;
}
}
}
#endregion alGetFilteri
#region alGetFilterf
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETFILTERF)( ALuint fid, ALenum pname, ALfloat* value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGetFilterf ( uint fid , Enums . EfxFilterf pname , [ Out ] float * value ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alGetFilterf Imported_alGetFilterf ;
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to retrieve floating point properties from Filter objects.</summary>
/// <param name="fid">Filter object identifier.</param>
/// <param name="pname">Effect property to retrieve.</param>
/// <param name="value">Address where floating point value will be stored.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void GetFilter ( uint fid , Enums . EfxFilterf pname , out float value )
{
unsafe
{
fixed ( float * ptr = & value )
{
Imported_alGetFilterf ( fid , pname , ptr ) ;
}
}
}
#endregion alGetFilterf
2008-01-17 20:02:37 +01:00
// Not used:
// typedef void (__cdecl *LPALFILTERIV)( ALuint fid, ALenum param, ALint* values );
// typedef void (__cdecl *LPALFILTERFV)( ALuint fid, ALenum param, ALfloat* values );
// typedef void (__cdecl *LPALGETFILTERIV)( ALuint fid, ALenum pname, ALint* values );
// typedef void (__cdecl *LPALGETFILTERFV)( ALuint fid, ALenum pname, ALfloat* values );
2008-01-16 19:43:52 +01:00
2008-01-18 16:50:58 +01:00
#endregion Filter Object
#region Auxiliary Effect Slot Object
2008-01-17 00:57:54 +01:00
2008-01-18 16:50:58 +01:00
#region alGenAuxiliaryEffectSlots
2008-01-18 14:32:51 +01:00
2008-01-18 16:50:58 +01:00
// typedef void (__cdecl *LPALGENAUXILIARYEFFECTSLOTS)( ALsizei n, ALuint* slots );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
unsafe private delegate void Delegate_alGenAuxiliaryEffectSlots ( int n , [ Out ] uint * slots ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alGenAuxiliaryEffectSlots Imported_alGenAuxiliaryEffectSlots ;
2008-01-18 18:24:39 +01:00
/// <summary>The alGenAuxiliaryEffectSlots function is used to create one or more Auxiliary Effect Slots. The number of slots that can be created will be dependant upon the Open AL device used.</summary>
/// <remarks>An application should check the OpenAL error state after making this call to determine if the Effect Slot was successfully created. If the function call fails then none of the requested Effect Slots are created. A good strategy for creating any OpenAL object is to use a for-loop and generate one object each loop iteration and then check for an error condition. If an error is set then the loop can be broken and the application can determine if sufficient resources are available.</remarks>
/// <param name="n">Number of Auxiliary Effect Slots to be created.</param>
/// <param name="slots">Pointer addressing sufficient memory to store n Effect Slot object identifiers.</param>
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
public void GenAuxiliaryEffectSlots ( int n , out uint slots )
{
unsafe
{
fixed ( uint * ptr = & slots )
{
Imported_alGenAuxiliaryEffectSlots ( n , ptr ) ;
slots = * ptr ;
}
}
}
2008-01-18 14:32:51 +01:00
[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
/// <summary>This function generates only one Auxiliary Effect Slot.</summary>
2008-01-18 18:24:39 +01:00
/// <param name="slot">Storage UInt32 for the new auxiliary effect slot name/handle.</param>
2008-01-18 16:50:58 +01:00
public void GenAuxiliaryEffectSlots ( out uint slot )
{
unsafe
{
fixed ( uint * ptr = & slot )
{
Imported_alGenAuxiliaryEffectSlots ( 1 , ptr ) ;
}
}
}
2008-01-18 14:32:51 +01:00
2008-01-18 16:50:58 +01:00
#endregion alGenAuxiliaryEffectSlots
2008-01-18 14:32:51 +01:00
2008-01-18 16:50:58 +01:00
#region alDeleteAuxiliaryEffectSlots
2008-01-18 14:32:51 +01:00
2008-01-18 16:50:58 +01:00
// typedef void (__cdecl *LPALDELETEAUXILIARYEFFECTSLOTS)( ALsizei n, ALuint* slots );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
unsafe private delegate void Delegate_alDeleteAuxiliaryEffectSlots ( int n , [ In ] uint * slots ) ;
2008-01-18 14:32:51 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alDeleteAuxiliaryEffectSlots Imported_alDeleteAuxiliaryEffectSlots ;
2008-01-16 19:43:52 +01:00
2008-01-18 18:24:39 +01:00
/// <summary>The alDeleteAuxiliaryEffectSlots function is used to delete and free resources for Auxiliary Effect Slots previously created with alGenAuxiliaryEffectSlots.</summary>
/// <param name="n">Number of Auxiliary Effect Slots to be deleted.</param>
/// <param name="slots">Pointer to n Effect Slot object identifiers.</param>
2008-01-17 21:55:56 +01:00
[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
public void DeleteAuxiliaryEffectSlots ( int n , ref uint [ ] slots )
{
unsafe
{
fixed ( uint * ptr = slots )
{
Imported_alDeleteAuxiliaryEffectSlots ( n , ptr ) ;
}
}
}
2008-01-16 19:43:52 +01:00
2008-01-18 16:50:58 +01:00
/// <summary>This function deletes one AuxiliaryEffectSlot only.</summary>
2008-01-18 18:24:39 +01:00
/// <param name="slot">Pointer to an auxiliary effect slot name/handle identifying the Auxiliary Effect Slot Object to be deleted.</param>
2008-01-17 21:55:56 +01:00
[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
public void DeleteAuxiliaryEffectSlots ( ref uint slot )
{
unsafe
{
fixed ( uint * ptr = & slot )
{
Imported_alDeleteAuxiliaryEffectSlots ( 1 , ptr ) ;
}
}
}
#endregion alDeleteAuxiliaryEffectSlots
#region alIsAuxiliaryEffectSlot
2008-01-16 19:43:52 +01:00
// typedef ALboolean (__cdecl *LPALISAUXILIARYEFFECTSLOT)( ALuint slot );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate bool Delegate_alIsAuxiliaryEffectSlot ( uint slot ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alIsAuxiliaryEffectSlot Imported_alIsAuxiliaryEffectSlot ;
2008-01-16 19:43:52 +01:00
2008-01-18 18:24:39 +01:00
/// <summary>The alIsAuxiliaryEffectSlot function is used to determine if an object identifier is a valid Auxiliary Effect Slot object.</summary>
/// <param name="slot">Effect Slot object identifier to validate.</param>
/// <returns>True if the identifier is a valid Auxiliary Effect Slot, False otherwise.</returns>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public bool IsAuxiliaryEffectSlot ( uint slot )
{
return Imported_alIsAuxiliaryEffectSlot ( slot ) ;
}
2008-01-18 16:50:58 +01:00
#endregion alIsAuxiliaryEffectSlot
#region alAuxiliaryEffectSloti
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALAUXILIARYEFFECTSLOTI)( ALuint asid, ALenum param, ALint value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate void Delegate_alAuxiliaryEffectSloti ( uint asid , Enums . EfxAuxiliaryi param , int value ) ;
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alAuxiliaryEffectSloti Imported_alAuxiliaryEffectSloti ;
2008-01-16 19:43:52 +01:00
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to set integer properties on Auxiliary Effect Slot objects.</summary>
/// <param name="asid">Auxiliary Effect Slot object identifier.</param>
/// <param name="param">Auxiliary Effect Slot property to set.</param>
/// <param name="value">Integer value.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
public void AuxiliaryEffectSlot ( uint asid , Enums . EfxAuxiliaryi param , int value )
{
Imported_alAuxiliaryEffectSloti ( asid , param , value ) ;
}
2008-01-18 16:50:58 +01:00
#endregion alAuxiliaryEffectSloti
#region alAuxiliaryEffectSlotf
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALAUXILIARYEFFECTSLOTF)( ALuint asid, ALenum param, ALfloat value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private delegate void Delegate_alAuxiliaryEffectSlotf ( uint asid , Enums . EfxAuxiliaryf param , float value ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 18:24:39 +01:00
private Delegate_alAuxiliaryEffectSlotf Imported_alAuxiliaryEffectSlotf ;
/// <summary>This function is used to set floating point properties on Auxiliary Effect Slot objects.</summary>
/// <param name="asid">Auxiliary Effect Slot object identifier.</param>
/// <param name="param">Auxiliary Effect Slot property to set.</param>
/// <param name="value">Floating point value.</param>
[CLSCompliant(false)]
public void AuxiliaryEffectSlot ( uint asid , Enums . EfxAuxiliaryf param , float value )
{
Imported_alAuxiliaryEffectSlotf ( asid , param , value ) ;
}
2008-01-18 16:50:58 +01:00
#endregion alAuxiliaryEffectSlotf
#region alGetAuxiliaryEffectSloti
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETAUXILIARYEFFECTSLOTI)( ALuint asid, ALenum pname, ALint* value );
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGetAuxiliaryEffectSloti ( uint asid , Enums . EfxAuxiliaryi pname , [ Out ] int * value ) ;
2008-01-16 19:43:52 +01:00
2008-01-20 20:00:03 +01:00
//[CLSCompliant(false)]
2008-01-18 16:50:58 +01:00
private Delegate_alGetAuxiliaryEffectSloti Imported_alGetAuxiliaryEffectSloti ;
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to retrieve integer properties on Auxiliary Effect Slot objects.</summary>
/// <param name="asid">Auxiliary Effect Slot object identifier.</param>
/// <param name="pname">Auxiliary Effect Slot property to retrieve.</param>
/// <param name="value">Address where integer value will be stored.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void GetAuxiliaryEffectSlot ( uint asid , Enums . EfxAuxiliaryi pname , out int value )
{
unsafe
{
fixed ( int * ptr = & value )
{
Imported_alGetAuxiliaryEffectSloti ( asid , pname , ptr ) ;
}
}
}
#endregion alGetAuxiliaryEffectSloti
#region alGetAuxiliaryEffectSlotf
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETAUXILIARYEFFECTSLOTF)( ALuint asid, ALenum pname, ALfloat* value );
2008-01-17 21:55:56 +01:00
[CLSCompliant(false)]
2008-01-18 14:32:51 +01:00
unsafe private delegate void Delegate_alGetAuxiliaryEffectSlotf ( uint asid , Enums . EfxAuxiliaryf pname , [ Out ] float * value ) ;
2008-01-17 20:02:37 +01:00
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
private Delegate_alGetAuxiliaryEffectSlotf Imported_alGetAuxiliaryEffectSlotf ;
2008-01-18 18:24:39 +01:00
/// <summary>This function is used to retrieve floating properties on Auxiliary Effect Slot objects.</summary>
/// <param name="asid">Auxiliary Effect Slot object identifier.</param>
/// <param name="pname">Auxiliary Effect Slot property to retrieve.</param>
/// <param name="value">Address where floating point value will be stored.</param>
2008-01-18 16:50:58 +01:00
[CLSCompliant(false)]
public void GetAuxiliaryEffectSlot ( uint asid , Enums . EfxAuxiliaryf pname , out float value )
{
unsafe
{
fixed ( float * ptr = & value )
{
Imported_alGetAuxiliaryEffectSlotf ( asid , pname , ptr ) ;
}
}
}
#endregion alGetAuxiliaryEffectSlotf
2008-01-17 20:02:37 +01:00
// Not used:
// typedef void (__cdecl *LPALAUXILIARYEFFECTSLOTIV)( ALuint asid, ALenum param, ALint* values );
// typedef void (__cdecl *LPALAUXILIARYEFFECTSLOTFV)( ALuint asid, ALenum param, ALfloat* values );
// typedef void (__cdecl *LPALGETAUXILIARYEFFECTSLOTIV)( ALuint asid, ALenum pname, ALint* values );
2008-01-16 19:43:52 +01:00
// typedef void (__cdecl *LPALGETAUXILIARYEFFECTSLOTFV)( ALuint asid, ALenum pname, ALfloat* values );
2008-01-17 20:02:37 +01:00
2008-01-18 16:50:58 +01:00
#endregion Auxiliary Effect Slot Object
2008-01-17 21:55:56 +01:00
#region Constructor / Extension Loading
private bool _valid ;
/// <summary>Returns True if the EFX Extension has been found and could be initialized.</summary>
public bool IsInitialized
{ get { return _valid ; } }
2008-01-18 14:32:51 +01:00
public EfxExtension ( )
2008-01-17 21:55:56 +01:00
{
_valid = false ;
2008-01-18 14:32:51 +01:00
if ( Alc . IsExtensionPresent ( Alc . GetContextsDevice ( Alc . GetCurrentContext ( ) ) , "ALC_EXT_EFX" ) = = false )
2008-01-17 21:55:56 +01:00
{
Console . WriteLine ( "Extension unknown." ) ;
return ;
}
2008-01-17 22:53:51 +01:00
Console . WriteLine ( "ALC_EXT_EFX found." ) ;
2008-01-17 21:55:56 +01:00
try
{
2008-01-18 14:32:51 +01:00
Imported_alGenEffects = ( Delegate_alGenEffects ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGenEffects" ) , typeof ( Delegate_alGenEffects ) ) ;
Imported_alDeleteEffects = ( Delegate_alDeleteEffects ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alDeleteEffects" ) , typeof ( Delegate_alDeleteEffects ) ) ;
2008-01-18 18:24:39 +01:00
Imported_alIsEffect = ( Delegate_alIsEffect ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alIsEffect" ) , typeof ( Delegate_alIsEffect ) ) ;
Imported_alEffecti = ( Delegate_alEffecti ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alEffecti" ) , typeof ( Delegate_alEffecti ) ) ;
Imported_alEffectf = ( Delegate_alEffectf ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alEffectf" ) , typeof ( Delegate_alEffectf ) ) ;
2008-01-18 19:35:43 +01:00
Imported_alEffectfv = ( Delegate_alEffectfv ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alEffectfv" ) , typeof ( Delegate_alEffectfv ) ) ;
2008-01-18 14:32:51 +01:00
Imported_alGetEffecti = ( Delegate_alGetEffecti ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetEffecti" ) , typeof ( Delegate_alGetEffecti ) ) ;
Imported_alGetEffectf = ( Delegate_alGetEffectf ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetEffectf" ) , typeof ( Delegate_alGetEffectf ) ) ;
2008-01-18 19:35:43 +01:00
Imported_alGetEffectfv = ( Delegate_alGetEffectfv ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetEffectfv" ) , typeof ( Delegate_alGetEffectfv ) ) ;
2008-01-18 14:32:51 +01:00
} catch ( Exception e )
2008-01-17 21:55:56 +01:00
{
2008-01-18 14:32:51 +01:00
Console . WriteLine ( "Failed to marshal Effect functions. " + e . ToString ( ) ) ;
2008-01-17 21:55:56 +01:00
return ;
}
2008-01-17 22:53:51 +01:00
Console . WriteLine ( "Effect functions appear to be ok." ) ;
2008-01-17 21:55:56 +01:00
try
{
2008-01-18 14:32:51 +01:00
Imported_alGenFilters = ( Delegate_alGenFilters ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGenFilters" ) , typeof ( Delegate_alGenFilters ) ) ;
Imported_alDeleteFilters = ( Delegate_alDeleteFilters ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alDeleteFilters" ) , typeof ( Delegate_alDeleteFilters ) ) ;
2008-01-18 18:24:39 +01:00
Imported_alIsFilter = ( Delegate_alIsFilter ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alIsFilter" ) , typeof ( Delegate_alIsFilter ) ) ;
Imported_alFilteri = ( Delegate_alFilteri ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alFilteri" ) , typeof ( Delegate_alFilteri ) ) ;
Imported_alFilterf = ( Delegate_alFilterf ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alFilterf" ) , typeof ( Delegate_alFilterf ) ) ;
2008-01-18 14:32:51 +01:00
Imported_alGetFilteri = ( Delegate_alGetFilteri ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetFilteri" ) , typeof ( Delegate_alGetFilteri ) ) ;
Imported_alGetFilterf = ( Delegate_alGetFilterf ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetFilterf" ) , typeof ( Delegate_alGetFilterf ) ) ;
} catch ( Exception e )
2008-01-17 21:55:56 +01:00
{
2008-01-18 14:32:51 +01:00
Console . WriteLine ( "Failed to marshal Filter functions. " + e . ToString ( ) ) ;
2008-01-17 21:55:56 +01:00
return ;
}
2008-01-17 22:53:51 +01:00
Console . WriteLine ( "Filter functions appear to be ok." ) ;
2008-01-17 21:55:56 +01:00
try
{
2008-01-18 14:32:51 +01:00
Imported_alGenAuxiliaryEffectSlots = ( Delegate_alGenAuxiliaryEffectSlots ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGenAuxiliaryEffectSlots" ) , typeof ( Delegate_alGenAuxiliaryEffectSlots ) ) ;
Imported_alDeleteAuxiliaryEffectSlots = ( Delegate_alDeleteAuxiliaryEffectSlots ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alDeleteAuxiliaryEffectSlots" ) , typeof ( Delegate_alDeleteAuxiliaryEffectSlots ) ) ;
2008-01-18 18:24:39 +01:00
Imported_alIsAuxiliaryEffectSlot = ( Delegate_alIsAuxiliaryEffectSlot ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alIsAuxiliaryEffectSlot" ) , typeof ( Delegate_alIsAuxiliaryEffectSlot ) ) ;
Imported_alAuxiliaryEffectSloti = ( Delegate_alAuxiliaryEffectSloti ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alAuxiliaryEffectSloti" ) , typeof ( Delegate_alAuxiliaryEffectSloti ) ) ;
Imported_alAuxiliaryEffectSlotf = ( Delegate_alAuxiliaryEffectSlotf ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alAuxiliaryEffectSlotf" ) , typeof ( Delegate_alAuxiliaryEffectSlotf ) ) ;
2008-01-18 14:32:51 +01:00
Imported_alGetAuxiliaryEffectSloti = ( Delegate_alGetAuxiliaryEffectSloti ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetAuxiliaryEffectSloti" ) , typeof ( Delegate_alGetAuxiliaryEffectSloti ) ) ;
Imported_alGetAuxiliaryEffectSlotf = ( Delegate_alGetAuxiliaryEffectSlotf ) Marshal . GetDelegateForFunctionPointer ( AL . GetProcAddress ( "alGetAuxiliaryEffectSlotf" ) , typeof ( Delegate_alGetAuxiliaryEffectSlotf ) ) ;
} catch ( Exception e )
2008-01-17 21:55:56 +01:00
{
2008-01-18 14:32:51 +01:00
Console . WriteLine ( "Failed to marshal AuxiliaryEffectSlot functions. " + e . ToString ( ) ) ;
2008-01-17 21:55:56 +01:00
return ;
}
2008-01-17 22:53:51 +01:00
Console . WriteLine ( "Auxiliary Effect Slot functions appear to be ok." ) ;
2008-01-17 21:55:56 +01:00
2008-01-18 18:33:07 +01:00
// didn't return so far, everything went fine.
2008-01-17 21:55:56 +01:00
_valid = true ;
}
#endregion Constructor / Extension Loading
2008-01-16 19:43:52 +01:00
}
2008-01-18 14:32:51 +01:00
2008-01-16 19:43:52 +01:00
}