1
0
Fork 0
mirror of https://github.com/ninjamuffin99/Funkin.git synced 2024-12-26 15:07:14 +00:00

Merge remote-tracking branch 'origin/master' into feature/scripted-modules

This commit is contained in:
Eric Myllyoja 2022-04-18 19:46:39 -04:00
commit 0b17f74f48
6 changed files with 77 additions and 16 deletions

View file

@ -1,8 +1,5 @@
package funkin; package funkin;
import funkin.modding.module.ModuleHandler;
import funkin.play.stage.StageData;
import funkin.charting.ChartingState;
import flixel.addons.transition.FlxTransitionSprite.GraphicTransTileDiamond; import flixel.addons.transition.FlxTransitionSprite.GraphicTransTileDiamond;
import flixel.addons.transition.FlxTransitionableState; import flixel.addons.transition.FlxTransitionableState;
import flixel.addons.transition.TransitionData; import flixel.addons.transition.TransitionData;
@ -10,12 +7,18 @@ import flixel.graphics.FlxGraphic;
import flixel.math.FlxPoint; import flixel.math.FlxPoint;
import flixel.math.FlxRect; import flixel.math.FlxRect;
import flixel.util.FlxColor; import flixel.util.FlxColor;
import openfl.display.BitmapData; import funkin.charting.ChartingState;
import funkin.charting.ChartingState;
import funkin.modding.module.ModuleHandler;
import funkin.play.PicoFight; import funkin.play.PicoFight;
import funkin.play.PlayState;
import funkin.play.stage.StageData;
import funkin.play.stage.StageData;
import funkin.ui.PreferencesMenu; import funkin.ui.PreferencesMenu;
import funkin.ui.animDebugShit.DebugBoundingState;
import funkin.ui.stageBuildShit.StageBuilderState; import funkin.ui.stageBuildShit.StageBuilderState;
import funkin.util.macro.MacroUtil; import funkin.util.macro.MacroUtil;
import funkin.play.PlayState; import openfl.display.BitmapData;
using StringTools; using StringTools;
@ -176,7 +179,7 @@ class InitState extends FlxTransitionableState
#elseif FIGHT #elseif FIGHT
FlxG.switchState(new PicoFight()); FlxG.switchState(new PicoFight());
#elseif ANIMDEBUG #elseif ANIMDEBUG
FlxG.switchState(new ui.animDebugShit.DebugBoundingState()); FlxG.switchState(new DebugBoundingState());
#elseif NETTEST #elseif NETTEST
FlxG.switchState(new netTest.NetTest()); FlxG.switchState(new netTest.NetTest());
#else #else

View file

@ -80,8 +80,8 @@ class Note extends FlxSprite
public static var RED_NOTE:Int = 3; public static var RED_NOTE:Int = 3;
// SCORING STUFF // SCORING STUFF
public static var safeFrames:Int = 10; public static var HIT_WINDOW:Float = (10 / 60) * 1000; // 166.67 ms hit window (10 frames at 60fps)
public static var HIT_WINDOW:Float = (safeFrames / 60) * 1000; // 166.67 ms hit window // thresholds are fractions of HIT_WINDOW ^^
// anything above bad threshold is shit // anything above bad threshold is shit
public static var BAD_THRESHOLD:Float = 0.8; // 125ms , 8 frames public static var BAD_THRESHOLD:Float = 0.8; // 125ms , 8 frames
public static var GOOD_THRESHOLD:Float = 0.55; // 91.67ms , 5.5 frames public static var GOOD_THRESHOLD:Float = 0.55; // 91.67ms , 5.5 frames

View file

@ -22,6 +22,8 @@ class NoteSplash extends FlxSprite
setupNoteSplash(x, y, noteData); setupNoteSplash(x, y, noteData);
antialiasing = true;
// alpha = 0.75; // alpha = 0.75;
} }

View file

@ -43,7 +43,10 @@ class PauseSubState extends MusicBeatSubstate
menuItems = pauseOG; menuItems = pauseOG;
pauseMusic = new FlxSound().loadEmbedded(Paths.music('breakfast'), true, true); if (PlayState.storyWeek == 6) // consistent with logic that decides asset lib!!
pauseMusic = new FlxSound().loadEmbedded(Paths.music('breakfast-pixel'), true, true);
else
pauseMusic = new FlxSound().loadEmbedded(Paths.music('breakfast'), true, true);
pauseMusic.volume = 0; pauseMusic.volume = 0;
pauseMusic.play(false, FlxG.random.int(0, Std.int(pauseMusic.length / 2))); pauseMusic.play(false, FlxG.random.int(0, Std.int(pauseMusic.length / 2)));

View file

@ -38,6 +38,31 @@ class VoicesGroup extends FlxTypedGroup<FlxSound>
} }
} }
/**
* Finds the largest deviation from the desired time inside this VoicesGroup.
*
* @param targetTime The time to check against.
* If none is provided, it checks the time of all members against the first member of this VoicesGroup.
* @return The largest deviation from the target time found.
*/
public function checkSyncError(?targetTime:Float):Float
{
var error:Float = 0;
forEachAlive(function(snd)
{
if (targetTime == null)
targetTime = snd.time;
else
{
var diff:Float = snd.time - targetTime;
if (Math.abs(diff) > Math.abs(error))
error = diff;
}
});
return error;
}
// prob a better / cleaner way to do all these forEach stuff? // prob a better / cleaner way to do all these forEach stuff?
public function pause() public function pause()
{ {

View file

@ -5,7 +5,6 @@ import flixel.FlxObject;
import flixel.FlxSprite; import flixel.FlxSprite;
import flixel.FlxState; import flixel.FlxState;
import flixel.FlxSubState; import flixel.FlxSubState;
import flixel.addons.effects.FlxTrail;
import flixel.addons.transition.FlxTransitionableState; import flixel.addons.transition.FlxTransitionableState;
import flixel.group.FlxGroup; import flixel.group.FlxGroup;
import flixel.math.FlxMath; import flixel.math.FlxMath;
@ -541,11 +540,6 @@ class PlayState extends MusicBeatState implements IHook
// REPOSITIONING PER STAGE // REPOSITIONING PER STAGE
switch (currentStageId) switch (currentStageId)
{ {
case 'schoolEvil':
var evilTrail = new FlxTrail(dad, null, 4, 24, 0.3, 0.069);
// Go behind Spirit.
evilTrail.zIndex = 190;
add(evilTrail);
case "tank": case "tank":
gf.y += 10; gf.y += 10;
gf.x -= 30; gf.x -= 30;
@ -825,7 +819,7 @@ class PlayState extends MusicBeatState implements IHook
var gottaHitNote:Bool = section.mustHitSection; var gottaHitNote:Bool = section.mustHitSection;
if (songNotes.highStakes) if (songNotes.highStakes) // noteData > 3
gottaHitNote = !section.mustHitSection; gottaHitNote = !section.mustHitSection;
var oldNote:Note; var oldNote:Note;
@ -838,6 +832,10 @@ class PlayState extends MusicBeatState implements IHook
// swagNote.data = songNotes; // swagNote.data = songNotes;
swagNote.data.sustainLength = songNotes.sustainLength; swagNote.data.sustainLength = songNotes.sustainLength;
swagNote.data.altNote = songNotes.altNote; swagNote.data.altNote = songNotes.altNote;
<<<<<<< HEAD
=======
>>>>>>> origin/master
swagNote.scrollFactor.set(0, 0); swagNote.scrollFactor.set(0, 0);
var susLength:Float = swagNote.data.sustainLength; var susLength:Float = swagNote.data.sustainLength;
@ -939,10 +937,15 @@ class PlayState extends MusicBeatState implements IHook
vocals.pause(); vocals.pause();
FlxG.sound.music.time = 0; FlxG.sound.music.time = 0;
regenNoteData(); // loads the note data from start regenNoteData(); // loads the note data from start
health = 1; health = 1;
songScore = 0; songScore = 0;
<<<<<<< HEAD
Countdown.performCountdown(currentStageId.startsWith('school')); Countdown.performCountdown(currentStageId.startsWith('school'));
=======
restartCountdownTimer();
>>>>>>> origin/master
needsReset = false; needsReset = false;
} }
@ -1258,9 +1261,19 @@ class PlayState extends MusicBeatState implements IHook
// TODO: Why the hell is the noteMiss logic in two different places? // TODO: Why the hell is the noteMiss logic in two different places?
if (daNote.tooLate) if (daNote.tooLate)
{ {
<<<<<<< HEAD
var event:NoteScriptEvent = new NoteScriptEvent(ScriptEvent.NOTE_MISS, daNote, true); var event:NoteScriptEvent = new NoteScriptEvent(ScriptEvent.NOTE_MISS, daNote, true);
dispatchEvent(event); dispatchEvent(event);
health -= 0.0775; health -= 0.0775;
=======
if (curStage != null)
{
curStage.onNoteMiss(daNote);
}
// lose less health on sustain notes!
health -= 0.0775 * (daNote.isSustainNote ? 0.2 : 1); // if it's sustain, multiply it by 0.2 (not checked for balence yet), else keep it same (multiply by 1)
>>>>>>> origin/master
vocals.volume = 0; vocals.volume = 0;
killCombo(); killCombo();
} }
@ -1528,9 +1541,15 @@ class PlayState extends MusicBeatState implements IHook
switch (currentStageId) switch (currentStageId)
{ {
case 'limo': case 'limo':
<<<<<<< HEAD
cameraFollowPoint.x = currentStage.getBoyfriend().getMidpoint().x - 300; cameraFollowPoint.x = currentStage.getBoyfriend().getMidpoint().x - 300;
case 'mall': case 'mall':
cameraFollowPoint.y = currentStage.getBoyfriend().getMidpoint().y - 200; cameraFollowPoint.y = currentStage.getBoyfriend().getMidpoint().y - 200;
=======
camFollow.x = boyfriend.getMidpoint().x - 300;
case 'mallXmas':
camFollow.y = boyfriend.getMidpoint().y - 200;
>>>>>>> origin/master
case 'school' | 'schoolEvil': case 'school' | 'schoolEvil':
cameraFollowPoint.x = currentStage.getBoyfriend().getMidpoint().x - 200; cameraFollowPoint.x = currentStage.getBoyfriend().getMidpoint().x - 200;
cameraFollowPoint.y = currentStage.getBoyfriend().getMidpoint().y - 200; cameraFollowPoint.y = currentStage.getBoyfriend().getMidpoint().y - 200;
@ -1723,8 +1742,17 @@ class PlayState extends MusicBeatState implements IHook
if (!super.stepHit()) if (!super.stepHit())
return false; return false;
<<<<<<< HEAD
if (Math.abs(FlxG.sound.music.time - (Conductor.songPosition - Conductor.offset)) > 20 if (Math.abs(FlxG.sound.music.time - (Conductor.songPosition - Conductor.offset)) > 20
|| (currentSong.needsVoices && Math.abs(vocals.time - (Conductor.songPosition - Conductor.offset)) > 20)) || (currentSong.needsVoices && Math.abs(vocals.time - (Conductor.songPosition - Conductor.offset)) > 20))
=======
override function stepHit()
{
super.stepHit();
if (Math.abs(FlxG.sound.music.time - (Conductor.songPosition - Conductor.offset)) > 20
|| Math.abs(vocals.checkSyncError(Conductor.songPosition - Conductor.offset)) > 20)
>>>>>>> origin/master
{ {
resyncVocals(); resyncVocals();
} }