From f158a3929c1c24be0f89eb258e0480f3ef8bb56a Mon Sep 17 00:00:00 2001
From: Cameron Taylor <cameron.taylor.ninja@gmail.com>
Date: Fri, 18 Feb 2022 16:29:29 -0500
Subject: [PATCH] weekend fighting in progress + del superlinter

---
 .github/workflows/superlinter.yml    |  10 --
 source/Character.hx                  |  32 +++++
 source/MusicBeatState.hx             |   2 +
 source/audiovis/PolygonSpectogram.hx |  18 ++-
 source/charting/ChartingState.hx     |   3 +-
 source/play/Fighter.hx               |  67 +++++++++++
 source/play/PicoFight.hx             | 174 ++++++++++++++++++++++++++-
 7 files changed, 286 insertions(+), 20 deletions(-)
 delete mode 100644 .github/workflows/superlinter.yml
 create mode 100644 source/play/Fighter.hx

diff --git a/.github/workflows/superlinter.yml b/.github/workflows/superlinter.yml
deleted file mode 100644
index 7f2c82e13..000000000
--- a/.github/workflows/superlinter.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-jobs:
-  build:
-    runs-on: [ubuntu-latest, macos-latest]
-    steps:
-      - uses: krdlab/setup-haxe@v1
-        with:
-          haxe-version: 4.0.5
-      - run: |
-          haxe -version
-          haxelib install hxnodejs
\ No newline at end of file
diff --git a/source/Character.hx b/source/Character.hx
index db69aa20a..0c1eb4118 100644
--- a/source/Character.hx
+++ b/source/Character.hx
@@ -509,6 +509,38 @@ class Character extends FlxSprite
 						playAnim(animShit, true, false, animation.getByName(animShit).frames.length - 8);
 					}
 				}
+			case 'darnell-fighter':
+				frames = Paths.getSparrowAtlas('fightDarnell');
+
+				quickAnimAdd('idle', "fight idle darnell");
+				quickAnimAdd('block', 'block');
+				quickAnimAdd('hit high', 'hit high');
+				quickAnimAdd('hit low', 'hit low');
+				quickAnimAdd('punch low', 'punch low');
+				quickAnimAdd('punch high', 'punch high');
+				quickAnimAdd('dodge', 'dodge');
+				playAnim('idle');
+
+				addOffset('punch low', -90);
+				addOffset('punch high', -90);
+				addOffset('block', 50, 20);
+				addOffset('dodge', 50, -20);
+
+			case 'pico-fighter':
+				frames = Paths.getSparrowAtlas('fightPico');
+
+				quickAnimAdd('idle', 'fight idle pico');
+				quickAnimAdd('block', 'block');
+				quickAnimAdd('hit high', 'hit high');
+				quickAnimAdd('hit low', 'hit low');
+				quickAnimAdd('punch low', 'punch low');
+				quickAnimAdd('punch high', 'punch high');
+				quickAnimAdd('dodge', 'dodge');
+				playAnim('idle');
+
+				addOffset('punch low', 160);
+				addOffset('punch high', 160);
+
 			case 'nene':
 				// GIRLFRIEND CODE
 				tex = Paths.getSparrowAtlas('characters/Nene_assets');
diff --git a/source/MusicBeatState.hx b/source/MusicBeatState.hx
index 2bd38809c..5a5d1e18f 100644
--- a/source/MusicBeatState.hx
+++ b/source/MusicBeatState.hx
@@ -12,6 +12,7 @@ class MusicBeatState extends FlxUIState
 	private var curStep:Int = 0;
 	private var curBeat:Int = 0;
 	private var controls(get, never):Controls;
+	private var lastBeatHitTime:Float = 0;
 
 	inline function get_controls():Controls
 		return PlayerSettings.player1.controls;
@@ -67,6 +68,7 @@ class MusicBeatState extends FlxUIState
 
 	public function beatHit():Void
 	{
+		lastBeatHitTime = Conductor.songPosition;
 		// do literally nothing dumbass
 	}
 }
diff --git a/source/audiovis/PolygonSpectogram.hx b/source/audiovis/PolygonSpectogram.hx
index 71f44359f..31409c45f 100644
--- a/source/audiovis/PolygonSpectogram.hx
+++ b/source/audiovis/PolygonSpectogram.hx
@@ -15,6 +15,7 @@ class PolygonSpectogram extends MeshRender
 	public var vis:VisShit;
 	public var visType:VISTYPE = UPDATED;
 	public var daHeight:Float = FlxG.height;
+	public var realtimeVisLenght:Float = 0.2;
 
 	var numSamples:Int = 0;
 	var setBuffer:Bool = false;
@@ -22,6 +23,9 @@ class PolygonSpectogram extends MeshRender
 	public var audioData:Int16Array;
 	public var detail:Float = 1;
 
+	public var thickness:Float = 2;
+	public var waveAmplitude:Int = 100;
+
 	public function new(daSound:FlxSound, ?col:FlxColor = FlxColor.WHITE, ?height:Float = 720, ?detail:Float = 1)
 	{
 		super(0, 0, col);
@@ -83,13 +87,15 @@ class PolygonSpectogram extends MeshRender
 				var sampleApprox:Int = Std.int(FlxMath.remapToRange(i, 0, funnyPixels, startSample, startSample + samplesToGen));
 				var curAud:CurAudioInfo = VisShit.getCurAud(audioData, sampleApprox);
 
-				var waveAmplitude:Int = 200;
-
 				var coolPoint:FlxPoint = new FlxPoint();
-				coolPoint.x = (curAud.balanced * waveAmplitude / 2 + waveAmplitude / 2);
+				coolPoint.x = (curAud.balanced * waveAmplitude);
 				coolPoint.y = (i / funnyPixels * daHeight);
 
-				add_quad(prevPoint.x, prevPoint.y, prevPoint.x + 2, prevPoint.y, coolPoint.x, coolPoint.y, coolPoint.x + 2, coolPoint.y + 2);
+				add_quad(prevPoint.x, prevPoint.y, prevPoint.x
+					+ thickness, prevPoint.y, coolPoint.x, coolPoint.y, coolPoint.x
+					+ thickness,
+					coolPoint.y
+					+ thickness);
 
 				prevPoint.x = coolPoint.x;
 				prevPoint.y = coolPoint.y;
@@ -105,7 +111,7 @@ class PolygonSpectogram extends MeshRender
 		{
 			if (curTime != vis.snd.time)
 			{
-				trace("DOIN SHIT" + FlxG.random.int(0, 200));
+				// trace("DOIN SHIT" + FlxG.random.int(0, 200));
 
 				if (vis.snd.playing)
 					curTime = vis.snd.time;
@@ -117,7 +123,7 @@ class PolygonSpectogram extends MeshRender
 
 				curTime = vis.snd.time;
 
-				generateSection(vis.snd.time, 0.2);
+				generateSection(vis.snd.time, realtimeVisLenght);
 			}
 		}
 	}
diff --git a/source/charting/ChartingState.hx b/source/charting/ChartingState.hx
index 3a05967c8..2559be86f 100644
--- a/source/charting/ChartingState.hx
+++ b/source/charting/ChartingState.hx
@@ -423,8 +423,9 @@ class ChartingState extends MusicBeatState
 		FlxG.sound.playMusic(Paths.inst(daSong), 0.6);
 
 		var musSpec:PolygonSpectogram = new PolygonSpectogram(FlxG.sound.music, FlxColor.RED, FlxG.height / 2, Math.floor(FlxG.height / 2));
-		musSpec.x += 70;
+		musSpec.x += 170;
 		musSpec.scrollFactor.set();
+		musSpec.waveAmplitude = 50;
 		// musSpec.visType = FREQUENCIES;
 		add(musSpec);
 
diff --git a/source/play/Fighter.hx b/source/play/Fighter.hx
new file mode 100644
index 000000000..cde3c1f30
--- /dev/null
+++ b/source/play/Fighter.hx
@@ -0,0 +1,67 @@
+package play;
+
+import flixel.FlxSprite;
+
+class Fighter extends Character
+{
+	public function new(?x:Float = 0, ?y:Float = 0, ?char:String = "pico-fighter")
+	{
+		super(x, y, char);
+
+		animation.finishCallback = function(anim:String)
+		{
+			switch anim
+			{
+				case "punch low" | "punch high" | "block" | 'dodge':
+					dance();
+			}
+		};
+	}
+
+	public var actions:Array<ACTIONS> = [PUNCH, BLOCK, DODGE];
+
+	public function doSomething(?forceAction:ACTIONS)
+	{
+		var daAction:ACTIONS = FlxG.random.getObject(actions);
+
+		if (forceAction != null)
+			daAction = forceAction;
+
+		switch (daAction)
+		{
+			case PUNCH:
+				punch();
+			case BLOCK:
+				block();
+			case DODGE:
+				dodge();
+		}
+	}
+
+	public var curAction:ACTIONS = DODGE;
+
+	function dodge()
+	{
+		playAnim('dodge');
+		curAction = DODGE;
+	}
+
+	public function block()
+	{
+		playAnim('block');
+		curAction = BLOCK;
+	}
+
+	public function punch()
+	{
+		curAction = PUNCH;
+		playAnim('punch ' + (FlxG.random.bool() ? "low" : "high"));
+	}
+}
+
+enum ACTIONS
+{
+	DODGE;
+	BLOCK;
+	PUNCH;
+}
diff --git a/source/play/PicoFight.hx b/source/play/PicoFight.hx
index b7a14132c..576d8b4f8 100644
--- a/source/play/PicoFight.hx
+++ b/source/play/PicoFight.hx
@@ -1,36 +1,204 @@
 package play;
 
+import Note.NoteData;
+import audiovis.PolygonSpectogram;
+import flixel.FlxObject;
 import flixel.FlxSprite;
+import flixel.addons.effects.FlxTrail;
+import flixel.group.FlxGroup.FlxTypedGroup;
+import flixel.math.FlxMath;
+import flixel.util.FlxColor;
+import flixel.util.FlxTimer;
 
 class PicoFight extends MusicBeatState
 {
 	var picoHealth:Float = 1;
 	var darnellHealth:Float = 1;
 
+	var pico:Fighter;
+	var darnell:Fighter;
+	var darnellGhost:Fighter;
+
+	var nextHitTmr:FlxSprite;
+
+	var funnyWave:PolygonSpectogram;
+
+	var noteQueue:Array<NoteData> = [];
+	var noteSpawner:FlxTypedGroup<FlxSprite>;
+
 	override function create()
 	{
+		Paths.setCurrentLevel("week8");
+
 		var bg:FlxSprite = new FlxSprite().makeGraphic(FlxG.width, FlxG.height);
 		bg.scrollFactor.set();
 		add(bg);
 
-		// fuk u, hardcoded bullshit bitch
 		FlxG.sound.playMusic(Paths.inst("blazin"));
-		Conductor.bpm = 180;
+
+		SongLoad.loadFromJson('blazin', "blazin");
+		Conductor.changeBPM(SongLoad.songData.bpm);
+
+		for (dumbassSection in SongLoad.songData.noteMap['hard'])
+		{
+			for (noteStuf in dumbassSection.sectionNotes)
+			{
+				noteQueue.push(noteStuf);
+				trace(noteStuf);
+			}
+		}
+
+		funnyWave = new PolygonSpectogram(FlxG.sound.music, FlxColor.RED, FlxG.height);
+		funnyWave.x = (FlxG.width / 2);
+		funnyWave.realtimeVisLenght = 0.6;
+		add(funnyWave);
+
+		noteSpawner = new FlxTypedGroup<FlxSprite>();
+		add(noteSpawner);
+
+		makeNotes();
+
+		nextHitTmr = new FlxSprite((FlxG.width / 2) - 5).makeGraphic(10, FlxG.height, FlxColor.BLACK);
+		add(nextHitTmr);
+
+		var trailShit:FlxTrail = new FlxTrail(nextHitTmr);
+		add(trailShit);
+
+		pico = new Fighter(0, 300, "pico-fighter");
+		add(pico);
+
+		darnell = new Fighter(0, 300, "darnell-fighter");
+		add(darnell);
+
+		darnellGhost = new Fighter(0, 300, "darnell-fighter");
+		darnellGhost.alpha = 0.5;
+		add(darnellGhost);
+
+		mid = (FlxG.width / 2) - (pico.width / 2);
+		resetPositions();
+
+		// fuk u, hardcoded bullshit bitch
 
 		super.create();
 	}
 
+	function makeNotes()
+	{
+		for (notes in noteQueue)
+		{
+			if (notes.strumTime < Conductor.songPosition + (Conductor.crochet * 4))
+			{
+				spawnNote(notes);
+				spawnNote(notes, FlxObject.RIGHT);
+			}
+		}
+	}
+
+	function spawnNote(note:NoteData, facing:Int = FlxObject.LEFT)
+	{
+		var spr:FlxSprite = new FlxSprite(0, (FlxG.height / 2) - 60).makeGraphic(10, 120, Note.codeColors[note.noteData]);
+		spr.ID = Std.int(note.strumTime); // using ID as strum, lol!
+		spr.facing = facing;
+		noteSpawner.add(spr);
+	}
+
+	var mid:Float = (FlxG.width * 0.5) - 200;
+
+	function resetPositions()
+	{
+		resetPicoPos();
+		resetDarnell();
+	}
+
+	function resetPicoPos()
+	{
+		pico.x = mid + pico.width;
+	}
+
+	function resetDarnell()
+	{
+		darnell.x = mid - darnell.width;
+	}
+
+	var prevNoteHit:Float = 0;
+
 	override function update(elapsed:Float)
 	{
+		darnellGhost.x = darnell.x;
+
 		Conductor.songPosition = FlxG.sound.music.time;
 
+		funnyWave.thickness = CoolUtil.coolLerp(funnyWave.thickness, 2, 0.5);
+		funnyWave.waveAmplitude = Std.int(CoolUtil.coolLerp(funnyWave.waveAmplitude, 100, 0.1));
+		funnyWave.realtimeVisLenght = CoolUtil.coolLerp(funnyWave.realtimeVisLenght, 0.6, 0.1);
+
+		noteSpawner.forEachAlive((nt:FlxSprite) ->
+		{
+			// i forget how to make rhythm games
+			nt.x = (nt.ID - Conductor.songPosition) * (nt.ID / (Conductor.songPosition * 0.8));
+
+			if (nt.facing == FlxObject.RIGHT)
+			{
+				nt.x = FlxMath.remapToRange(nt.x, 0, FlxG.width, FlxG.width, 0);
+				nt.x -= FlxG.width / 2;
+			}
+			else
+			{
+				nt.x += FlxG.width / 2;
+			}
+
+			nt.scale.x = FlxMath.remapToRange(nt.ID - Conductor.songPosition, 0, Conductor.crochet * 3, 0.2, 2);
+			nt.scale.y = FlxMath.remapToRange((nt.ID - Conductor.songPosition), 0, Conductor.crochet * 2, 6, 0.2);
+
+			if (nt.ID < Conductor.songPosition)
+				nt.kill();
+		});
+
+		if (noteQueue.length > 0)
+		{
+			nextHitTmr.scale.y = FlxMath.remapToRange(Conductor.songPosition, prevNoteHit, noteQueue[0].strumTime, 1, 0);
+
+			darnellGhost.scale.x = darnellGhost.scale.y = FlxMath.remapToRange(Conductor.songPosition, prevNoteHit, noteQueue[0].strumTime, 2, 1);
+			darnellGhost.alpha = FlxMath.remapToRange(Conductor.songPosition, prevNoteHit, noteQueue[0].strumTime, 0.3, 0.1);
+
+			if (Conductor.songPosition >= noteQueue[0].strumTime)
+			{
+				prevNoteHit = noteQueue[0].strumTime;
+
+				noteQueue.shift();
+
+				darnell.doSomething(darnellGhost.curAction);
+
+				darnellGhost.doSomething();
+				darnellGhost.animation.curAnim.frameRate = 12;
+			}
+		}
+
+		if (controls.NOTE_LEFT_P)
+		{
+			pico.punch();
+		}
+		if (controls.NOTE_LEFT_R)
+			pico.playAnim('idle');
+
 		super.update(elapsed);
 	}
 
+	override function stepHit()
+	{
+		super.stepHit();
+	}
+
 	override function beatHit()
 	{
+		funnyWave.thickness = 10;
+		funnyWave.waveAmplitude = 300;
+		funnyWave.realtimeVisLenght = 0.1;
+
 		picoHealth += 1;
-		trace(picoHealth);
+
+		makeNotes();
+		// trace(picoHealth);
 		super.beatHit();
 	}
 }