3D Sound

TeamSpeak 3 supports 3D sound to assign each speaker a unique position in 3D space. Provided are functions to modify the 3D position, velocity and orientation of own and foreign clients.

Generally the struct TS3_VECTOR describes a vector in 3D space:

typedef struct {
    float x;        /* X coordinate in 3D space. */
    float y;        /* Y coordinate in 3D space. */
    float z;        /* Z coordinate in 3D space. */
} TS3_VECTOR;

To set the position, velocity and orientation of the own client in 3D space, call:

unsigned int ts3client_systemset3DListenerAttributes(serverConnectionHandlerID, á
áposition, á
áforward, á
áup);á
uint64 serverConnectionHandlerID;
const TS3_VECTOR* position;
const TS3_VECTOR* forward;
const TS3_VECTOR* up;
á

Parameters

Returns ERROR_ok on success, otherwise an error code as defined in public_errors.h.


To adjust 3D sound system settings use:

unsigned int ts3client_systemset3DSettings(serverConnectionHandlerID, á
ádistanceFactor, á
árolloffScale);á
uint64 serverConnectionHandlerID;
float distanceFactor;
float rolloffScale;
á

Parameters

Returns ERROR_ok on success, otherwise an error code as defined in public_errors.h.


To adjust a clients position and velocity in 3D space, call:

unsigned int ts3client_channelset3DAttributes(serverConnectionHandlerID, á
áclientID, á
áposition);á
uint64 serverConnectionHandlerID;
anyID clientID;
const TS3_VECTOR* position;
á

Parameters

Returns ERROR_ok on success, otherwise an error code as defined in public_errors.h.


This event is called to calculate volume attenuation for distance in 3D positioning of clients.

void onCustom3dRolloffCalculationClientEvent(serverConnectionHandlerID, á
áclientID, á
ádistance, á
ávolume);á
uint64 serverConnectionHandlerID;
anyID clientID;
float distance;
float* volume;
á

Parameters


This event is called to calculate volume attenuation for distance in 3D positioning of a wave file that was opened previously with ts3client_playWaveFileHandle.

void onCustom3dRolloffCalculationWaveEvent(serverConnectionHandlerID, á
áwaveHandle, á
ádistance, á
ávolume);á
uint64 serverConnectionHandlerID;
uint64 waveHandle;
float distance;
float* volume;
á

Parameters


This method is used to 3D position a wave file that was opened previously with ts3client_playWaveFileHandle.

unsigned int ts3client_set3DWaveAttributes(serverConnectionHandlerID, á
áwaveHandle, á
áposition);á
uint64 serverConnectionHandlerID;
uint64 waveHandle;
const TS3_VECTOR* position;
á

Parameters

Returns ERROR_ok on success, otherwise an error code as defined in public_errors.h.