1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-18 00:23:22 +08:00
osu-lazer/osu.Game.Rulesets.Osu/Objects/Drawables/Pieces/SpinnerDisc.cs

139 lines
4.2 KiB
C#
Raw Normal View History

// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using System;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
2017-02-25 20:12:39 +08:00
using osu.Framework.Graphics.Transforms;
using osu.Framework.Input;
2017-02-15 22:24:08 +08:00
using osu.Game.Graphics;
using OpenTK;
using OpenTK.Graphics;
2017-04-18 15:05:58 +08:00
namespace osu.Game.Rulesets.Osu.Objects.Drawables.Pieces
{
2017-05-18 18:40:20 +08:00
public class SpinnerDisc : CircularContainer, IHasAccentColour
{
2017-05-18 18:40:20 +08:00
private readonly Spinner spinner;
2017-05-18 18:40:20 +08:00
public Color4 AccentColour
{
2017-05-18 18:40:20 +08:00
get { return background.AccentColour; }
set { background.AccentColour = value; }
}
2017-05-18 18:40:20 +08:00
private readonly SpinnerBackground background;
2017-02-15 22:24:08 +08:00
2017-05-18 20:38:19 +08:00
private const float idle_alpha = 0.2f;
private const float tracking_alpha = 0.4f;
2017-02-15 22:24:08 +08:00
2017-05-18 18:40:20 +08:00
public SpinnerDisc(Spinner s)
{
2017-05-18 18:40:20 +08:00
spinner = s;
AlwaysReceiveInput = true;
RelativeSizeAxes = Axes.Both;
Children = new Drawable[]
{
2017-05-18 18:40:20 +08:00
background = new SpinnerBackground { Alpha = idle_alpha },
};
}
2017-03-07 09:59:19 +08:00
private bool tracking;
public bool Tracking
{
get { return tracking; }
set
{
if (value == tracking) return;
tracking = value;
2017-05-18 18:40:20 +08:00
background.FadeTo(tracking ? tracking_alpha : idle_alpha, 100);
}
}
2017-03-07 09:59:19 +08:00
private bool complete;
2017-02-15 22:24:08 +08:00
public bool Complete
{
get { return complete; }
set
{
if (value == complete) return;
complete = value;
updateCompleteTick();
}
}
protected override bool OnMouseDown(InputState state, MouseDownEventArgs args)
{
2017-05-18 18:40:20 +08:00
Tracking |= state.Mouse.HasMainButtonPressed;
return base.OnMouseDown(state, args);
}
protected override bool OnMouseUp(InputState state, MouseUpEventArgs args)
{
2017-05-18 18:40:20 +08:00
Tracking &= state.Mouse.HasMainButtonPressed;
return base.OnMouseUp(state, args);
}
protected override bool OnMouseMove(InputState state)
{
Tracking |= state.Mouse.HasMainButtonPressed;
2017-05-18 18:40:20 +08:00
mousePosition = Parent.ToLocalSpace(state.Mouse.NativeState.Position);
return base.OnMouseMove(state);
}
private Vector2 mousePosition;
private float lastAngle;
private float currentRotation;
public float RotationAbsolute;
2017-02-15 22:24:08 +08:00
private int completeTick;
2017-02-22 17:08:31 +08:00
private bool updateCompleteTick() => completeTick != (completeTick = (int)(RotationAbsolute / 360));
2017-02-15 22:24:08 +08:00
2017-05-18 18:40:20 +08:00
private bool rotationTransferred;
protected override void Update()
{
base.Update();
var thisAngle = -(float)MathHelper.RadiansToDegrees(Math.Atan2(mousePosition.X - DrawSize.X / 2, mousePosition.Y - DrawSize.Y / 2));
2017-05-18 18:40:20 +08:00
bool validAndTracking = tracking && spinner.StartTime <= Time.Current && spinner.EndTime > Time.Current;
if (validAndTracking)
{
2017-05-18 18:40:20 +08:00
if (!rotationTransferred)
{
currentRotation = Rotation * 2;
rotationTransferred = true;
}
if (thisAngle - lastAngle > 180)
lastAngle += 360;
else if (lastAngle - thisAngle > 180)
lastAngle -= 360;
currentRotation += thisAngle - lastAngle;
RotationAbsolute += Math.Abs(thisAngle - lastAngle);
}
2017-05-18 18:40:20 +08:00
lastAngle = thisAngle;
2017-02-15 22:24:08 +08:00
if (Complete && updateCompleteTick())
{
2017-05-18 18:40:20 +08:00
background.Flush(flushType: typeof(TransformAlpha));
background.FadeTo(tracking_alpha + 0.2f, 60, EasingTypes.OutExpo);
2017-05-18 18:40:20 +08:00
background.Delay(60);
2017-05-18 20:38:19 +08:00
background.FadeTo(tracking_alpha, 250, EasingTypes.OutQuint);
2017-02-15 22:24:08 +08:00
}
2017-05-18 18:40:20 +08:00
RotateTo(currentRotation / 2, validAndTracking ? 500 : 1500, EasingTypes.OutExpo);
}
}
}