1
0
Fork 0
mirror of https://github.com/ninjamuffin99/Funkin.git synced 2025-01-07 20:57:52 +00:00
Funkin/source/funkin/noteStuff/NoteUtil.hx

99 lines
2.3 KiB
Haxe
Raw Normal View History

2022-09-17 09:38:45 +00:00
package funkin.noteStuff;
import haxe.Json;
import openfl.Assets;
/**
* Just various functions that IDK where to put em!!!
* Semi-temp for now? the note stuff is super clutter-y right now
* so I am putting this new stuff here right now XDD
2023-06-08 20:30:45 +00:00
*
2022-09-17 09:38:45 +00:00
* A lot of this stuff can probably be moved to where appropriate!
* i dont care about NoteUtil.hx at all!!!
*/
class NoteUtil
{
2023-01-23 00:55:30 +00:00
/**
* IDK THING FOR BOTH LOL! DIS SHIT HACK-Y
2023-06-08 20:30:45 +00:00
* @param jsonPath
2023-01-23 00:55:30 +00:00
* @return Map<Int, Array<SongEventInfo>>
*/
public static function loadSongEvents(jsonPath:String):Map<Int, Array<SongEventInfo>>
{
return parseSongEvents(loadSongEventFromJson(jsonPath));
}
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
public static function loadSongEventFromJson(jsonPath:String):Array<SongEvent>
{
var daEvents:Array<SongEvent>;
daEvents = cast Json.parse(Assets.getText(jsonPath)).events; // DUMB LIL DETAIL HERE: MAKE SURE THAT .events IS THERE??
trace('GET JSON SONG EVENTS:');
trace(daEvents);
return daEvents;
}
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
/**
* Parses song event json stuff into a neater lil map grouping?
2023-06-08 20:30:45 +00:00
* @param songEvents
2023-01-23 00:55:30 +00:00
*/
public static function parseSongEvents(songEvents:Array<SongEvent>):Map<Int, Array<SongEventInfo>>
{
var songData:Map<Int, Array<SongEventInfo>> = new Map();
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
for (songEvent in songEvents)
{
trace(songEvent);
if (songData[songEvent.t] == null) songData[songEvent.t] = [];
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
songData[songEvent.t].push({songEventType: songEvent.e, value: songEvent.v, activated: false});
}
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
trace("FINISH SONG EVENTS!");
trace(songData);
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
return songData;
}
2022-09-17 09:38:45 +00:00
2023-01-23 00:55:30 +00:00
public static function checkSongEvents(songData:Map<Int, Array<SongEventInfo>>, time:Float)
{
for (eventGrp in songData.keys())
{
if (time >= eventGrp)
{
for (events in songData[eventGrp])
{
if (!events.activated)
{
// TURN TO NICER SWITCH STATEMENT CHECKER OF EVENT TYPES!!
trace(events.value);
trace(eventGrp);
trace(Conductor.songPosition);
events.activated = true;
}
}
}
}
}
2022-09-17 09:38:45 +00:00
}
typedef SongEventInfo =
{
2023-01-23 00:55:30 +00:00
var songEventType:SongEventType;
var value:Dynamic;
var activated:Bool;
2022-09-17 09:38:45 +00:00
}
typedef SongEvent =
{
2023-01-23 00:55:30 +00:00
var t:Int;
var e:SongEventType;
var v:Dynamic;
2022-09-17 09:38:45 +00:00
}
enum abstract SongEventType(String)
{
2023-01-23 00:55:30 +00:00
var FocusCamera;
var PlayCharAnim;
var Trace;
2022-09-17 09:38:45 +00:00
}