diff options
Diffstat (limited to 'engines/saga')
-rw-r--r-- | engines/saga/interface.cpp | 2 | ||||
-rw-r--r-- | engines/saga/saga.cpp | 22 | ||||
-rw-r--r-- | engines/saga/sound.cpp | 4 |
3 files changed, 18 insertions, 10 deletions
diff --git a/engines/saga/interface.cpp b/engines/saga/interface.cpp index 43c4115cb0..24fd15594d 100644 --- a/engines/saga/interface.cpp +++ b/engines/saga/interface.cpp @@ -1637,7 +1637,7 @@ void Interface::setOption(PanelButton *panelButton) { case kTextSound: _vm->_soundVolume = _vm->_soundVolume + 25; if (_vm->_soundVolume > 255) _vm->_soundVolume = 0; - ConfMan.setInt("sound_volume", _vm->_soundVolume); + ConfMan.setInt("sfx_volume", _vm->_soundVolume); _vm->_sound->setVolume(); break; case kTextVoices: diff --git a/engines/saga/saga.cpp b/engines/saga/saga.cpp index 6035e7ee12..1fce2d1c65 100644 --- a/engines/saga/saga.cpp +++ b/engines/saga/saga.cpp @@ -141,10 +141,18 @@ SagaEngine::~SagaEngine() { } Common::Error SagaEngine::init() { - _musicVolume = ConfMan.hasKey("music_volume") ? ConfMan.getInt("music_volume") : 255; - _subtitlesEnabled = ConfMan.hasKey("subtitles") ? ConfMan.getBool("subtitles") : true; + // Assign default values to the config manager, in case settings are missing + ConfMan.registerDefault("music_volume", "255"); + ConfMan.registerDefault("sfx_volume", "255"); + ConfMan.registerDefault("speech_volume", "255"); + ConfMan.registerDefault("talkspeed", "255"); + ConfMan.registerDefault("subtitles", "true"); + ConfMan.registerDefault("copy_protection", "false"); + + _musicVolume = ConfMan.getInt("music_volume"); + _subtitlesEnabled = ConfMan.getBool("subtitles"); _readingSpeed = getTalkspeed(); - _copyProtection = ConfMan.hasKey("copy_protection") ? ConfMan.getBool("copy_protection") : false; + _copyProtection = ConfMan.getBool("copy_protection"); _gf_wyrmkeep = false; _gf_compressed_sounds = false; _musicWasPlaying = false; @@ -217,7 +225,7 @@ Common::Error SagaEngine::init() { _voicesEnabled = true; ConfMan.setBool("voices", true); } else { - _voicesEnabled = ConfMan.hasKey("voices") ? ConfMan.getBool("voices") : true; + _voicesEnabled = ConfMan.getBool("voices"); } } else { _voicesEnabled = true; @@ -518,17 +526,17 @@ void SagaEngine::setTalkspeed(int talkspeed) { } int SagaEngine::getTalkspeed() { - return ((ConfMan.hasKey("talkspeed") ? ConfMan.getInt("talkspeed") : 255) * 3 + 255 / 2) / 255; + return (ConfMan.getInt("talkspeed") * 3 + 255 / 2) / 255; } void SagaEngine::syncSoundSettings() { - _subtitlesEnabled = ConfMan.hasKey("subtitles") ? ConfMan.getBool("subtitles") : true; + _subtitlesEnabled = ConfMan.getBool("subtitles"); _readingSpeed = getTalkspeed(); if (_readingSpeed > 3) _readingSpeed = 0; - _musicVolume = ConfMan.hasKey("music_volume") ? ConfMan.getInt("music_volume") : 255; + _musicVolume = ConfMan.getInt("music_volume"); _music->setVolume(_musicVolume, 1); _sound->setVolume(); } diff --git a/engines/saga/sound.cpp b/engines/saga/sound.cpp index f87f30a3fa..e693e16629 100644 --- a/engines/saga/sound.cpp +++ b/engines/saga/sound.cpp @@ -206,8 +206,8 @@ void Sound::stopAll() { } void Sound::setVolume() { - _vm->_soundVolume = ConfMan.hasKey("sound_volume") ? ConfMan.getInt("sound_volume") : 255; - _vm->_speechVolume = ConfMan.hasKey("speech_volume") ? ConfMan.getInt("speech_volume") : 255; + _vm->_soundVolume = ConfMan.getInt("sfx_volume"); + _vm->_speechVolume = ConfMan.getInt("speech_volume"); _mixer->setVolumeForSoundType(Audio::Mixer::kSFXSoundType, _vm->_soundVolume); _mixer->setVolumeForSoundType(Audio::Mixer::kSpeechSoundType, _vm->_speechVolume); } |