1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-27 20:22:56 +08:00
osu-lazer/osu.Game.Rulesets.Osu/Mods/OsuModSpinIn.cs

93 lines
3.4 KiB
C#
Raw Normal View History

// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2018-09-19 11:15:36 +08:00
2018-09-21 07:06:37 +08:00
using System;
2018-09-19 11:15:36 +08:00
using System.Collections.Generic;
2018-09-20 11:56:25 +08:00
using System.Linq;
using osu.Framework.Bindables;
2018-09-19 11:15:36 +08:00
using osu.Framework.Graphics;
using osu.Framework.Graphics.Sprites;
using osu.Game.Configuration;
2018-09-19 11:15:36 +08:00
using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.Objects.Drawables;
using osu.Game.Rulesets.Osu.Objects;
using osu.Game.Rulesets.Osu.Objects.Drawables;
using osuTK;
2018-09-19 11:15:36 +08:00
namespace osu.Game.Rulesets.Osu.Mods
{
public class OsuModSpinIn : Mod, IApplicableToDrawableHitObjects, IReadFromConfig
2018-09-19 11:15:36 +08:00
{
2018-09-21 07:06:37 +08:00
public override string Name => "Spin In";
public override string Acronym => "SI";
public override IconUsage Icon => FontAwesome.Solid.Undo;
2018-09-19 11:15:36 +08:00
public override ModType Type => ModType.Fun;
public override string Description => "Circles spin in. No approach circles.";
2018-09-19 11:15:36 +08:00
public override double ScoreMultiplier => 1;
// todo: this mod should be able to be compatible with hidden with a bit of further implementation.
public override Type[] IncompatibleMods => new[] { typeof(OsuModeObjectScaleTween), typeof(OsuModHidden), typeof(OsuModTraceable) };
2018-09-21 07:06:37 +08:00
private const int rotate_offset = 360;
private const float rotate_starting_width = 2;
2018-09-21 07:06:37 +08:00
private Bindable<bool> increaseFirstObjectVisibility = new Bindable<bool>();
public void ReadFromConfig(OsuConfigManager config)
{
increaseFirstObjectVisibility = config.GetBindable<bool>(OsuSetting.IncreaseFirstObjectVisibility);
}
2018-09-19 11:15:36 +08:00
public void ApplyToDrawableHitObjects(IEnumerable<DrawableHitObject> drawables)
{
foreach (var drawable in drawables.Skip(increaseFirstObjectVisibility.Value ? 1 : 0))
2018-09-19 11:15:36 +08:00
{
switch (drawable)
{
case DrawableSpinner _:
continue;
default:
drawable.ApplyCustomUpdateState += applyZoomState;
break;
}
2018-09-19 11:15:36 +08:00
}
}
private void applyZoomState(DrawableHitObject drawable, ArmedState state)
2018-09-19 11:15:36 +08:00
{
var h = (OsuHitObject)drawable.HitObject;
2018-09-20 11:56:25 +08:00
switch (drawable)
2018-09-19 11:15:36 +08:00
{
2018-09-20 11:56:25 +08:00
case DrawableHitCircle circle:
using (circle.BeginAbsoluteSequence(h.StartTime - h.TimePreempt, true))
2018-09-20 11:56:25 +08:00
{
circle.ApproachCircle.Hide();
2018-09-19 11:15:36 +08:00
circle.RotateTo(rotate_offset).Then().RotateTo(0, h.TimePreempt, Easing.InOutSine);
circle.ScaleTo(new Vector2(rotate_starting_width, 0)).Then().ScaleTo(1, h.TimePreempt, Easing.InOutSine);
2018-09-20 11:56:25 +08:00
// bypass fade in.
if (state == ArmedState.Idle)
circle.FadeIn();
}
2018-09-20 11:56:25 +08:00
break;
2018-09-19 11:15:36 +08:00
2018-09-20 11:56:25 +08:00
case DrawableSlider slider:
using (slider.BeginAbsoluteSequence(h.StartTime - h.TimePreempt))
2018-09-20 11:56:25 +08:00
{
slider.ScaleTo(0).Then().ScaleTo(1, h.TimePreempt, Easing.InOutSine);
2018-09-20 11:56:25 +08:00
// bypass fade in.
if (state == ArmedState.Idle)
slider.FadeIn();
2018-09-20 11:56:25 +08:00
}
break;
}
2018-09-19 11:15:36 +08:00
}
}
}