Funkin/source/funkin/Conductor.hx

64 lines
1.4 KiB
Haxe
Raw Normal View History

package funkin;
2020-10-03 02:50:15 -04:00
import funkin.SongLoad.SwagSong;
2020-10-03 02:50:15 -04:00
/**
* ...
* @author
*/
typedef BPMChangeEvent =
{
var stepTime:Int;
var songTime:Float;
var bpm:Float;
}
2020-10-03 02:50:15 -04:00
class Conductor
{
public static var bpm:Float = 100;
2020-10-03 02:50:15 -04:00
public static var crochet:Float = ((60 / bpm) * 1000); // beats in milliseconds
public static var stepCrochet:Float = crochet / 4; // steps in milliseconds
public static var songPosition:Float;
2020-10-24 05:19:13 -04:00
public static var lastSongPos:Float;
2020-10-03 02:50:15 -04:00
public static var offset:Float = 0;
public static var bpmChangeMap:Array<BPMChangeEvent> = [];
public function new() {}
2020-10-04 20:53:49 -04:00
public static function mapBPMChanges(song:SwagSong)
{
bpmChangeMap = [];
var curBPM:Float = song.bpm;
var totalSteps:Int = 0;
var totalPos:Float = 0;
for (i in 0...SongLoad.getSong().length)
{
if (SongLoad.getSong()[i].changeBPM && SongLoad.getSong()[i].bpm != curBPM)
{
curBPM = SongLoad.getSong()[i].bpm;
var event:BPMChangeEvent = {
stepTime: totalSteps,
songTime: totalPos,
bpm: curBPM
};
bpmChangeMap.push(event);
}
var deltaSteps:Int = SongLoad.getSong()[i].lengthInSteps;
totalSteps += deltaSteps;
totalPos += ((60 / curBPM) * 1000 / 4) * deltaSteps;
}
trace("new BPM map BUDDY " + bpmChangeMap);
}
public static function changeBPM(newBpm:Float)
2020-10-04 20:53:49 -04:00
{
bpm = newBpm;
crochet = ((60 / bpm) * 1000);
stepCrochet = crochet / 4;
}
2020-10-03 02:50:15 -04:00
}