Compare commits
3 Commits
1f4fdb1e05
...
ee0e43103f
| Author | SHA1 | Date | |
|---|---|---|---|
| ee0e43103f | |||
| 439f5fdb38 | |||
| ba2fa79d97 |
158
source/external/jail_audio.cpp
vendored
158
source/external/jail_audio.cpp
vendored
@@ -92,13 +92,17 @@ Uint32 JA_UpdateCallback(void *userdata, SDL_TimerID timerID, Uint32 interval)
|
|||||||
{
|
{
|
||||||
if (JA_musicEnabled && current_music && current_music->state == JA_MUSIC_PLAYING)
|
if (JA_musicEnabled && current_music && current_music->state == JA_MUSIC_PLAYING)
|
||||||
{
|
{
|
||||||
if (fading) {
|
if (fading)
|
||||||
|
{
|
||||||
int time = SDL_GetTicks();
|
int time = SDL_GetTicks();
|
||||||
if (time > (fade_start_time+fade_duration)) {
|
if (time > (fade_start_time + fade_duration))
|
||||||
|
{
|
||||||
fading = false;
|
fading = false;
|
||||||
JA_StopMusic();
|
JA_StopMusic();
|
||||||
return 30;
|
return 30;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
const int time_passed = time - fade_start_time;
|
const int time_passed = time - fade_start_time;
|
||||||
const float percent = (float)time_passed / (float)fade_duration;
|
const float percent = (float)time_passed / (float)fade_duration;
|
||||||
SDL_SetAudioStreamGain(current_music->stream, JA_musicVolume * (1.0 - percent));
|
SDL_SetAudioStreamGain(current_music->stream, JA_musicVolume * (1.0 - percent));
|
||||||
@@ -107,14 +111,17 @@ Uint32 JA_UpdateCallback(void *userdata, SDL_TimerID timerID, Uint32 interval)
|
|||||||
|
|
||||||
if (current_music->times != 0)
|
if (current_music->times != 0)
|
||||||
{
|
{
|
||||||
if ((Uint32)SDL_GetAudioStreamAvailable(current_music->stream) < (current_music->length/2)) {
|
if ((Uint32)SDL_GetAudioStreamAvailable(current_music->stream) < (current_music->length / 2))
|
||||||
|
{
|
||||||
SDL_PutAudioStreamData(current_music->stream, current_music->buffer, current_music->length);
|
SDL_PutAudioStreamData(current_music->stream, current_music->buffer, current_music->length);
|
||||||
}
|
}
|
||||||
if (current_music->times>0) current_music->times--;
|
if (current_music->times > 0)
|
||||||
|
current_music->times--;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (SDL_GetAudioStreamAvailable(current_music->stream) == 0) JA_StopMusic();
|
if (SDL_GetAudioStreamAvailable(current_music->stream) == 0)
|
||||||
|
JA_StopMusic();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -125,17 +132,19 @@ Uint32 JA_UpdateCallback(void *userdata, SDL_TimerID timerID, Uint32 interval)
|
|||||||
{
|
{
|
||||||
if (channels[i].times != 0)
|
if (channels[i].times != 0)
|
||||||
{
|
{
|
||||||
if ((Uint32)SDL_GetAudioStreamAvailable(channels[i].stream) < (channels[i].sound->length/2)) {
|
if ((Uint32)SDL_GetAudioStreamAvailable(channels[i].stream) < (channels[i].sound->length / 2))
|
||||||
|
{
|
||||||
SDL_PutAudioStreamData(channels[i].stream, channels[i].sound->buffer, channels[i].sound->length);
|
SDL_PutAudioStreamData(channels[i].stream, channels[i].sound->buffer, channels[i].sound->length);
|
||||||
if (channels[i].times>0) channels[i].times--;
|
if (channels[i].times > 0)
|
||||||
|
channels[i].times--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (SDL_GetAudioStreamAvailable(channels[i].stream) == 0) JA_StopChannel(i);
|
if (SDL_GetAudioStreamAvailable(channels[i].stream) == 0)
|
||||||
|
JA_StopChannel(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 30;
|
return 30;
|
||||||
@@ -149,19 +158,23 @@ void JA_Init(const int freq, const SDL_AudioFormat format, const int num_channel
|
|||||||
|
|
||||||
SDL_Log("Iniciant JailAudio...");
|
SDL_Log("Iniciant JailAudio...");
|
||||||
JA_audioSpec = {format, num_channels, freq};
|
JA_audioSpec = {format, num_channels, freq};
|
||||||
if (!sdlAudioDevice) SDL_CloseAudioDevice(sdlAudioDevice);
|
if (!sdlAudioDevice)
|
||||||
|
SDL_CloseAudioDevice(sdlAudioDevice);
|
||||||
sdlAudioDevice = SDL_OpenAudioDevice(SDL_AUDIO_DEVICE_DEFAULT_PLAYBACK, &JA_audioSpec);
|
sdlAudioDevice = SDL_OpenAudioDevice(SDL_AUDIO_DEVICE_DEFAULT_PLAYBACK, &JA_audioSpec);
|
||||||
SDL_Log((sdlAudioDevice == 0) ? "Failed to initialize SDL audio!\n" : "OK!\n");
|
SDL_Log((sdlAudioDevice == 0) ? "Failed to initialize SDL audio!\n" : "OK!\n");
|
||||||
for (int i=0;i<JA_MAX_SIMULTANEOUS_CHANNELS;++i) channels[i].state = JA_CHANNEL_FREE;
|
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; ++i)
|
||||||
|
channels[i].state = JA_CHANNEL_FREE;
|
||||||
// SDL_PauseAudioDevice(sdlAudioDevice);
|
// SDL_PauseAudioDevice(sdlAudioDevice);
|
||||||
JA_timerID = SDL_AddTimer(30, JA_UpdateCallback, nullptr);
|
JA_timerID = SDL_AddTimer(30, JA_UpdateCallback, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void JA_Quit()
|
void JA_Quit()
|
||||||
{
|
{
|
||||||
if (JA_timerID) SDL_RemoveTimer(JA_timerID);
|
if (JA_timerID)
|
||||||
|
SDL_RemoveTimer(JA_timerID);
|
||||||
|
|
||||||
if (!sdlAudioDevice) SDL_CloseAudioDevice(sdlAudioDevice);
|
if (!sdlAudioDevice)
|
||||||
|
SDL_CloseAudioDevice(sdlAudioDevice);
|
||||||
sdlAudioDevice = 0;
|
sdlAudioDevice = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -193,7 +206,8 @@ JA_Music_t *JA_LoadMusic(const char* filename)
|
|||||||
long fsize = ftell(f);
|
long fsize = ftell(f);
|
||||||
fseek(f, 0, SEEK_SET);
|
fseek(f, 0, SEEK_SET);
|
||||||
Uint8 *buffer = (Uint8 *)malloc(fsize + 1);
|
Uint8 *buffer = (Uint8 *)malloc(fsize + 1);
|
||||||
if (fread(buffer, fsize, 1, f)!=1) return NULL;
|
if (fread(buffer, fsize, 1, f) != 1)
|
||||||
|
return NULL;
|
||||||
fclose(f);
|
fclose(f);
|
||||||
|
|
||||||
JA_Music_t *music = JA_LoadMusic(buffer, fsize);
|
JA_Music_t *music = JA_LoadMusic(buffer, fsize);
|
||||||
@@ -205,7 +219,8 @@ JA_Music_t *JA_LoadMusic(const char* filename)
|
|||||||
|
|
||||||
void JA_PlayMusic(JA_Music_t *music, const int loop)
|
void JA_PlayMusic(JA_Music_t *music, const int loop)
|
||||||
{
|
{
|
||||||
if (!JA_musicEnabled) return;
|
if (!JA_musicEnabled)
|
||||||
|
return;
|
||||||
|
|
||||||
JA_StopMusic();
|
JA_StopMusic();
|
||||||
|
|
||||||
@@ -215,16 +230,23 @@ void JA_PlayMusic(JA_Music_t *music, const int loop)
|
|||||||
current_music->times = loop;
|
current_music->times = loop;
|
||||||
|
|
||||||
current_music->stream = SDL_CreateAudioStream(¤t_music->spec, &JA_audioSpec);
|
current_music->stream = SDL_CreateAudioStream(¤t_music->spec, &JA_audioSpec);
|
||||||
if (!SDL_PutAudioStreamData(current_music->stream, current_music->buffer, current_music->length)) printf("[ERROR] SDL_PutAudioStreamData failed!\n");
|
if (!SDL_PutAudioStreamData(current_music->stream, current_music->buffer, current_music->length))
|
||||||
|
printf("[ERROR] SDL_PutAudioStreamData failed!\n");
|
||||||
SDL_SetAudioStreamGain(current_music->stream, JA_musicVolume);
|
SDL_SetAudioStreamGain(current_music->stream, JA_musicVolume);
|
||||||
if (!SDL_BindAudioStream(sdlAudioDevice, current_music->stream)) printf("[ERROR] SDL_BindAudioStream failed!\n");
|
if (!SDL_BindAudioStream(sdlAudioDevice, current_music->stream))
|
||||||
|
{
|
||||||
|
printf("[ERROR] SDL_BindAudioStream failed: %s\n", SDL_GetError());
|
||||||
|
}
|
||||||
|
|
||||||
// SDL_ResumeAudioStreamDevice(current_music->stream);
|
// SDL_ResumeAudioStreamDevice(current_music->stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
void JA_PauseMusic()
|
void JA_PauseMusic()
|
||||||
{
|
{
|
||||||
if (!JA_musicEnabled) return;
|
if (!JA_musicEnabled)
|
||||||
if (!current_music || current_music->state == JA_MUSIC_INVALID) return;
|
return;
|
||||||
|
if (!current_music || current_music->state == JA_MUSIC_INVALID)
|
||||||
|
return;
|
||||||
|
|
||||||
current_music->state = JA_MUSIC_PAUSED;
|
current_music->state = JA_MUSIC_PAUSED;
|
||||||
// SDL_PauseAudioStreamDevice(current_music->stream);
|
// SDL_PauseAudioStreamDevice(current_music->stream);
|
||||||
@@ -233,8 +255,10 @@ void JA_PauseMusic()
|
|||||||
|
|
||||||
void JA_ResumeMusic()
|
void JA_ResumeMusic()
|
||||||
{
|
{
|
||||||
if (!JA_musicEnabled) return;
|
if (!JA_musicEnabled)
|
||||||
if (!current_music || current_music->state == JA_MUSIC_INVALID) return;
|
return;
|
||||||
|
if (!current_music || current_music->state == JA_MUSIC_INVALID)
|
||||||
|
return;
|
||||||
|
|
||||||
current_music->state = JA_MUSIC_PLAYING;
|
current_music->state = JA_MUSIC_PLAYING;
|
||||||
// SDL_ResumeAudioStreamDevice(current_music->stream);
|
// SDL_ResumeAudioStreamDevice(current_music->stream);
|
||||||
@@ -243,8 +267,10 @@ void JA_ResumeMusic()
|
|||||||
|
|
||||||
void JA_StopMusic()
|
void JA_StopMusic()
|
||||||
{
|
{
|
||||||
if (!JA_musicEnabled) return;
|
if (!JA_musicEnabled)
|
||||||
if (!current_music || current_music->state == JA_MUSIC_INVALID) return;
|
return;
|
||||||
|
if (!current_music || current_music->state == JA_MUSIC_INVALID)
|
||||||
|
return;
|
||||||
|
|
||||||
current_music->pos = 0;
|
current_music->pos = 0;
|
||||||
current_music->state = JA_MUSIC_STOPPED;
|
current_music->state = JA_MUSIC_STOPPED;
|
||||||
@@ -255,8 +281,10 @@ void JA_StopMusic()
|
|||||||
|
|
||||||
void JA_FadeOutMusic(const int milliseconds)
|
void JA_FadeOutMusic(const int milliseconds)
|
||||||
{
|
{
|
||||||
if (!JA_musicEnabled) return;
|
if (!JA_musicEnabled)
|
||||||
if (current_music == NULL || current_music->state == JA_MUSIC_INVALID) return;
|
return;
|
||||||
|
if (current_music == NULL || current_music->state == JA_MUSIC_INVALID)
|
||||||
|
return;
|
||||||
|
|
||||||
fading = true;
|
fading = true;
|
||||||
fade_start_time = SDL_GetTicks();
|
fade_start_time = SDL_GetTicks();
|
||||||
@@ -266,50 +294,54 @@ void JA_FadeOutMusic(const int milliseconds)
|
|||||||
|
|
||||||
JA_Music_state JA_GetMusicState()
|
JA_Music_state JA_GetMusicState()
|
||||||
{
|
{
|
||||||
if (!JA_musicEnabled) return JA_MUSIC_DISABLED;
|
if (!JA_musicEnabled)
|
||||||
if (!current_music) return JA_MUSIC_INVALID;
|
return JA_MUSIC_DISABLED;
|
||||||
|
if (!current_music)
|
||||||
|
return JA_MUSIC_INVALID;
|
||||||
|
|
||||||
return current_music->state;
|
return current_music->state;
|
||||||
}
|
}
|
||||||
|
|
||||||
void JA_DeleteMusic(JA_Music_t *music)
|
void JA_DeleteMusic(JA_Music_t *music)
|
||||||
{
|
{
|
||||||
if (current_music == music) current_music = nullptr;
|
if (current_music == music)
|
||||||
|
current_music = nullptr;
|
||||||
SDL_free(music->buffer);
|
SDL_free(music->buffer);
|
||||||
if (music->stream) SDL_DestroyAudioStream(music->stream);
|
if (music->stream)
|
||||||
|
SDL_DestroyAudioStream(music->stream);
|
||||||
delete music;
|
delete music;
|
||||||
}
|
}
|
||||||
|
|
||||||
float JA_SetMusicVolume(float volume)
|
float JA_SetMusicVolume(float volume)
|
||||||
{
|
{
|
||||||
JA_musicVolume = SDL_clamp(volume, 0.0f, 1.0f);
|
JA_musicVolume = SDL_clamp(volume, 0.0f, 1.0f);
|
||||||
if (current_music) SDL_SetAudioStreamGain(current_music->stream, JA_musicVolume);
|
if (current_music)
|
||||||
|
SDL_SetAudioStreamGain(current_music->stream, JA_musicVolume);
|
||||||
return JA_musicVolume;
|
return JA_musicVolume;
|
||||||
}
|
}
|
||||||
|
|
||||||
void JA_SetMusicPosition(float value)
|
void JA_SetMusicPosition(float value)
|
||||||
{
|
{
|
||||||
if (!current_music) return;
|
if (!current_music)
|
||||||
|
return;
|
||||||
current_music->pos = value * current_music->spec.freq;
|
current_music->pos = value * current_music->spec.freq;
|
||||||
}
|
}
|
||||||
|
|
||||||
float JA_GetMusicPosition()
|
float JA_GetMusicPosition()
|
||||||
{
|
{
|
||||||
if (!current_music) return 0;
|
if (!current_music)
|
||||||
|
return 0;
|
||||||
return float(current_music->pos) / float(current_music->spec.freq);
|
return float(current_music->pos) / float(current_music->spec.freq);
|
||||||
}
|
}
|
||||||
|
|
||||||
void JA_EnableMusic(const bool value)
|
void JA_EnableMusic(const bool value)
|
||||||
{
|
{
|
||||||
if ( !value && current_music && (current_music->state==JA_MUSIC_PLAYING) ) JA_StopMusic();
|
if (!value && current_music && (current_music->state == JA_MUSIC_PLAYING))
|
||||||
|
JA_StopMusic();
|
||||||
|
|
||||||
JA_musicEnabled = value;
|
JA_musicEnabled = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
JA_Sound_t *JA_NewSound(Uint8 *buffer, Uint32 length)
|
JA_Sound_t *JA_NewSound(Uint8 *buffer, Uint32 length)
|
||||||
{
|
{
|
||||||
JA_Sound_t *sound = new JA_Sound_t();
|
JA_Sound_t *sound = new JA_Sound_t();
|
||||||
@@ -336,11 +368,16 @@ JA_Sound_t *JA_LoadSound(const char* filename)
|
|||||||
|
|
||||||
int JA_PlaySound(JA_Sound_t *sound, const int loop)
|
int JA_PlaySound(JA_Sound_t *sound, const int loop)
|
||||||
{
|
{
|
||||||
if (!JA_soundEnabled) return -1;
|
if (!JA_soundEnabled)
|
||||||
|
return -1;
|
||||||
|
|
||||||
int channel = 0;
|
int channel = 0;
|
||||||
while (channel < JA_MAX_SIMULTANEOUS_CHANNELS && channels[channel].state != JA_CHANNEL_FREE) { channel++; }
|
while (channel < JA_MAX_SIMULTANEOUS_CHANNELS && channels[channel].state != JA_CHANNEL_FREE)
|
||||||
if (channel == JA_MAX_SIMULTANEOUS_CHANNELS) channel = 0;
|
{
|
||||||
|
channel++;
|
||||||
|
}
|
||||||
|
if (channel == JA_MAX_SIMULTANEOUS_CHANNELS)
|
||||||
|
channel = 0;
|
||||||
JA_StopChannel(channel);
|
JA_StopChannel(channel);
|
||||||
|
|
||||||
channels[channel].sound = sound;
|
channels[channel].sound = sound;
|
||||||
@@ -357,9 +394,11 @@ int JA_PlaySound(JA_Sound_t *sound, const int loop)
|
|||||||
|
|
||||||
int JA_PlaySoundOnChannel(JA_Sound_t *sound, const int channel, const int loop)
|
int JA_PlaySoundOnChannel(JA_Sound_t *sound, const int channel, const int loop)
|
||||||
{
|
{
|
||||||
if (!JA_soundEnabled) return -1;
|
if (!JA_soundEnabled)
|
||||||
|
return -1;
|
||||||
|
|
||||||
if (channel < 0 || channel >= JA_MAX_SIMULTANEOUS_CHANNELS) return -1;
|
if (channel < 0 || channel >= JA_MAX_SIMULTANEOUS_CHANNELS)
|
||||||
|
return -1;
|
||||||
JA_StopChannel(channel);
|
JA_StopChannel(channel);
|
||||||
|
|
||||||
channels[channel].sound = sound;
|
channels[channel].sound = sound;
|
||||||
@@ -376,8 +415,10 @@ int JA_PlaySoundOnChannel(JA_Sound_t *sound, const int channel, const int loop)
|
|||||||
|
|
||||||
void JA_DeleteSound(JA_Sound_t *sound)
|
void JA_DeleteSound(JA_Sound_t *sound)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; i++) {
|
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; i++)
|
||||||
if (channels[i].sound == sound) JA_StopChannel(i);
|
{
|
||||||
|
if (channels[i].sound == sound)
|
||||||
|
JA_StopChannel(i);
|
||||||
}
|
}
|
||||||
SDL_free(sound->buffer);
|
SDL_free(sound->buffer);
|
||||||
delete sound;
|
delete sound;
|
||||||
@@ -385,7 +426,8 @@ void JA_DeleteSound(JA_Sound_t *sound)
|
|||||||
|
|
||||||
void JA_PauseChannel(const int channel)
|
void JA_PauseChannel(const int channel)
|
||||||
{
|
{
|
||||||
if (!JA_soundEnabled) return;
|
if (!JA_soundEnabled)
|
||||||
|
return;
|
||||||
|
|
||||||
if (channel == -1)
|
if (channel == -1)
|
||||||
{
|
{
|
||||||
@@ -410,7 +452,8 @@ void JA_PauseChannel(const int channel)
|
|||||||
|
|
||||||
void JA_ResumeChannel(const int channel)
|
void JA_ResumeChannel(const int channel)
|
||||||
{
|
{
|
||||||
if (!JA_soundEnabled) return;
|
if (!JA_soundEnabled)
|
||||||
|
return;
|
||||||
|
|
||||||
if (channel == -1)
|
if (channel == -1)
|
||||||
{
|
{
|
||||||
@@ -435,12 +478,15 @@ void JA_ResumeChannel(const int channel)
|
|||||||
|
|
||||||
void JA_StopChannel(const int channel)
|
void JA_StopChannel(const int channel)
|
||||||
{
|
{
|
||||||
if (!JA_soundEnabled) return;
|
if (!JA_soundEnabled)
|
||||||
|
return;
|
||||||
|
|
||||||
if (channel == -1)
|
if (channel == -1)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; i++) {
|
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; i++)
|
||||||
if (channels[i].state != JA_CHANNEL_FREE) SDL_DestroyAudioStream(channels[i].stream);
|
{
|
||||||
|
if (channels[i].state != JA_CHANNEL_FREE)
|
||||||
|
SDL_DestroyAudioStream(channels[i].stream);
|
||||||
channels[channel].stream = nullptr;
|
channels[channel].stream = nullptr;
|
||||||
channels[i].state = JA_CHANNEL_FREE;
|
channels[i].state = JA_CHANNEL_FREE;
|
||||||
channels[i].pos = 0;
|
channels[i].pos = 0;
|
||||||
@@ -449,7 +495,8 @@ void JA_StopChannel(const int channel)
|
|||||||
}
|
}
|
||||||
else if (channel >= 0 && channel < JA_MAX_SIMULTANEOUS_CHANNELS)
|
else if (channel >= 0 && channel < JA_MAX_SIMULTANEOUS_CHANNELS)
|
||||||
{
|
{
|
||||||
if (channels[channel].state != JA_CHANNEL_FREE) SDL_DestroyAudioStream(channels[channel].stream);
|
if (channels[channel].state != JA_CHANNEL_FREE)
|
||||||
|
SDL_DestroyAudioStream(channels[channel].stream);
|
||||||
channels[channel].stream = nullptr;
|
channels[channel].stream = nullptr;
|
||||||
channels[channel].state = JA_CHANNEL_FREE;
|
channels[channel].state = JA_CHANNEL_FREE;
|
||||||
channels[channel].pos = 0;
|
channels[channel].pos = 0;
|
||||||
@@ -459,9 +506,11 @@ void JA_StopChannel(const int channel)
|
|||||||
|
|
||||||
JA_Channel_state JA_GetChannelState(const int channel)
|
JA_Channel_state JA_GetChannelState(const int channel)
|
||||||
{
|
{
|
||||||
if (!JA_soundEnabled) return JA_SOUND_DISABLED;
|
if (!JA_soundEnabled)
|
||||||
|
return JA_SOUND_DISABLED;
|
||||||
|
|
||||||
if (channel < 0 || channel >= JA_MAX_SIMULTANEOUS_CHANNELS) return JA_CHANNEL_INVALID;
|
if (channel < 0 || channel >= JA_MAX_SIMULTANEOUS_CHANNELS)
|
||||||
|
return JA_CHANNEL_INVALID;
|
||||||
|
|
||||||
return channels[channel].state;
|
return channels[channel].state;
|
||||||
}
|
}
|
||||||
@@ -481,7 +530,8 @@ void JA_EnableSound(const bool value)
|
|||||||
{
|
{
|
||||||
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; i++)
|
for (int i = 0; i < JA_MAX_SIMULTANEOUS_CHANNELS; i++)
|
||||||
{
|
{
|
||||||
if (channels[i].state == JA_CHANNEL_PLAYING) JA_StopChannel(i);
|
if (channels[i].state == JA_CHANNEL_PLAYING)
|
||||||
|
JA_StopChannel(i);
|
||||||
}
|
}
|
||||||
JA_soundEnabled = value;
|
JA_soundEnabled = value;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,34 +31,6 @@ namespace Options
|
|||||||
// Inicializa las opciones del programa
|
// Inicializa las opciones del programa
|
||||||
void init()
|
void init()
|
||||||
{
|
{
|
||||||
// Opciones de ventana
|
|
||||||
window.caption = "Coffee Crisis Arcade Edition";
|
|
||||||
window.size = 2;
|
|
||||||
|
|
||||||
// Opciones de video
|
|
||||||
video.fullscreen = false;
|
|
||||||
video.scale_mode = SDL_ScaleMode::SDL_SCALEMODE_NEAREST;
|
|
||||||
video.v_sync = true;
|
|
||||||
video.integer_scale = true;
|
|
||||||
video.shaders = false;
|
|
||||||
|
|
||||||
// Opciones de audio
|
|
||||||
audio.enabled = true;
|
|
||||||
audio.volume = 100;
|
|
||||||
audio.music.enabled = true;
|
|
||||||
audio.music.volume = 100;
|
|
||||||
audio.sound.enabled = true;
|
|
||||||
audio.sound.volume = 50;
|
|
||||||
|
|
||||||
// Opciones de configuracion
|
|
||||||
settings.difficulty = DifficultyCode::NORMAL;
|
|
||||||
settings.language = Lang::Code::VALENCIAN;
|
|
||||||
settings.autofire = true;
|
|
||||||
settings.shutdown_enabled = false;
|
|
||||||
settings.is_y_axis_inverted = false;
|
|
||||||
settings.clearLastHiScoreEntries();
|
|
||||||
settings.config_file = Asset::get()->get("config.txt");
|
|
||||||
|
|
||||||
// Opciones de control
|
// Opciones de control
|
||||||
controllers.clear();
|
controllers.clear();
|
||||||
controllers.resize(2);
|
controllers.resize(2);
|
||||||
|
|||||||
@@ -6,6 +6,9 @@
|
|||||||
#include <vector> // Para std::vector
|
#include <vector> // Para std::vector
|
||||||
#include "input.h" // Para InputAction, InputDeviceToUse
|
#include "input.h" // Para InputAction, InputDeviceToUse
|
||||||
#include "manage_hiscore_table.h" // Para HiScoreEntry
|
#include "manage_hiscore_table.h" // Para HiScoreEntry
|
||||||
|
#include "asset.h"
|
||||||
|
|
||||||
|
static constexpr int INVALID_INDEX = -1;
|
||||||
|
|
||||||
namespace Lang
|
namespace Lang
|
||||||
{
|
{
|
||||||
@@ -32,12 +35,18 @@ namespace Options
|
|||||||
: code(c), name(n) {}
|
: code(c), name(n) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones de la ventana ---
|
// --- Opciones de ventana ---
|
||||||
struct WindowOptions
|
struct WindowOptions
|
||||||
{
|
{
|
||||||
std::string caption; // Texto que aparece en la barra de título de la ventana
|
std::string caption; // Texto que aparece en la barra de título de la ventana
|
||||||
int size = 1; // Valor por el que se multiplica el tamaño de la ventana
|
int size; // Valor por el que se multiplica el tamaño de la ventana
|
||||||
int max_size = 1; // Tamaño máximo para que la ventana no sea mayor que la pantalla
|
int max_size; // Tamaño máximo para que la ventana no sea mayor que la pantalla
|
||||||
|
|
||||||
|
// Constructor por defecto con valores iniciales
|
||||||
|
WindowOptions()
|
||||||
|
: caption("Coffee Crisis Arcade Edition"),
|
||||||
|
size(2),
|
||||||
|
max_size(2) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones de vídeo ---
|
// --- Opciones de vídeo ---
|
||||||
@@ -49,6 +58,15 @@ namespace Options
|
|||||||
bool integer_scale; // Indica si se usa escalado entero
|
bool integer_scale; // Indica si se usa escalado entero
|
||||||
bool shaders; // Indica si se usan shaders para los filtros de vídeo
|
bool shaders; // Indica si se usan shaders para los filtros de vídeo
|
||||||
std::string info; // Información sobre el modo de vídeo
|
std::string info; // Información sobre el modo de vídeo
|
||||||
|
|
||||||
|
// Constructor por defecto con valores iniciales
|
||||||
|
VideoOptions()
|
||||||
|
: scale_mode(SDL_ScaleMode::SDL_SCALEMODE_NEAREST),
|
||||||
|
fullscreen(false),
|
||||||
|
v_sync(true),
|
||||||
|
integer_scale(true),
|
||||||
|
shaders(false),
|
||||||
|
info() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones de música ---
|
// --- Opciones de música ---
|
||||||
@@ -56,6 +74,11 @@ namespace Options
|
|||||||
{
|
{
|
||||||
bool enabled; // Indica si la música suena o no
|
bool enabled; // Indica si la música suena o no
|
||||||
int volume; // Volumen de la música
|
int volume; // Volumen de la música
|
||||||
|
|
||||||
|
// Constructor por defecto
|
||||||
|
MusicOptions()
|
||||||
|
: enabled(true),
|
||||||
|
volume(100) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones de sonido ---
|
// --- Opciones de sonido ---
|
||||||
@@ -63,6 +86,11 @@ namespace Options
|
|||||||
{
|
{
|
||||||
bool enabled; // Indica si los sonidos suenan o no
|
bool enabled; // Indica si los sonidos suenan o no
|
||||||
int volume; // Volumen de los sonidos
|
int volume; // Volumen de los sonidos
|
||||||
|
|
||||||
|
// Constructor por defecto
|
||||||
|
SoundOptions()
|
||||||
|
: enabled(true),
|
||||||
|
volume(100) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones de audio ---
|
// --- Opciones de audio ---
|
||||||
@@ -72,9 +100,16 @@ namespace Options
|
|||||||
SoundOptions sound; // Opciones para los efectos de sonido
|
SoundOptions sound; // Opciones para los efectos de sonido
|
||||||
bool enabled; // Indica si el audio está activo o no
|
bool enabled; // Indica si el audio está activo o no
|
||||||
int volume; // Volumen general del audio
|
int volume; // Volumen general del audio
|
||||||
|
|
||||||
|
// Constructor por defecto
|
||||||
|
AudioOptions()
|
||||||
|
: music(),
|
||||||
|
sound(),
|
||||||
|
enabled(true),
|
||||||
|
volume(100) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones de configuracion ---
|
// --- Opciones de configuración ---
|
||||||
struct SettingsOptions
|
struct SettingsOptions
|
||||||
{
|
{
|
||||||
DifficultyCode difficulty; // Dificultad del juego
|
DifficultyCode difficulty; // Dificultad del juego
|
||||||
@@ -83,14 +118,24 @@ namespace Options
|
|||||||
bool shutdown_enabled; // Especifica si se puede apagar el sistema
|
bool shutdown_enabled; // Especifica si se puede apagar el sistema
|
||||||
bool is_y_axis_inverted; // Indica si hay que invertir el eje Y de los controles
|
bool is_y_axis_inverted; // Indica si hay que invertir el eje Y de los controles
|
||||||
std::vector<HiScoreEntry> hi_score_table; // Tabla de mejores puntuaciones
|
std::vector<HiScoreEntry> hi_score_table; // Tabla de mejores puntuaciones
|
||||||
std::vector<int> last_hi_score_entry = {-1, -1}; // Últimas posiciones de entrada en la tabla
|
std::vector<int> last_hi_score_entry; // Últimas posiciones de entrada en la tabla
|
||||||
std::string config_file; // Ruta al fichero donde guardar la configuracion y las opciones del juego
|
std::string config_file; // Ruta al fichero donde guardar la configuración y las opciones del juego
|
||||||
|
|
||||||
|
// Constructor por defecto con valores iniciales
|
||||||
|
SettingsOptions()
|
||||||
|
: difficulty(DifficultyCode::NORMAL),
|
||||||
|
language(Lang::Code::VALENCIAN),
|
||||||
|
autofire(true),
|
||||||
|
shutdown_enabled(false),
|
||||||
|
is_y_axis_inverted(false),
|
||||||
|
last_hi_score_entry({INVALID_INDEX, INVALID_INDEX}),
|
||||||
|
config_file(Asset::get()->get("config.txt")) {}
|
||||||
|
|
||||||
// Reinicia las últimas entradas de puntuación
|
// Reinicia las últimas entradas de puntuación
|
||||||
void clearLastHiScoreEntries()
|
void clearLastHiScoreEntries()
|
||||||
{
|
{
|
||||||
last_hi_score_entry[0] = -1;
|
last_hi_score_entry[0] = INVALID_INDEX;
|
||||||
last_hi_score_entry[1] = -1;
|
last_hi_score_entry[1] = INVALID_INDEX;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -107,9 +152,23 @@ namespace Options
|
|||||||
|
|
||||||
// Constructor por defecto
|
// Constructor por defecto
|
||||||
GamepadOptions()
|
GamepadOptions()
|
||||||
: index(-1), player_id(-1), type(InputDeviceToUse::CONTROLLER), name(""), plugged(false),
|
: index(INVALID_INDEX),
|
||||||
inputs{InputAction::FIRE_LEFT, InputAction::FIRE_CENTER, InputAction::FIRE_RIGHT, InputAction::START, InputAction::SERVICE},
|
player_id(INVALID_INDEX),
|
||||||
buttons{SDL_GAMEPAD_BUTTON_WEST, SDL_GAMEPAD_BUTTON_NORTH, SDL_GAMEPAD_BUTTON_EAST, SDL_GAMEPAD_BUTTON_START, SDL_GAMEPAD_BUTTON_BACK} {}
|
type(InputDeviceToUse::CONTROLLER),
|
||||||
|
name(),
|
||||||
|
plugged(false),
|
||||||
|
inputs{
|
||||||
|
InputAction::FIRE_LEFT,
|
||||||
|
InputAction::FIRE_CENTER,
|
||||||
|
InputAction::FIRE_RIGHT,
|
||||||
|
InputAction::START,
|
||||||
|
InputAction::SERVICE},
|
||||||
|
buttons{
|
||||||
|
SDL_GAMEPAD_BUTTON_WEST,
|
||||||
|
SDL_GAMEPAD_BUTTON_NORTH,
|
||||||
|
SDL_GAMEPAD_BUTTON_EAST,
|
||||||
|
SDL_GAMEPAD_BUTTON_START,
|
||||||
|
SDL_GAMEPAD_BUTTON_BACK} {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Opciones pendientes de aplicar ---
|
// --- Opciones pendientes de aplicar ---
|
||||||
@@ -117,7 +176,13 @@ namespace Options
|
|||||||
{
|
{
|
||||||
Lang::Code new_language; // Idioma en espera de aplicar
|
Lang::Code new_language; // Idioma en espera de aplicar
|
||||||
DifficultyCode new_difficulty; // Dificultad en espera de aplicar
|
DifficultyCode new_difficulty; // Dificultad en espera de aplicar
|
||||||
bool has_pending_changes = false; // Indica si hay cambios pendientes
|
bool has_pending_changes; // Indica si hay cambios pendientes
|
||||||
|
|
||||||
|
// Constructor por defecto con valores iniciales
|
||||||
|
PendingChanges()
|
||||||
|
: new_language(Lang::Code::VALENCIAN),
|
||||||
|
new_difficulty(DifficultyCode::NORMAL),
|
||||||
|
has_pending_changes(false) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
// --- Variables globales ---
|
// --- Variables globales ---
|
||||||
@@ -127,7 +192,7 @@ namespace Options
|
|||||||
extern AudioOptions audio; // Opciones de audio
|
extern AudioOptions audio; // Opciones de audio
|
||||||
extern std::vector<GamepadOptions> controllers; // Opciones de mando para cada jugador
|
extern std::vector<GamepadOptions> controllers; // Opciones de mando para cada jugador
|
||||||
extern PendingChanges pending_changes; // Opciones que se aplican al cerrar
|
extern PendingChanges pending_changes; // Opciones que se aplican al cerrar
|
||||||
extern std::vector<Difficulty> difficulties;
|
extern std::vector<Difficulty> difficulties; // Lista de los diferentes tipos de dificultad
|
||||||
|
|
||||||
// --- Funciones de configuración ---
|
// --- Funciones de configuración ---
|
||||||
void init(); // Inicializa las opciones del programa
|
void init(); // Inicializa las opciones del programa
|
||||||
@@ -138,7 +203,7 @@ namespace Options
|
|||||||
void swapControllers(); // Intercambia los jugadores asignados a los dos primeros mandos
|
void swapControllers(); // Intercambia los jugadores asignados a los dos primeros mandos
|
||||||
int getPlayerWhoUsesKeyboard(); // Averigua quién está usando el teclado
|
int getPlayerWhoUsesKeyboard(); // Averigua quién está usando el teclado
|
||||||
void applyPendingChanges(); // Aplica los cambios pendientes copiando los valores a sus variables
|
void applyPendingChanges(); // Aplica los cambios pendientes copiando los valores a sus variables
|
||||||
void checkPendingChanges();
|
void checkPendingChanges(); // Verifica si hay cambios pendientes
|
||||||
DifficultyCode getDifficultyCodeFromName(const std::string &name);
|
DifficultyCode getDifficultyCodeFromName(const std::string &name); // Obtiene el código de dificultad a partir del nombre
|
||||||
std::string getDifficultyNameFromCode(DifficultyCode code);
|
std::string getDifficultyNameFromCode(DifficultyCode code); // Obtiene el nombre de la dificultad a partir del código
|
||||||
} // namespace Options
|
} // namespace Options
|
||||||
@@ -55,7 +55,7 @@ void initParam()
|
|||||||
param.title.title_c_c_position = 11;
|
param.title.title_c_c_position = 11;
|
||||||
|
|
||||||
// BACKGROUND
|
// BACKGROUND
|
||||||
param.background.attenuate_color = Color(255, 255, 255);
|
param.background.attenuate_color = Color(255, 255, 255, 0);
|
||||||
|
|
||||||
// BALLOONS
|
// BALLOONS
|
||||||
param.balloon.emplace_back(0.09f, 2.60f);
|
param.balloon.emplace_back(0.09f, 2.60f);
|
||||||
@@ -67,9 +67,7 @@ void initParam()
|
|||||||
param.notification.pos_v = NotifyPosition::TOP;
|
param.notification.pos_v = NotifyPosition::TOP;
|
||||||
param.notification.pos_h = NotifyPosition::LEFT;
|
param.notification.pos_h = NotifyPosition::LEFT;
|
||||||
param.notification.sound = false;
|
param.notification.sound = false;
|
||||||
param.notification.color.r = 48;
|
param.notification.color = Color(48, 48, 48);
|
||||||
param.notification.color.g = 48;
|
|
||||||
param.notification.color.b = 48;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Carga los parámetros desde un archivo
|
// Carga los parámetros desde un archivo
|
||||||
|
|||||||
Reference in New Issue
Block a user