From 6679575c137ce4a13b15cf2ac884a3b1fa0c23a2 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Thu, 15 Jun 2017 15:06:38 +0900 Subject: [PATCH] Add current time labels --- .../Tests/TestCaseScrollingHitObjects.cs | 68 ++++++++++++++++--- 1 file changed, 57 insertions(+), 11 deletions(-) diff --git a/osu.Desktop.VisualTests/Tests/TestCaseScrollingHitObjects.cs b/osu.Desktop.VisualTests/Tests/TestCaseScrollingHitObjects.cs index 32ec522737..7935e31042 100644 --- a/osu.Desktop.VisualTests/Tests/TestCaseScrollingHitObjects.cs +++ b/osu.Desktop.VisualTests/Tests/TestCaseScrollingHitObjects.cs @@ -9,6 +9,7 @@ using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.UserInterface; using osu.Framework.Testing; +using osu.Game.Graphics.Sprites; using osu.Game.Rulesets.Objects; using osu.Game.Rulesets.Objects.Drawables; using osu.Game.Rulesets.Timing; @@ -22,8 +23,9 @@ namespace osu.Desktop.VisualTests.Tests private SpeedAdjustmentCollection adjustmentCollection; private BindableDouble timeRangeBindable; - private SpriteText timeRangeText; - private SpriteText bottomLabel; + private OsuSpriteText timeRangeText; + private OsuSpriteText bottomLabel; + private SpriteText topTime, bottomTime; public override void Reset() { @@ -43,7 +45,7 @@ namespace osu.Desktop.VisualTests.Tests KeyboardStep = 100 }); - Add(timeRangeText = new SpriteText + Add(timeRangeText = new OsuSpriteText { X = 210, TextSize = 16, @@ -70,21 +72,38 @@ namespace osu.Desktop.VisualTests.Tests adjustmentCollection = new SpeedAdjustmentCollection { RelativeSizeAxes = Axes.Both, - VisibleTimeRange = timeRangeBindable + VisibleTimeRange = timeRangeBindable, + Masking = true, }, - new SpriteText + new OsuSpriteText { Text = "t minus 0", + Margin = new MarginPadding(2), TextSize = 14, Anchor = Anchor.TopRight, }, - bottomLabel = new SpriteText + bottomLabel = new OsuSpriteText { Text = "t minus x", + Margin = new MarginPadding(2), TextSize = 14, Anchor = Anchor.BottomRight, Origin = Anchor.BottomLeft, }, + topTime = new OsuSpriteText + { + Margin = new MarginPadding(2), + TextSize = 14, + Anchor = Anchor.TopLeft, + Origin = Anchor.TopRight, + }, + bottomTime = new OsuSpriteText + { + Margin = new MarginPadding(2), + TextSize = 14, + Anchor = Anchor.BottomLeft, + Origin = Anchor.BottomRight, + }, } } }); @@ -96,6 +115,13 @@ namespace osu.Desktop.VisualTests.Tests AddStep("Add hit object", () => adjustmentCollection.Add(new TestDrawableHitObject(new HitObject { StartTime = Time.Current + 2000 }))); } + protected override void Update() + { + base.Update(); + topTime.Text = Time.Current.ToString("#,#"); + bottomTime.Text = (Time.Current + timeRangeBindable.Value).ToString("#,#"); + } + private class TestSpeedAdjustmentContainer : SpeedAdjustmentContainer { public TestSpeedAdjustmentContainer(MultiplierControlPoint controlPoint) @@ -126,6 +152,8 @@ namespace osu.Desktop.VisualTests.Tests private class TestDrawableHitObject : DrawableHitObject { + private const float height = 14; + public TestDrawableHitObject(HitObject hitObject) : base(hitObject) { @@ -135,12 +163,30 @@ namespace osu.Desktop.VisualTests.Tests Y = (float)hitObject.StartTime; - Add(new Box + Children = new Drawable[] { - RelativeSizeAxes = Axes.X, - Height = 10, - }); + new Box + { + RelativeSizeAxes = Axes.X, + Height = height, + }, + new Box + { + RelativeSizeAxes = Axes.X, + Colour = Color4.Cyan, + Height = 1, + }, + new OsuSpriteText + { + Anchor = Anchor.Centre, + Origin = Anchor.Centre, + Colour = Color4.Black, + TextSize = height, + Font = @"Exo2.0-BoldItalic", + Text = $"{hitObject.StartTime:#,#}" + } + }; } } } -} \ No newline at end of file +}