Redesigned -t option

svn-id: r7584
This commit is contained in:
Jamieson Christian 2003-05-16 22:28:33 +00:00
parent 64d9c75c2d
commit 48f73469e0
2 changed files with 10 additions and 6 deletions

2
README
View File

@ -326,7 +326,7 @@ Command Line Options:
-m<num> - Set the music volume, 0-255. Default is '192'
-o<num> - Set the master volume, 0-255. Default is '192'
-s<num> - Set the sfx volume, 0-255. Default is '192'
-t<num> - Set music tempo. Adlib default: 0x1D9000, Midi: 0x4A0000
-t<num> - Set music tempo. 50-200. Default is '100' (percent)
-n - Disable subtitles. Use with games that have voice.
-y - Set talk speed ('yak option'). Default is '60'
-l<file> - Load alternate configuration file

View File

@ -301,6 +301,8 @@ private:
bool _initialized;
byte _volume_fader_counter;
int _tempoFactor;
uint _queue_end, _queue_pos, _queue_sound;
byte _queue_adding;
@ -1643,11 +1645,11 @@ int IMuseInternal::get_volchan_entry(uint a) {
uint32 IMuseInternal::property(int prop, uint32 value) {
switch (prop) {
case IMuse::PROP_TEMPO_BASE:
// Jamieson630: This used to specify a low-level microsecond
// timing override for the MIDI drivers, based on the -t
// option. It hasn't worked for a while, but may come back
// later as a more user-friendly adjustment option.
// _game_tempo = value;
// This is a specified as a percentage of normal
// music speed. The number must be an integer
// ranging from 50 to 200 (for 50% to 200% normal speed).
if (value >= 50 && value <= 200)
_tempoFactor = value;
break;
}
return 0;
@ -1671,6 +1673,7 @@ int IMuseInternal::initialize(OSystem *syst, MidiDriver *native_midi) {
if (native_midi)
initMidiDriver (_midi_native);
if (!_tempoFactor) _tempoFactor = 100;
_master_volume = 255;
if (_music_volume < 1)
_music_volume = kDefaultMusicVolume;
@ -1854,6 +1857,7 @@ void Player::set_tempo(uint32 b) {
i = _midi->getBaseTempo();
j = _tempo = b;
j = j * 100 / _se->_tempoFactor;
while (i & 0xFFFF0000 || j & 0xFFFF0000) {
i >>= 1;