mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 12:45:09 +08:00
Update animations for new/old miss style and add fades
This commit is contained in:
parent
9d3de5bca0
commit
c47e70da9b
@ -47,18 +47,18 @@ namespace osu.Game.Rulesets.Judgements
|
|||||||
|
|
||||||
public virtual void PlayAnimation()
|
public virtual void PlayAnimation()
|
||||||
{
|
{
|
||||||
this.RotateTo(0);
|
|
||||||
this.MoveTo(Vector2.Zero);
|
|
||||||
|
|
||||||
switch (Result)
|
switch (Result)
|
||||||
{
|
{
|
||||||
case HitResult.Miss:
|
case HitResult.Miss:
|
||||||
this.ScaleTo(1.6f);
|
this.ScaleTo(1.6f);
|
||||||
this.ScaleTo(1, 100, Easing.In);
|
this.ScaleTo(1, 100, Easing.In);
|
||||||
|
|
||||||
|
this.MoveTo(Vector2.Zero);
|
||||||
this.MoveToOffset(new Vector2(0, 100), 800, Easing.InQuint);
|
this.MoveToOffset(new Vector2(0, 100), 800, Easing.InQuint);
|
||||||
|
|
||||||
|
this.RotateTo(0);
|
||||||
this.RotateTo(40, 800, Easing.InQuint);
|
this.RotateTo(40, 800, Easing.InQuint);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -66,6 +66,8 @@ namespace osu.Game.Rulesets.Judgements
|
|||||||
this.ScaleTo(1, 500, Easing.OutElastic);
|
this.ScaleTo(1, 500, Easing.OutElastic);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.FadeOutFromOne(800);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ using System;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Animations;
|
using osu.Framework.Graphics.Animations;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Rulesets.Judgements;
|
using osu.Game.Rulesets.Judgements;
|
||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
using osuTK;
|
using osuTK;
|
||||||
@ -53,9 +54,14 @@ namespace osu.Game.Skinning
|
|||||||
|
|
||||||
animation?.GotoFrame(0);
|
animation?.GotoFrame(0);
|
||||||
|
|
||||||
this.RotateTo(0);
|
const double fade_in_length = 120;
|
||||||
this.MoveTo(Vector2.Zero);
|
const double fade_out_delay = 500;
|
||||||
|
const double fade_out_length = 600;
|
||||||
|
|
||||||
|
this.FadeInFromZero(fade_in_length);
|
||||||
|
this.Delay(fade_out_delay).FadeOut(fade_out_length);
|
||||||
|
|
||||||
|
// new style non-miss judgements show the original style temporarily, with additive colour.
|
||||||
if (temporaryOldStyle != null)
|
if (temporaryOldStyle != null)
|
||||||
{
|
{
|
||||||
temporaryOldStyle.PlayAnimation();
|
temporaryOldStyle.PlayAnimation();
|
||||||
@ -73,19 +79,23 @@ namespace osu.Game.Skinning
|
|||||||
switch (result)
|
switch (result)
|
||||||
{
|
{
|
||||||
case HitResult.Miss:
|
case HitResult.Miss:
|
||||||
mainPiece.ScaleTo(1.6f);
|
this.ScaleTo(1.6f);
|
||||||
mainPiece.ScaleTo(1, 100, Easing.In);
|
this.ScaleTo(1, 100, Easing.In);
|
||||||
|
|
||||||
mainPiece.MoveToOffset(new Vector2(0, 100), 800, Easing.InQuint);
|
//todo: this only applies to osu! ruleset apparently.
|
||||||
|
this.MoveTo(new Vector2(0, -2));
|
||||||
|
this.MoveToOffset(new Vector2(0, 20), fade_out_delay + fade_out_length, Easing.In);
|
||||||
|
|
||||||
mainPiece.RotateTo(40, 800, Easing.InQuint);
|
float rotation = RNG.NextSingle(-8.6f, 8.6f);
|
||||||
|
|
||||||
|
this.RotateTo(0);
|
||||||
|
this.RotateTo(rotation, fade_in_length)
|
||||||
|
.Then().RotateTo(rotation * 2, fade_out_delay + fade_out_length - fade_in_length, Easing.In);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
const double animation_length = 1100;
|
|
||||||
|
|
||||||
mainPiece.ScaleTo(0.9f);
|
mainPiece.ScaleTo(0.9f);
|
||||||
mainPiece.ScaleTo(1.05f, animation_length);
|
mainPiece.ScaleTo(1.05f, fade_out_delay + fade_out_length);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,9 +5,9 @@ using System;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Animations;
|
using osu.Framework.Graphics.Animations;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Rulesets.Judgements;
|
using osu.Game.Rulesets.Judgements;
|
||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
using osuTK;
|
|
||||||
|
|
||||||
namespace osu.Game.Skinning
|
namespace osu.Game.Skinning
|
||||||
{
|
{
|
||||||
@ -34,8 +34,12 @@ namespace osu.Game.Skinning
|
|||||||
|
|
||||||
animation?.GotoFrame(0);
|
animation?.GotoFrame(0);
|
||||||
|
|
||||||
this.RotateTo(0);
|
const double fade_in_length = 120;
|
||||||
this.MoveTo(Vector2.Zero);
|
const double fade_out_delay = 500;
|
||||||
|
const double fade_out_length = 600;
|
||||||
|
|
||||||
|
this.FadeInFromZero(fade_in_length);
|
||||||
|
this.Delay(fade_out_delay).FadeOut(fade_out_length);
|
||||||
|
|
||||||
// legacy judgements don't play any transforms if they are an animation.
|
// legacy judgements don't play any transforms if they are an animation.
|
||||||
if (animation?.FrameCount > 1)
|
if (animation?.FrameCount > 1)
|
||||||
@ -47,20 +51,21 @@ namespace osu.Game.Skinning
|
|||||||
this.ScaleTo(1.6f);
|
this.ScaleTo(1.6f);
|
||||||
this.ScaleTo(1, 100, Easing.In);
|
this.ScaleTo(1, 100, Easing.In);
|
||||||
|
|
||||||
this.MoveToOffset(new Vector2(0, 100), 800, Easing.InQuint);
|
float rotation = RNG.NextSingle(-8.6f, 8.6f);
|
||||||
|
|
||||||
this.RotateTo(40, 800, Easing.InQuint);
|
this.RotateTo(0);
|
||||||
|
this.RotateTo(rotation, fade_in_length)
|
||||||
|
.Then().RotateTo(rotation * 2, fade_out_delay + fade_out_length - fade_in_length, Easing.In);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
const double animation_length = 120;
|
|
||||||
|
|
||||||
this.ScaleTo(0.6f).Then()
|
this.ScaleTo(0.6f).Then()
|
||||||
.ScaleTo(1.1f, animation_length * 0.8f).Then()
|
.ScaleTo(1.1f, fade_in_length * 0.8f).Then()
|
||||||
// this is actually correct to match stable; there were overlapping transforms.
|
// this is actually correct to match stable; there were overlapping transforms.
|
||||||
.ScaleTo(0.9f).Delay(animation_length * 0.2f)
|
.ScaleTo(0.9f).Delay(fade_in_length * 0.2f)
|
||||||
.ScaleTo(1.1f).ScaleTo(0.9f, animation_length * 0.2f).Then()
|
.ScaleTo(1.1f).ScaleTo(0.9f, fade_in_length * 0.2f).Then()
|
||||||
.ScaleTo(0.95f).ScaleTo(finalScale, animation_length * 0.2f);
|
.ScaleTo(0.95f).ScaleTo(finalScale, fade_in_length * 0.2f);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -373,11 +373,11 @@ namespace osu.Game.Skinning
|
|||||||
case GameplaySkinComponent<HitResult> resultComponent:
|
case GameplaySkinComponent<HitResult> resultComponent:
|
||||||
Func<Drawable> createDrawable = () => getJudgementAnimation(resultComponent.Component);
|
Func<Drawable> createDrawable = () => getJudgementAnimation(resultComponent.Component);
|
||||||
|
|
||||||
|
// kind of wasteful that we throw this away, but should do for now.
|
||||||
if (createDrawable() != null)
|
if (createDrawable() != null)
|
||||||
{
|
{
|
||||||
var particles = getParticleTexture(resultComponent.Component);
|
if (Configuration.LegacyVersion > 1)
|
||||||
if (particles != null)
|
return new LegacyJudgementPieceNew(resultComponent.Component, createDrawable, getParticleDrawable(resultComponent.Component));
|
||||||
return new LegacyJudgementPieceNew(resultComponent.Component, createDrawable, getParticleTexture(resultComponent.Component));
|
|
||||||
else
|
else
|
||||||
return new LegacyJudgementPieceOld(resultComponent.Component, createDrawable);
|
return new LegacyJudgementPieceOld(resultComponent.Component, createDrawable);
|
||||||
}
|
}
|
||||||
@ -388,7 +388,7 @@ namespace osu.Game.Skinning
|
|||||||
return this.GetAnimation(component.LookupName, false, false);
|
return this.GetAnimation(component.LookupName, false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Drawable getParticleTexture(HitResult result)
|
private Drawable getParticleDrawable(HitResult result)
|
||||||
{
|
{
|
||||||
switch (result)
|
switch (result)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user