Funkin/source/funkin/play/notes/NoteHoldCover.hx

102 lines
2.5 KiB
Haxe
Raw Normal View History

2023-07-04 16:38:10 -04:00
package funkin.play.notes;
import flixel.group.FlxSpriteGroup.FlxTypedSpriteGroup;
import funkin.play.notes.NoteDirection;
import flixel.graphics.frames.FlxFramesCollection;
import flixel.FlxG;
import flixel.graphics.frames.FlxAtlasFrames;
import flixel.FlxSprite;
class NoteHoldCover extends FlxTypedSpriteGroup<FlxSprite>
{
static final FRAMERATE_DEFAULT:Int = 24;
static var glowFrames:FlxAtlasFrames;
2023-07-05 22:11:58 -04:00
public var holdNote:SustainTrail;
2023-07-04 16:38:10 -04:00
var glow:FlxSprite;
var sparks:FlxSprite;
public function new()
{
super(0, 0);
setup();
}
2023-07-05 22:11:58 -04:00
public static function preloadFrames():Void
{
glowFrames = Paths.getSparrowAtlas('holdCoverRed');
glowFrames.parent.persist = true;
}
2023-07-04 16:38:10 -04:00
/**
* Add ALL the animations to this sprite. We will recycle and reuse the FlxSprite multiple times.
*/
function setup():Void
{
glow = new FlxSprite();
add(glow);
if (glowFrames == null) preloadFrames();
glow.frames = glowFrames;
2023-07-05 22:11:58 -04:00
glow.animation.addByPrefix('holdCoverStartRed', 'holdCoverStartRed0', FRAMERATE_DEFAULT, false, false, false);
2023-07-04 16:38:10 -04:00
glow.animation.addByPrefix('holdCoverRed', 'holdCoverRed0', FRAMERATE_DEFAULT, true, false, false);
2023-07-05 22:11:58 -04:00
glow.animation.addByPrefix('holdCoverEndRed', 'holdCoverEndRed0', FRAMERATE_DEFAULT, false, false, false);
2023-07-04 16:38:10 -04:00
glow.animation.finishCallback = this.onAnimationFinished;
if (glow.animation.getAnimationList().length < 2)
{
trace('WARNING: NoteHoldCover failed to initialize all animations.');
}
}
2023-07-05 22:11:58 -04:00
public override function update(elapsed):Void
2023-07-04 16:38:10 -04:00
{
2023-07-05 22:11:58 -04:00
super.update(elapsed);
if (!holdNote.alive && !glow.animation.curAnim.name.startsWith('holdCoverEnd'))
{
this.visible = false;
this.kill();
}
else
{
this.visible = true;
}
2023-07-04 16:38:10 -04:00
}
2023-07-05 22:11:58 -04:00
public function playStart():Void
2023-07-04 16:38:10 -04:00
{
2023-07-05 22:11:58 -04:00
// glow.animation.play('holdCoverStart${noteDirection.colorName.toTitleCase()}');\
glow.animation.play('holdCoverStartRed');
}
public function playContinue():Void
{
// glow.animation.play('holdCover${noteDirection.colorName.toTitleCase()}');\
2023-07-04 16:38:10 -04:00
glow.animation.play('holdCoverRed');
}
2023-07-05 22:11:58 -04:00
public function playEnd():Void
2023-07-04 16:38:10 -04:00
{
2023-07-05 22:11:58 -04:00
// glow.animation.play('holdCoverEnd${noteDirection.colorName.toTitleCase()}');\
2023-07-04 16:38:10 -04:00
glow.animation.play('holdCoverEndRed');
}
public function onAnimationFinished(animationName:String):Void
{
2023-07-05 22:11:58 -04:00
if (animationName.startsWith('holdCoverStart'))
{
playContinue();
}
2023-07-04 16:38:10 -04:00
if (animationName.startsWith('holdCoverEnd'))
{
// *lightning* *zap* *crackle*
2023-07-05 22:11:58 -04:00
this.visible = false;
2023-07-04 16:38:10 -04:00
this.kill();
}
}
}