1
0
mirror of https://github.com/ppy/osu.git synced 2024-09-22 10:47:25 +08:00
osu-lazer/osu.Game/Graphics/Cursor/MenuCursor.cs

137 lines
4.8 KiB
C#
Raw Normal View History

2017-03-16 21:41:07 +08:00
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using OpenTK;
using osu.Framework.Allocation;
using osu.Framework.Configuration;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Cursor;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Input;
using osu.Game.Configuration;
using System;
using osu.Framework.Graphics.Textures;
namespace osu.Game.Graphics.Cursor
{
public class MenuCursor : CursorContainer
{
protected override Drawable CreateCursor() => new Cursor();
private bool dragging;
2017-04-03 00:19:59 +08:00
2017-03-18 19:47:49 +08:00
protected override bool OnMouseMove(InputState state)
{
if (dragging)
2017-03-18 19:47:49 +08:00
{
2017-03-18 21:23:53 +08:00
Vector2 offset = state.Mouse.Position - state.Mouse.PositionMouseDown ?? state.Mouse.Delta;
2017-03-18 19:47:49 +08:00
float degrees = (float)MathHelper.RadiansToDegrees(Math.Atan2(-offset.X, offset.Y)) + 24.3f;
// Always rotate in the direction of least distance
float diff = (degrees - ActiveCursor.Rotation) % 360;
if (diff < -180) diff += 360;
if (diff > 180) diff -= 360;
degrees = ActiveCursor.Rotation + diff;
ActiveCursor.RotateTo(degrees, 600, EasingTypes.OutQuint);
}
return base.OnMouseMove(state);
2017-04-03 00:19:59 +08:00
}
protected override bool OnDragStart(InputState state)
{
dragging = true;
return base.OnDragStart(state);
}
2017-03-16 21:41:07 +08:00
protected override bool OnMouseDown(InputState state, MouseDownEventArgs args)
{
ActiveCursor.Scale = new Vector2(1);
ActiveCursor.ScaleTo(0.90f, 800, EasingTypes.OutQuint);
((Cursor)ActiveCursor).AdditiveLayer.Alpha = 0;
((Cursor)ActiveCursor).AdditiveLayer.FadeInFromZero(800, EasingTypes.OutQuint);
return base.OnMouseDown(state, args);
}
protected override bool OnMouseUp(InputState state, MouseUpEventArgs args)
{
if (!state.Mouse.HasMainButtonPressed)
{
dragging = false;
2017-03-16 21:41:07 +08:00
((Cursor)ActiveCursor).AdditiveLayer.FadeOut(500, EasingTypes.OutQuint);
2017-03-18 21:37:50 +08:00
ActiveCursor.RotateTo(0, 600 * (1 + Math.Abs(ActiveCursor.Rotation / 720)), EasingTypes.OutElasticHalf);
2017-03-16 21:41:07 +08:00
ActiveCursor.ScaleTo(1, 500, EasingTypes.OutElastic);
}
return base.OnMouseUp(state, args);
}
protected override bool OnClick(InputState state)
{
((Cursor)ActiveCursor).AdditiveLayer.FadeOutFromOne(500, EasingTypes.OutQuint);
return base.OnClick(state);
}
2017-03-16 22:58:36 +08:00
protected override void PopIn()
{
ActiveCursor.FadeTo(1, 250, EasingTypes.OutQuint);
ActiveCursor.ScaleTo(1, 400, EasingTypes.OutQuint);
2017-03-16 22:58:36 +08:00
}
protected override void PopOut()
{
ActiveCursor.FadeTo(0, 900, EasingTypes.OutQuint);
2017-03-16 22:58:36 +08:00
ActiveCursor.ScaleTo(0, 500, EasingTypes.In);
}
2017-03-16 21:41:07 +08:00
public class Cursor : Container
{
private Container cursorContainer;
private Bindable<double> cursorScale;
private const float base_scale = 0.15f;
2017-03-16 21:41:07 +08:00
public Sprite AdditiveLayer;
public Cursor()
{
2017-04-20 06:42:40 +08:00
AutoSizeAxes = Axes.Both;
2017-03-16 21:41:07 +08:00
}
[BackgroundDependencyLoader]
2017-03-17 20:04:46 +08:00
private void load(OsuConfigManager config, TextureStore textures, OsuColour colour)
2017-03-16 21:41:07 +08:00
{
Children = new Drawable[]
{
cursorContainer = new Container
{
AutoSizeAxes = Axes.Both,
2017-03-16 21:41:07 +08:00
Children = new Drawable[]
{
new Sprite
{
Texture = textures.Get(@"Cursor/menu-cursor"),
},
AdditiveLayer = new Sprite
{
BlendingMode = BlendingMode.Additive,
2017-03-17 20:04:46 +08:00
Colour = colour.Pink,
2017-03-16 21:41:07 +08:00
Alpha = 0,
2017-03-17 20:04:46 +08:00
Texture = textures.Get(@"Cursor/menu-cursor-additive"),
2017-03-16 21:41:07 +08:00
},
}
2017-04-17 23:10:55 +08:00
}
2017-03-16 21:41:07 +08:00
};
2017-05-15 09:56:27 +08:00
cursorScale = config.GetBindable<double>(OsuSetting.MenuCursorSize);
cursorScale.ValueChanged += newScale => cursorContainer.Scale = new Vector2((float)newScale * base_scale);
cursorScale.TriggerChange();
2017-03-16 21:41:07 +08:00
}
}
}
}