This repository has been archived by the owner on Jan 26, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
use game ticks instead of timer for sound time interpolation
- Loading branch information
Showing
6 changed files
with
121 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
package funkin.states.newchart; | ||
|
||
class ChartEditor extends MusicBeatState | ||
{ | ||
public static var SONG:SwagSong; | ||
|
||
var bg:FlxSpriteExt; | ||
var grid:ChartGrid; | ||
|
||
override function create() | ||
{ | ||
super.create(); | ||
|
||
setupSong("bopeebo", "hard"); | ||
|
||
bg = new FlxSpriteExt().loadImage("menuDesat"); | ||
bg.scrollFactor.set(); | ||
bg.color = 0xFF242424; | ||
add(bg); | ||
|
||
grid = new ChartGrid(); | ||
add(grid); | ||
} | ||
|
||
public static function setupSong(song:String, diff:String, ?input:SwagSong):SwagSong | ||
{ | ||
return SONG = input ?? Song.loadFromFile(diff, song); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
package funkin.states.newchart; | ||
|
||
import openfl.events.MouseEvent; | ||
import flixel.addons.display.FlxGridOverlay; | ||
|
||
@:access(flixel.input.mouse.FlxMouse) | ||
class ChartGrid extends Group | ||
{ | ||
inline static var TILE:Int = 40; | ||
|
||
var notesGrid:FlxSpriteExt; | ||
var eventsGrid:FlxSpriteExt; | ||
|
||
public function new() { | ||
super(); | ||
|
||
// Use the same bitmap for batch rendering on both grids | ||
var bitmap = FlxGridOverlay.createGrid(1, 1, 8, 16, true, 0xff7c7c7c, 0xff6e6e6e); | ||
|
||
notesGrid = new FlxSpriteExt(0, 0, bitmap); | ||
notesGrid.setScale(TILE); | ||
add(notesGrid); | ||
|
||
eventsGrid = new FlxSpriteExt(0, 0, bitmap); | ||
eventsGrid.setScale(TILE); | ||
add(eventsGrid); | ||
|
||
// Adjust events grid shit | ||
eventsGrid.frame.frame.x = 1; | ||
eventsGrid.frame.frame.width = 1; | ||
eventsGrid.frame = eventsGrid.frame; | ||
eventsGrid.width = TILE; | ||
|
||
notesGrid.screenCenter(X); | ||
eventsGrid.x = notesGrid.x - TILE - 10; | ||
|
||
FlxG.mouse._stage.addEventListener(MouseEvent.MOUSE_MOVE, onMouseMove); | ||
} | ||
|
||
// Save doing the mouse stuff on update | ||
function onMouseMove(e) | ||
{ | ||
// TODO: add tile logic and all that bullshit | ||
} | ||
|
||
// Use inst time when possible to avoid needing to sync all the time lol | ||
inline function getTime():Float { | ||
return Conductor.playing ? Conductor.inst.time + Conductor.offset[0] + Conductor.latency : Conductor.songPosition; | ||
} | ||
|
||
inline function getTimeY():Float { | ||
return inline FlxMath.remapToRange(getTime(), 0, Conductor.sectionCrochet, 0, TILE * 16); // TODO: Change the 16 with the snap later | ||
} | ||
|
||
public var sectionObjects:Array<Array<FlxObject>> = []; | ||
|
||
var curSection(default, set):Int = 0; | ||
inline function set_curSection(value:Int):Int { | ||
return curSection = cast FlxMath.bound(value, 0, ChartEditor.SONG.notes.length - 1); | ||
} | ||
|
||
override function draw() { | ||
super.draw(); | ||
|
||
// Render the 3 current visible sections, maybe make this higher depending on the snap? | ||
for (i in 0...3) | ||
{ | ||
if (sectionObjects[curSection - 1 + i] != null) | ||
{ | ||
sectionObjects[curSection - 1 + i].fastForEach((object, i) -> { | ||
if (object != null) if (object.exists) if (object.visible) | ||
object.draw(); | ||
}); | ||
} | ||
} | ||
} | ||
|
||
override function destroy() { | ||
super.destroy(); | ||
FlxG.mouse._stage.removeEventListener(MouseEvent.MOUSE_MOVE, onMouseMove); | ||
} | ||
} |