Fix sustain clipping
banger
This commit is contained in:
parent
05817e12ea
commit
7f5d4ac35f
@ -2968,7 +2968,7 @@ class PlayState extends MusicBeatState
|
|||||||
// If not in botplay, only clip sustain notes when properly hit, botplay gets to clip it everytime
|
// If not in botplay, only clip sustain notes when properly hit, botplay gets to clip it everytime
|
||||||
if (!PlayStateChangeables.botPlay)
|
if (!PlayStateChangeables.botPlay)
|
||||||
{
|
{
|
||||||
if ((!daNote.mustPress || daNote.wasGoodHit || daNote.prevNote.wasGoodHit && !daNote.canBeHit)
|
if ((!daNote.mustPress || daNote.wasGoodHit || daNote.prevNote.wasGoodHit || holdArray[Math.floor(Math.abs(daNote.noteData))] && !daNote.canBeHit)
|
||||||
&& daNote.y - daNote.offset.y * daNote.scale.y + daNote.height >= (strumLine.y + Note.swagWidth / 2))
|
&& daNote.y - daNote.offset.y * daNote.scale.y + daNote.height >= (strumLine.y + Note.swagWidth / 2))
|
||||||
{
|
{
|
||||||
// Clip to strumline
|
// Clip to strumline
|
||||||
@ -3009,7 +3009,7 @@ class PlayState extends MusicBeatState
|
|||||||
|
|
||||||
if (!PlayStateChangeables.botPlay)
|
if (!PlayStateChangeables.botPlay)
|
||||||
{
|
{
|
||||||
if ((!daNote.mustPress || daNote.wasGoodHit || daNote.prevNote.wasGoodHit && !daNote.canBeHit)
|
if ((!daNote.mustPress || daNote.wasGoodHit || daNote.prevNote.wasGoodHit || holdArray[Math.floor(Math.abs(daNote.noteData))] && !daNote.canBeHit)
|
||||||
&& daNote.y + daNote.offset.y * daNote.scale.y <= (strumLine.y + Note.swagWidth / 2))
|
&& daNote.y + daNote.offset.y * daNote.scale.y <= (strumLine.y + Note.swagWidth / 2))
|
||||||
{
|
{
|
||||||
// Clip to strumline
|
// Clip to strumline
|
||||||
@ -3121,7 +3121,13 @@ class PlayState extends MusicBeatState
|
|||||||
// WIP interpolation shit? Need to fix the pause issue
|
// WIP interpolation shit? Need to fix the pause issue
|
||||||
// daNote.y = (strumLine.y - (songTime - daNote.strumTime) * (0.45 * PlayState.SONG.speed));
|
// daNote.y = (strumLine.y - (songTime - daNote.strumTime) * (0.45 * PlayState.SONG.speed));
|
||||||
|
|
||||||
if ((daNote.mustPress && daNote.tooLate && !PlayStateChangeables.useDownscroll || daNote.mustPress && daNote.tooLate
|
if (daNote.isSustainNote && daNote.wasGoodHit && Conductor.songPosition >= daNote.strumTime)
|
||||||
|
{
|
||||||
|
daNote.kill();
|
||||||
|
notes.remove(daNote, true);
|
||||||
|
daNote.destroy();
|
||||||
|
}
|
||||||
|
else if ((daNote.mustPress && daNote.tooLate && !PlayStateChangeables.useDownscroll || daNote.mustPress && daNote.tooLate
|
||||||
&& PlayStateChangeables.useDownscroll)
|
&& PlayStateChangeables.useDownscroll)
|
||||||
&& daNote.mustPress)
|
&& daNote.mustPress)
|
||||||
{
|
{
|
||||||
@ -4285,9 +4291,16 @@ class PlayState extends MusicBeatState
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (!note.isSustainNote)
|
||||||
|
{
|
||||||
note.kill();
|
note.kill();
|
||||||
notes.remove(note, true);
|
notes.remove(note, true);
|
||||||
note.destroy();
|
note.destroy();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
note.wasGoodHit = true;
|
||||||
|
}
|
||||||
|
|
||||||
updateAccuracy();
|
updateAccuracy();
|
||||||
}
|
}
|
||||||
|
48
source/SusClip.hx
Normal file
48
source/SusClip.hx
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
package;
|
||||||
|
|
||||||
|
import flixel.FlxG;
|
||||||
|
import flixel.FlxSprite;
|
||||||
|
import flixel.graphics.frames.FlxAtlasFrames;
|
||||||
|
import flixel.math.FlxMath;
|
||||||
|
import flixel.util.FlxColor;
|
||||||
|
|
||||||
|
import Note;
|
||||||
|
|
||||||
|
class SusClip extends FlxSprite
|
||||||
|
{
|
||||||
|
public var strumTime:Float = 0;
|
||||||
|
public var noteData:Int = 0;
|
||||||
|
public var mustPress:Bool = false;
|
||||||
|
public var noteYOff:Int = 0;
|
||||||
|
|
||||||
|
public function new(note:Note)
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
|
||||||
|
//Copy note data
|
||||||
|
strumTime = note.strumTime;
|
||||||
|
noteData = note.noteData;
|
||||||
|
mustPress = note.mustPress;
|
||||||
|
noteYOff = note.noteYOff;
|
||||||
|
|
||||||
|
x = note.x;
|
||||||
|
y = note.y;
|
||||||
|
alpha = note.alpha;
|
||||||
|
loadGraphicFromSprite(note);
|
||||||
|
|
||||||
|
angle = note.angle;
|
||||||
|
flipY = note.flipY;
|
||||||
|
clipRect = note.clipRect;
|
||||||
|
scale.copyFrom(note.scale);
|
||||||
|
scrollFactor.copyFrom(note.scrollFactor);
|
||||||
|
updateHitbox();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
override function update(elapsed:Float)
|
||||||
|
{
|
||||||
|
super.update(elapsed);
|
||||||
|
angle = modAngle + localAngle;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user