mirror of
https://github.com/ppy/osu.git
synced 2025-01-21 07:33:12 +08:00
Make RemainingTimeCounter into a Counter
This commit is contained in:
parent
4854302aaa
commit
2fbd490626
@ -7,6 +7,7 @@ using osu.Framework.Graphics.Shapes;
|
|||||||
using osu.Game.Beatmaps.Timing;
|
using osu.Game.Beatmaps.Timing;
|
||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
|
||||||
namespace osu.Game.Screens.Play.BreaksOverlay
|
namespace osu.Game.Screens.Play.BreaksOverlay
|
||||||
{
|
{
|
||||||
@ -115,7 +116,7 @@ namespace osu.Game.Screens.Play.BreaksOverlay
|
|||||||
.Then()
|
.Then()
|
||||||
.ResizeWidthTo(1);
|
.ResizeWidthTo(1);
|
||||||
|
|
||||||
remainingTimeCounter.CountTo(b.Duration);
|
remainingTimeCounter.CountTo(b.Duration).CountTo(0, b.Duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
using (BeginAbsoluteSequence(b.StartTime))
|
using (BeginAbsoluteSequence(b.StartTime))
|
||||||
|
@ -6,10 +6,11 @@ using osu.Game.Graphics.Sprites;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using System;
|
using System;
|
||||||
using osu.Game.Beatmaps.Timing;
|
using osu.Game.Beatmaps.Timing;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
|
||||||
namespace osu.Game.Screens.Play.BreaksOverlay
|
namespace osu.Game.Screens.Play.BreaksOverlay
|
||||||
{
|
{
|
||||||
public class RemainingTimeCounter : Container
|
public class RemainingTimeCounter : Counter
|
||||||
{
|
{
|
||||||
private const double fade_duration = BreakPeriod.MIN_BREAK_DURATION / 2;
|
private const double fade_duration = BreakPeriod.MIN_BREAK_DURATION / 2;
|
||||||
|
|
||||||
@ -18,7 +19,7 @@ namespace osu.Game.Screens.Play.BreaksOverlay
|
|||||||
public RemainingTimeCounter()
|
public RemainingTimeCounter()
|
||||||
{
|
{
|
||||||
AutoSizeAxes = Axes.Both;
|
AutoSizeAxes = Axes.Both;
|
||||||
Child = counter = new OsuSpriteText
|
InternalChild = counter = new OsuSpriteText
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
@ -29,21 +30,7 @@ namespace osu.Game.Screens.Play.BreaksOverlay
|
|||||||
Alpha = 0;
|
Alpha = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void CountTo(double duration)
|
protected override void OnCountChanged(double count) => counter.Text = ((int)Math.Ceiling(count / 1000)).ToString();
|
||||||
{
|
|
||||||
double offset = 0;
|
|
||||||
|
|
||||||
while (duration > 0)
|
|
||||||
{
|
|
||||||
int seconds = (int)Math.Ceiling(duration / 1000);
|
|
||||||
counter.Delay(offset).TransformTextTo(seconds.ToString());
|
|
||||||
|
|
||||||
double localOffset = duration - (seconds - 1) * 1000 + 1; // +1 because we want the duration to be the next second when ceiled
|
|
||||||
|
|
||||||
offset += localOffset;
|
|
||||||
duration -= localOffset;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public override void Show() => this.FadeIn(fade_duration);
|
public override void Show() => this.FadeIn(fade_duration);
|
||||||
public override void Hide() => this.FadeOut(fade_duration);
|
public override void Hide() => this.FadeOut(fade_duration);
|
||||||
|
Loading…
Reference in New Issue
Block a user