mirror of
https://github.com/FunkinCrew/Funkin.git
synced 2024-11-23 16:17:53 -05:00
87 lines
2.5 KiB
Haxe
87 lines
2.5 KiB
Haxe
|
package;
|
||
|
|
||
|
import flixel.FlxG;
|
||
|
import flixel.FlxSprite;
|
||
|
import flixel.FlxState;
|
||
|
import flixel.addons.display.FlxGridOverlay;
|
||
|
import flixel.addons.transition.FlxTransitionSprite.GraphicTransTileDiamond;
|
||
|
import flixel.addons.transition.FlxTransitionableState;
|
||
|
import flixel.addons.transition.TransitionData;
|
||
|
import flixel.graphics.FlxGraphic;
|
||
|
import flixel.math.FlxPoint;
|
||
|
import flixel.math.FlxRect;
|
||
|
import flixel.tweens.FlxEase;
|
||
|
import flixel.tweens.FlxTween;
|
||
|
import flixel.util.FlxColor;
|
||
|
import flixel.util.FlxTimer;
|
||
|
|
||
|
class TitleState extends FlxTransitionableState
|
||
|
{
|
||
|
static var initialized:Bool = false;
|
||
|
|
||
|
override public function create():Void
|
||
|
{
|
||
|
super.create();
|
||
|
|
||
|
if (!initialized)
|
||
|
{
|
||
|
var diamond:FlxGraphic = FlxGraphic.fromClass(GraphicTransTileDiamond);
|
||
|
diamond.persist = true;
|
||
|
diamond.destroyOnNoUse = false;
|
||
|
|
||
|
FlxTransitionableState.defaultTransIn = new TransitionData(FADE, FlxColor.BLACK, 2, new FlxPoint(0, -1), {asset: diamond, width: 32, height: 32},
|
||
|
new FlxRect(0, 0, FlxG.width, FlxG.height));
|
||
|
FlxTransitionableState.defaultTransOut = new TransitionData(FADE, FlxColor.BLACK, 1.3, new FlxPoint(0, 1),
|
||
|
{asset: diamond, width: 32, height: 32}, new FlxRect(0, 0, FlxG.width, FlxG.height));
|
||
|
|
||
|
initialized = true;
|
||
|
|
||
|
FlxTransitionableState.defaultTransIn.tileData = {asset: diamond, width: 32, height: 32};
|
||
|
FlxTransitionableState.defaultTransOut.tileData = {asset: diamond, width: 32, height: 32};
|
||
|
|
||
|
transIn = FlxTransitionableState.defaultTransIn;
|
||
|
transOut = FlxTransitionableState.defaultTransOut;
|
||
|
}
|
||
|
|
||
|
persistentUpdate = true;
|
||
|
|
||
|
var bg:FlxSprite = FlxGridOverlay.create(20, 20);
|
||
|
add(bg);
|
||
|
|
||
|
var logoBl:FlxSprite = new FlxSprite().loadGraphic(AssetPaths.logo__png);
|
||
|
logoBl.screenCenter();
|
||
|
logoBl.color = FlxColor.BLACK;
|
||
|
add(logoBl);
|
||
|
|
||
|
var logo:FlxSprite = new FlxSprite().loadGraphic(AssetPaths.logo__png);
|
||
|
logo.screenCenter();
|
||
|
add(logo);
|
||
|
|
||
|
FlxTween.tween(logoBl, {y: logoBl.y + 50}, 0.6, {ease: FlxEase.quadInOut, type: PINGPONG});
|
||
|
FlxTween.tween(logo, {y: logoBl.y + 50}, 0.6, {ease: FlxEase.quadInOut, type: PINGPONG, startDelay: 0.1});
|
||
|
|
||
|
FlxG.sound.playMusic('assets/music/title.mp3', 0, false);
|
||
|
|
||
|
FlxG.sound.music.fadeIn(4, 0, 0.7);
|
||
|
}
|
||
|
|
||
|
var transitioning:Bool = false;
|
||
|
|
||
|
override function update(elapsed:Float)
|
||
|
{
|
||
|
if (FlxG.keys.justPressed.ENTER && !transitioning)
|
||
|
{
|
||
|
transitioning = true;
|
||
|
FlxG.sound.music.stop();
|
||
|
|
||
|
new FlxTimer().start(2, function(tmr:FlxTimer)
|
||
|
{
|
||
|
FlxG.switchState(new PlayState());
|
||
|
});
|
||
|
FlxG.sound.play('assets/music/titleShoot.mp3', 0.7);
|
||
|
}
|
||
|
|
||
|
super.update(elapsed);
|
||
|
}
|
||
|
}
|