瀏覽代碼

Rename SoundInternal to SoundData for consistency with MusicData.

pull/413/head
David Reid 7 年之前
父節點
當前提交
b0852002b8
共有 2 個檔案被更改,包括 24 行新增20 行删除
  1. +23
    -19
      src/audio.c
  2. +1
    -1
      src/raylib.h

+ 23
- 19
src/audio.c 查看文件

@ -211,8 +211,8 @@ void TraceLog(int msgType, const char *text, ...); // Show trace lo
#define DEVICE_CHANNELS 2 #define DEVICE_CHANNELS 2
#define DEVICE_SAMPLE_RATE 44100 #define DEVICE_SAMPLE_RATE 44100
typedef struct SoundInternal SoundInternal;
struct SoundInternal
typedef struct SoundData SoundData;
struct SoundData
{ {
mal_format format; mal_format format;
mal_uint32 channels; mal_uint32 channels;
@ -224,8 +224,8 @@ struct SoundInternal
bool playing; bool playing;
bool paused; bool paused;
bool looping; bool looping;
SoundInternal* next;
SoundInternal* prev;
SoundData* next;
SoundData* prev;
mal_uint8 data[1]; // Raw audio data. mal_uint8 data[1]; // Raw audio data.
}; };
@ -234,10 +234,10 @@ static mal_device device;
static mal_bool32 isAudioInitialized = MAL_FALSE; static mal_bool32 isAudioInitialized = MAL_FALSE;
static float masterVolume = 1; static float masterVolume = 1;
static mal_mutex soundLock; static mal_mutex soundLock;
static SoundInternal* firstSound; // Sounds are tracked in a linked list.
static SoundInternal* lastSound;
static SoundData* firstSound; // Sounds are tracked in a linked list.
static SoundData* lastSound;
static void AppendSound(SoundInternal* internalSound)
static void AppendSound(SoundData* internalSound)
{ {
mal_mutex_lock(&context, &soundLock); mal_mutex_lock(&context, &soundLock);
{ {
@ -253,7 +253,7 @@ static void AppendSound(SoundInternal* internalSound)
mal_mutex_unlock(&context, &soundLock); mal_mutex_unlock(&context, &soundLock);
} }
static void RemoveSound(SoundInternal* internalSound)
static void RemoveSound(SoundData* internalSound)
{ {
mal_mutex_lock(&context, &soundLock); mal_mutex_lock(&context, &soundLock);
{ {
@ -294,7 +294,7 @@ static mal_uint32 OnSendAudioDataToDevice(mal_device* pDevice, mal_uint32 frameC
float* pFramesOutF = (float*)pFramesOut; // <-- Just for convenience. float* pFramesOutF = (float*)pFramesOut; // <-- Just for convenience.
// Sounds. // Sounds.
for (SoundInternal* internalSound = firstSound; internalSound != NULL; internalSound = internalSound->next)
for (SoundData* internalSound = firstSound; internalSound != NULL; internalSound = internalSound->next)
{ {
// Ignore stopped or paused sounds. // Ignore stopped or paused sounds.
if (!internalSound->playing || internalSound->paused) { if (!internalSound->playing || internalSound->paused) {
@ -583,7 +583,7 @@ Sound LoadSoundFromWave(Wave wave)
TraceLog(LOG_ERROR, "LoadSoundFromWave() : Failed to get frame count for format conversion."); TraceLog(LOG_ERROR, "LoadSoundFromWave() : Failed to get frame count for format conversion.");
} }
SoundInternal* internalSound = (SoundInternal*)calloc(sizeof(*internalSound) + (frameCount*DEVICE_CHANNELS*4), 1); // <-- Make sure this is initialized to zero for safety.
SoundData* internalSound = (SoundData*)calloc(sizeof(*internalSound) + (frameCount*DEVICE_CHANNELS*4), 1); // <-- Make sure this is initialized to zero for safety.
if (internalSound == NULL) { if (internalSound == NULL) {
TraceLog(LOG_ERROR, "LoadSoundFromWave() : Failed to allocate memory for internal buffer"); TraceLog(LOG_ERROR, "LoadSoundFromWave() : Failed to allocate memory for internal buffer");
} }
@ -678,7 +678,7 @@ void UnloadWave(Wave wave)
void UnloadSound(Sound sound) void UnloadSound(Sound sound)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
RemoveSound(internalSound); RemoveSound(internalSound);
free(internalSound); free(internalSound);
#else #else
@ -696,7 +696,7 @@ void UnloadSound(Sound sound)
void UpdateSound(Sound sound, const void *data, int samplesCount) void UpdateSound(Sound sound, const void *data, int samplesCount)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "UpdateSound() : Invalid sound"); TraceLog(LOG_ERROR, "UpdateSound() : Invalid sound");
@ -739,7 +739,7 @@ void UpdateSound(Sound sound, const void *data, int samplesCount)
void PlaySound(Sound sound) void PlaySound(Sound sound)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "PlaySound() : Invalid sound"); TraceLog(LOG_ERROR, "PlaySound() : Invalid sound");
@ -773,7 +773,7 @@ void PlaySound(Sound sound)
void PauseSound(Sound sound) void PauseSound(Sound sound)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "PauseSound() : Invalid sound"); TraceLog(LOG_ERROR, "PauseSound() : Invalid sound");
@ -790,7 +790,7 @@ void PauseSound(Sound sound)
void ResumeSound(Sound sound) void ResumeSound(Sound sound)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "ResumeSound() : Invalid sound"); TraceLog(LOG_ERROR, "ResumeSound() : Invalid sound");
@ -811,7 +811,7 @@ void ResumeSound(Sound sound)
void StopSound(Sound sound) void StopSound(Sound sound)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "StopSound() : Invalid sound"); TraceLog(LOG_ERROR, "StopSound() : Invalid sound");
@ -829,7 +829,7 @@ void StopSound(Sound sound)
bool IsSoundPlaying(Sound sound) bool IsSoundPlaying(Sound sound)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "IsSoundPlaying() : Invalid sound"); TraceLog(LOG_ERROR, "IsSoundPlaying() : Invalid sound");
@ -852,7 +852,7 @@ bool IsSoundPlaying(Sound sound)
void SetSoundVolume(Sound sound, float volume) void SetSoundVolume(Sound sound, float volume)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "SetSoundVolume() : Invalid sound"); TraceLog(LOG_ERROR, "SetSoundVolume() : Invalid sound");
@ -869,7 +869,7 @@ void SetSoundVolume(Sound sound, float volume)
void SetSoundPitch(Sound sound, float pitch) void SetSoundPitch(Sound sound, float pitch)
{ {
#if USE_MINI_AL #if USE_MINI_AL
SoundInternal* internalSound = (SoundInternal*)sound.handle;
SoundData* internalSound = (SoundData*)sound.handle;
if (internalSound == NULL) if (internalSound == NULL)
{ {
TraceLog(LOG_ERROR, "SetSoundPitch() : Invalid sound"); TraceLog(LOG_ERROR, "SetSoundPitch() : Invalid sound");
@ -1173,7 +1173,11 @@ void UnloadMusicStream(Music music)
// Start music playing (open stream) // Start music playing (open stream)
void PlayMusicStream(Music music) void PlayMusicStream(Music music)
{ {
#if USE_MINI_AL
//InternalMusic* internalMusic =
#else
alSourcePlay(music->stream.source); alSourcePlay(music->stream.source);
#endif
} }
// Pause music playing // Pause music playing

+ 1
- 1
src/raylib.h 查看文件

@ -486,7 +486,7 @@ typedef struct Wave {
// Sound source type // Sound source type
typedef struct Sound { typedef struct Sound {
void* handle; // A pointer to internal data used by the sound system.
void* handle; // A pointer to internal data used by the audio system.
unsigned int source; // OpenAL audio source id unsigned int source; // OpenAL audio source id
unsigned int buffer; // OpenAL audio buffer id unsigned int buffer; // OpenAL audio buffer id

Loading…
取消
儲存