Merge branch 'master' into jgrpp
# Conflicts: # src/economy.cpp # src/linkgraph/refresh.cpp # src/order_cmd.cpp # src/saveload/vehicle_sl.cpp # src/station.cpp # src/station_base.h # src/timetable_cmd.cpp # src/timetable_gui.cpp # src/vehicle.cpp # src/vehicle_base.h # src/vehicle_cmd.cpp
This commit is contained in:
@@ -525,8 +525,8 @@ struct MpsMachine {
|
||||
Channel channels[16]; ///< playback status for each MIDI channel
|
||||
std::vector<uint32> segments; ///< pointers into songdata to repeatable data segments
|
||||
int16 tempo_ticks; ///< ticker that increments when playing a frame, decrements before playing a frame
|
||||
int16 current_tempo; ///< threshold for actually playing a frame
|
||||
int16 initial_tempo; ///< starting tempo of song
|
||||
int16 current_tempo; ///< threshold for actually playing a frame
|
||||
int16 initial_tempo; ///< starting tempo of song
|
||||
bool shouldplayflag; ///< not-end-of-song flag
|
||||
|
||||
static const int TEMPO_RATE;
|
||||
@@ -787,10 +787,11 @@ struct MpsMachine {
|
||||
bool PlayInto()
|
||||
{
|
||||
/* Tempo seems to be handled as TEMPO_RATE = 148 ticks per second.
|
||||
* Use this as the tickdiv, and define the tempo to be one second (1M microseconds) per tickdiv.
|
||||
* Use this as the tickdiv, and define the tempo to be somewhat less than one second (1M microseconds) per quarter note.
|
||||
* This value was found experimentally to give a very close approximation of the correct playback speed.
|
||||
* MIDI software loading exported files will show a bogus tempo, but playback will be correct. */
|
||||
this->target.tickdiv = TEMPO_RATE;
|
||||
this->target.tempos.push_back(MidiFile::TempoChange(0, 1000000));
|
||||
this->target.tempos.push_back(MidiFile::TempoChange(0, 980500));
|
||||
|
||||
/* Initialize playback simulation */
|
||||
this->RestartSong();
|
||||
|
Reference in New Issue
Block a user