1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 02:43:19 +08:00

Update loop logic in line with framework changes

This commit is contained in:
Dean Herbert 2017-07-09 18:23:34 +09:00
parent bde06d466a
commit 2c8b8c3f9c
7 changed files with 68 additions and 144 deletions

View File

@ -21,10 +21,10 @@ namespace osu.Desktop.VisualTests.Tests
private const int start_time = 0; private const int start_time = 0;
private const int duration = 1000; private const int duration = 1000;
private Container container;
public TestCaseContextMenu() public TestCaseContextMenu()
{ {
MyContextMenuContainer container;
Add(container = new MyContextMenuContainer Add(container = new MyContextMenuContainer
{ {
Size = new Vector2(200), Size = new Vector2(200),
@ -54,43 +54,26 @@ namespace osu.Desktop.VisualTests.Tests
} }
} }
}); });
}
container.Transforms.Add(new TransformPosition protected override void LoadComplete()
{
base.LoadComplete();
using (container.BeginLoopedSequece())
{ {
StartValue = Vector2.Zero, container.MoveTo(new Vector2(0, 100), duration);
EndValue = new Vector2(0, 100), using (container.BeginDelayedSequence(duration))
StartTime = start_time, {
EndTime = start_time + duration, container.MoveTo(new Vector2(100, 100), duration);
LoopCount = -1, using (container.BeginDelayedSequence(duration))
LoopDelay = duration * 3 {
}); container.MoveTo(new Vector2(100, 0), duration);
container.Transforms.Add(new TransformPosition using (container.BeginDelayedSequence(duration))
{ container.MoveTo(Vector2.Zero, duration);
StartValue = new Vector2(0, 100), }
EndValue = new Vector2(100, 100), }
StartTime = start_time + duration, }
EndTime = start_time + duration * 2,
LoopCount = -1,
LoopDelay = duration * 3
});
container.Transforms.Add(new TransformPosition
{
StartValue = new Vector2(100, 100),
EndValue = new Vector2(100, 0),
StartTime = start_time + duration * 2,
EndTime = start_time + duration * 3,
LoopCount = -1,
LoopDelay = duration * 3
});
container.Transforms.Add(new TransformPosition
{
StartValue = new Vector2(100, 0),
EndValue = Vector2.Zero,
StartTime = start_time + duration * 3,
EndTime = start_time + duration * 4,
LoopCount = -1,
LoopDelay = duration * 3
});
} }
private class MyContextMenuContainer : Container, IHasContextMenu private class MyContextMenuContainer : Container, IHasContextMenu

View File

@ -34,7 +34,7 @@ namespace osu.Desktop.VisualTests.Tests
AddStep(@"simple #2", sendNotification2); AddStep(@"simple #2", sendNotification2);
AddStep(@"progress #1", sendProgress1); AddStep(@"progress #1", sendProgress1);
AddStep(@"progress #2", sendProgress2); AddStep(@"progress #2", sendProgress2);
AddStep(@"barrage", () => sendBarrage()); //AddStep(@"barrage", () => sendBarrage());
} }
private void sendBarrage(int remaining = 100) private void sendBarrage(int remaining = 100)

View File

@ -37,8 +37,8 @@ namespace osu.Game.Rulesets.Osu.Objects.Drawables.Pieces
protected override void LoadComplete() protected override void LoadComplete()
{ {
base.LoadComplete(); base.LoadComplete();
icon.RotateTo(360, 1000); using (icon.BeginLoopedSequece())
icon.Loop(); icon.RotateTo(360, 1000);
} }
public void UpdateProgress(double progress, int repeat) public void UpdateProgress(double progress, int repeat)

View File

@ -23,6 +23,11 @@ namespace osu.Game.Graphics.Containers
/// </summary> /// </summary>
protected double EarlyActivationMilliseconds; protected double EarlyActivationMilliseconds;
/// <summary>
/// The time in milliseconds until the next beat.
/// </summary>
public double TimeUntilNextBeat { get; private set; }
protected override void Update() protected override void Update()
{ {
if (Beatmap.Value?.Track == null) if (Beatmap.Value?.Track == null)
@ -42,12 +47,12 @@ namespace osu.Game.Graphics.Containers
if (currentTrackTime < timingPoint.Time) if (currentTrackTime < timingPoint.Time)
beatIndex--; beatIndex--;
TimeUntilNextBeat = (timingPoint.Time - currentTrackTime) % timingPoint.BeatLength;
if (timingPoint == lastTimingPoint && beatIndex == lastBeat) if (timingPoint == lastTimingPoint && beatIndex == lastBeat)
return; return;
double offsetFromBeat = (timingPoint.Time - currentTrackTime) % timingPoint.BeatLength; using (BeginDelayedSequence(TimeUntilNextBeat, true))
using (BeginDelayedSequence(offsetFromBeat, true))
OnNewBeat(beatIndex, timingPoint, effectPoint, Beatmap.Value.Track.CurrentAmplitudes); OnNewBeat(beatIndex, timingPoint, effectPoint, Beatmap.Value.Track.CurrentAmplitudes);
lastBeat = beatIndex; lastBeat = beatIndex;

View File

@ -34,9 +34,8 @@ namespace osu.Game.Graphics.UserInterface
{ {
base.LoadComplete(); base.LoadComplete();
spinner.RotateTo(360, 2000); using (spinner.BeginLoopedSequece())
using (spinner.BeginDelayedSequence(2000)) spinner.RotateTo(360, 2000);
spinner.Loop();
} }
private const float transition_duration = 500; private const float transition_duration = 500;

View File

@ -203,6 +203,8 @@ namespace osu.Game.Overlays.Notifications
get { return pulsate; } get { return pulsate; }
set set
{ {
if (pulsate == value) return;
pulsate = value; pulsate = value;
pulsateLayer.ClearTransforms(); pulsateLayer.ClearTransforms();
@ -211,25 +213,12 @@ namespace osu.Game.Overlays.Notifications
if (pulsate) if (pulsate)
{ {
const float length = 1000; const float length = 1000;
pulsateLayer.Transforms.Add(new TransformAlpha using (pulsateLayer.BeginLoopedSequece(length / 2))
{ {
StartTime = Time.Current, pulsateLayer.FadeTo(0.4f, length, EasingTypes.In);
EndTime = Time.Current + length, using (pulsateLayer.BeginDelayedSequence(length))
StartValue = 1, pulsateLayer.FadeTo(1, length, EasingTypes.Out);
EndValue = 0.4f, }
Easing = EasingTypes.In
});
pulsateLayer.Transforms.Add(new TransformAlpha
{
StartTime = Time.Current + length,
EndTime = Time.Current + length * 2,
StartValue = 0.4f,
EndValue = 1,
Easing = EasingTypes.Out
});
//todo: figure why we can't add arbitrary delays at the end of loop.
pulsateLayer.Loop(length * 2);
} }
} }
} }

View File

@ -9,7 +9,6 @@ using osu.Framework.Audio.Sample;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes; using osu.Framework.Graphics.Shapes;
using osu.Framework.Graphics.Transforms;
using osu.Framework.Input; using osu.Framework.Input;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Game.Graphics.Sprites; using osu.Game.Graphics.Sprites;
@ -17,6 +16,9 @@ using OpenTK;
using OpenTK.Graphics; using OpenTK.Graphics;
using OpenTK.Input; using OpenTK.Input;
using osu.Framework.Extensions.Color4Extensions; using osu.Framework.Extensions.Color4Extensions;
using osu.Game.Graphics.Containers;
using osu.Framework.Audio.Track;
using osu.Game.Beatmaps.ControlPoints;
namespace osu.Game.Screens.Menu namespace osu.Game.Screens.Menu
{ {
@ -24,7 +26,7 @@ namespace osu.Game.Screens.Menu
/// Button designed specifically for the osu!next main menu. /// Button designed specifically for the osu!next main menu.
/// In order to correctly flow, we have to use a negative margin on the parent container (due to the parallelogram shape). /// In order to correctly flow, we have to use a negative margin on the parent container (due to the parallelogram shape).
/// </summary> /// </summary>
public class Button : Container, IStateful<ButtonState> public class Button : BeatSyncedContainer, IStateful<ButtonState>
{ {
private readonly Container iconText; private readonly Container iconText;
private readonly Container box; private readonly Container box;
@ -117,6 +119,27 @@ namespace osu.Game.Screens.Menu
}; };
} }
protected override void OnNewBeat(int beatIndex, TimingControlPoint timingPoint, EffectControlPoint effectPoint, TrackAmplitudes amplitudes)
{
base.OnNewBeat(beatIndex, timingPoint, effectPoint, amplitudes);
if (!IsHovered) return;
bool rightward = beatIndex % 2 == 1;
double duration = timingPoint.BeatLength / 2;
icon.RotateTo(rightward ? 10 : -10, duration * 2, EasingTypes.InOutSine);
icon.MoveToY(-10, duration, EasingTypes.Out);
icon.ScaleTo(Vector2.One, duration, EasingTypes.Out);
using (icon.BeginDelayedSequence(duration))
{
icon.MoveToY(0, duration, EasingTypes.In);
icon.ScaleTo(new Vector2(1, 0.9f), duration, EasingTypes.In);
}
}
protected override bool OnHover(InputState state) protected override bool OnHover(InputState state)
{ {
if (State != ButtonState.Expanded) return true; if (State != ButtonState.Expanded) return true;
@ -125,85 +148,11 @@ namespace osu.Game.Screens.Menu
box.ScaleTo(new Vector2(1.5f, 1), 500, EasingTypes.OutElastic); box.ScaleTo(new Vector2(1.5f, 1), 500, EasingTypes.OutElastic);
int duration = 0; //(int)(Game.Audio.BeatLength / 2); double duration = TimeUntilNextBeat;
if (duration == 0) duration = 250;
icon.ClearTransforms(); icon.ClearTransforms();
icon.RotateTo(10, duration, EasingTypes.InOutSine);
icon.ScaleTo(1, 500, EasingTypes.OutElasticHalf); icon.ScaleTo(new Vector2(1, 0.9f), duration, EasingTypes.Out);
const double offset = 0; //(1 - Game.Audio.SyncBeatProgress) * duration;
double startTime = Time.Current + offset;
icon.RotateTo(10, offset, EasingTypes.InOutSine);
icon.ScaleTo(new Vector2(1, 0.9f), offset, EasingTypes.Out);
icon.Transforms.Add(new TransformRotation
{
StartValue = -10,
EndValue = 10,
StartTime = startTime,
EndTime = startTime + duration * 2,
Easing = EasingTypes.InOutSine,
LoopCount = -1,
LoopDelay = duration * 2
});
icon.Transforms.Add(new TransformPosition
{
StartValue = Vector2.Zero,
EndValue = new Vector2(0, -10),
StartTime = startTime,
EndTime = startTime + duration,
Easing = EasingTypes.Out,
LoopCount = -1,
LoopDelay = duration
});
icon.Transforms.Add(new TransformScale
{
StartValue = new Vector2(1, 0.9f),
EndValue = Vector2.One,
StartTime = startTime,
EndTime = startTime + duration,
Easing = EasingTypes.Out,
LoopCount = -1,
LoopDelay = duration
});
icon.Transforms.Add(new TransformPosition
{
StartValue = new Vector2(0, -10),
EndValue = Vector2.Zero,
StartTime = startTime + duration,
EndTime = startTime + duration * 2,
Easing = EasingTypes.In,
LoopCount = -1,
LoopDelay = duration
});
icon.Transforms.Add(new TransformScale
{
StartValue = Vector2.One,
EndValue = new Vector2(1, 0.9f),
StartTime = startTime + duration,
EndTime = startTime + duration * 2,
Easing = EasingTypes.In,
LoopCount = -1,
LoopDelay = duration
});
icon.Transforms.Add(new TransformRotation
{
StartValue = 10,
EndValue = -10,
StartTime = startTime + duration * 2,
EndTime = startTime + duration * 4,
Easing = EasingTypes.InOutSine,
LoopCount = -1,
LoopDelay = duration * 2
});
return true; return true;
} }
@ -212,7 +161,6 @@ namespace osu.Game.Screens.Menu
icon.ClearTransforms(); icon.ClearTransforms();
icon.RotateTo(0, 500, EasingTypes.Out); icon.RotateTo(0, 500, EasingTypes.Out);
icon.MoveTo(Vector2.Zero, 500, EasingTypes.Out); icon.MoveTo(Vector2.Zero, 500, EasingTypes.Out);
icon.ScaleTo(0.7f, 500, EasingTypes.OutElasticHalf);
icon.ScaleTo(Vector2.One, 200, EasingTypes.Out); icon.ScaleTo(Vector2.One, 200, EasingTypes.Out);
if (State == ButtonState.Expanded) if (State == ButtonState.Expanded)