don't draw animations when hidden is enabled
This commit is contained in:
parent
62a7ee0f21
commit
59ed2f9ee3
|
@ -26,7 +26,6 @@ import itdelatrisu.opsu.beatmap.Beatmap;
|
||||||
import itdelatrisu.opsu.beatmap.HitObject;
|
import itdelatrisu.opsu.beatmap.HitObject;
|
||||||
import itdelatrisu.opsu.downloads.Updater;
|
import itdelatrisu.opsu.downloads.Updater;
|
||||||
import itdelatrisu.opsu.objects.curves.Curve;
|
import itdelatrisu.opsu.objects.curves.Curve;
|
||||||
import itdelatrisu.opsu.objects.curves.Vec2f;
|
|
||||||
import itdelatrisu.opsu.replay.Replay;
|
import itdelatrisu.opsu.replay.Replay;
|
||||||
import itdelatrisu.opsu.replay.ReplayFrame;
|
import itdelatrisu.opsu.replay.ReplayFrame;
|
||||||
import itdelatrisu.opsu.ui.Colors;
|
import itdelatrisu.opsu.ui.Colors;
|
||||||
|
@ -892,9 +891,42 @@ public class GameData {
|
||||||
lighting.drawCentered(hitResult.x, hitResult.y, hitResult.color);
|
lighting.drawCentered(hitResult.x, hitResult.y, hitResult.color);
|
||||||
}
|
}
|
||||||
|
|
||||||
// slider done animation
|
// hit animations, only draw when the 'hidden' mod is not enabled
|
||||||
|
if (!GameMod.HIDDEN.isActive()) {
|
||||||
|
drawHitAnimations(hitResult, trackPosition);
|
||||||
|
}
|
||||||
|
|
||||||
// hit animations
|
// hit result
|
||||||
|
if (!hitResult.hideResult && (
|
||||||
|
hitResult.hitResultType == HitObjectType.CIRCLE ||
|
||||||
|
hitResult.hitResultType == HitObjectType.SPINNER ||
|
||||||
|
hitResult.curve != null)) {
|
||||||
|
float scaleProgress = AnimationEquation.IN_OUT_BOUNCE.calc(
|
||||||
|
(float) Utils.clamp(trackPosition - hitResult.time, 0, HITCIRCLE_TEXT_BOUNCE_TIME) / HITCIRCLE_TEXT_BOUNCE_TIME);
|
||||||
|
float scale = 1f + (HITCIRCLE_TEXT_ANIM_SCALE - 1f) * scaleProgress;
|
||||||
|
float fadeProgress = AnimationEquation.OUT_CUBIC.calc(
|
||||||
|
(float) Utils.clamp((trackPosition - hitResult.time) - HITCIRCLE_FADE_TIME, 0, HITCIRCLE_TEXT_FADE_TIME) / HITCIRCLE_TEXT_FADE_TIME);
|
||||||
|
float alpha = 1f - fadeProgress;
|
||||||
|
Image scaledHitResult = hitResults[hitResult.result].getScaledCopy(scale);
|
||||||
|
scaledHitResult.setAlpha(alpha);
|
||||||
|
scaledHitResult.drawCentered(hitResult.x, hitResult.y);
|
||||||
|
}
|
||||||
|
|
||||||
|
hitResult.alpha = 1 - ((float) (trackPosition - hitResult.time) / HITRESULT_FADE_TIME);
|
||||||
|
} else {
|
||||||
|
if (hitResult.curve != null)
|
||||||
|
hitResult.curve.discardGeometry();
|
||||||
|
iter.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Draw the hit animations: circles, reversearrows, slider curves fading out and/or expanding
|
||||||
|
* @param hitResult the hitresult which holds information about the kind of animation to draw
|
||||||
|
* @param trackPosition the current track position (in ms)
|
||||||
|
*/
|
||||||
|
private void drawHitAnimations(HitObjectResult hitResult, int trackPosition) {
|
||||||
if (hitResult.hitResultType == HitObjectType.SLIDER_CURVE && hitResult.curve != null) {
|
if (hitResult.hitResultType == HitObjectType.SLIDER_CURVE && hitResult.curve != null) {
|
||||||
float progress = AnimationEquation.OUT_CUBIC.calc(
|
float progress = AnimationEquation.OUT_CUBIC.calc(
|
||||||
(float) Utils.clamp(trackPosition - hitResult.time, 0, HITCIRCLE_FADE_TIME) / HITCIRCLE_FADE_TIME);
|
(float) Utils.clamp(trackPosition - hitResult.time, 0, HITCIRCLE_FADE_TIME) / HITCIRCLE_FADE_TIME);
|
||||||
|
@ -941,30 +973,6 @@ public class GameData {
|
||||||
scaledHitCircle.drawCentered(hitResult.x, hitResult.y, hitResult.color);
|
scaledHitCircle.drawCentered(hitResult.x, hitResult.y, hitResult.color);
|
||||||
scaledHitCircleOverlay.drawCentered(hitResult.x, hitResult.y);
|
scaledHitCircleOverlay.drawCentered(hitResult.x, hitResult.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
// hit result
|
|
||||||
if (!hitResult.hideResult && (
|
|
||||||
hitResult.hitResultType == HitObjectType.CIRCLE ||
|
|
||||||
hitResult.hitResultType == HitObjectType.SPINNER ||
|
|
||||||
hitResult.curve != null)) {
|
|
||||||
float scaleProgress = AnimationEquation.IN_OUT_BOUNCE.calc(
|
|
||||||
(float) Utils.clamp(trackPosition - hitResult.time, 0, HITCIRCLE_TEXT_BOUNCE_TIME) / HITCIRCLE_TEXT_BOUNCE_TIME);
|
|
||||||
float scale = 1f + (HITCIRCLE_TEXT_ANIM_SCALE - 1f) * scaleProgress;
|
|
||||||
float fadeProgress = AnimationEquation.OUT_CUBIC.calc(
|
|
||||||
(float) Utils.clamp((trackPosition - hitResult.time) - HITCIRCLE_FADE_TIME, 0, HITCIRCLE_TEXT_FADE_TIME) / HITCIRCLE_TEXT_FADE_TIME);
|
|
||||||
float alpha = 1f - fadeProgress;
|
|
||||||
Image scaledHitResult = hitResults[hitResult.result].getScaledCopy(scale);
|
|
||||||
scaledHitResult.setAlpha(alpha);
|
|
||||||
scaledHitResult.drawCentered(hitResult.x, hitResult.y);
|
|
||||||
}
|
|
||||||
|
|
||||||
hitResult.alpha = 1 - ((float) (trackPosition - hitResult.time) / HITRESULT_FADE_TIME);
|
|
||||||
} else {
|
|
||||||
if (hitResult.curve != null)
|
|
||||||
hitResult.curve.discardGeometry();
|
|
||||||
iter.remove();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue
Block a user