1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-12 01:07:25 +08:00
osu-lazer/osu.Game.Rulesets.Osu/Difficulty/Skills/Aim.cs

51 lines
2.0 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-04-13 17:19:50 +08:00
using System;
2018-05-15 16:36:29 +08:00
using osu.Game.Rulesets.Osu.Difficulty.Preprocessing;
2018-04-13 17:19:50 +08:00
2018-05-15 16:36:29 +08:00
namespace osu.Game.Rulesets.Osu.Difficulty.Skills
2018-04-13 17:19:50 +08:00
{
/// <summary>
/// Represents the skill required to correctly aim at every object in the map with a uniform CircleSize and normalized distances.
/// </summary>
public class Aim : Skill
{
2018-12-24 11:41:04 +08:00
private const double angle_bonus_begin = Math.PI / 3;
2018-12-22 08:31:30 +08:00
private const double timing_threshold = 107;
2018-12-22 08:56:33 +08:00
2018-04-13 17:19:50 +08:00
protected override double SkillMultiplier => 26.25;
protected override double StrainDecayBase => 0.15;
protected override double StrainValueOf(OsuDifficultyHitObject current)
2018-12-08 14:01:26 +08:00
{
2018-12-21 13:52:43 +08:00
double result = 0;
2018-12-08 14:01:26 +08:00
2018-12-24 11:41:04 +08:00
const double scale = 90;
2018-12-21 13:52:43 +08:00
if (Previous.Count > 0)
{
2018-12-22 08:31:30 +08:00
if (current.Angle != null && current.Angle.Value > angle_bonus_begin)
2018-12-21 21:52:27 +08:00
{
2018-12-24 11:41:04 +08:00
var angleBonus = Math.Sqrt(
Math.Max(Previous[0].JumpDistance - scale, 0)
* Math.Pow(Math.Sin(current.Angle.Value - angle_bonus_begin), 2)
* Math.Max(current.JumpDistance - scale, 0));
result = 1.5 * Math.Pow(Math.Max(0, angleBonus), 0.99) / Math.Max(timing_threshold, Previous[0].StrainTime);
2018-12-21 21:52:27 +08:00
}
2018-12-21 13:52:43 +08:00
}
2018-12-24 11:41:04 +08:00
return Math.Max(
result + (
Math.Pow(current.JumpDistance, 0.99)
+ Math.Pow(current.TravelDistance, 0.99)
+ Math.Sqrt(Math.Pow(current.TravelDistance, 0.99) * Math.Pow(current.JumpDistance, 0.99)))
/ Math.Max(current.StrainTime, timing_threshold),
(Math.Sqrt(Math.Pow(current.TravelDistance, 0.99) * Math.Pow(current.JumpDistance, 0.99))
+ Math.Pow(current.JumpDistance, 0.99)
+ Math.Pow(current.TravelDistance, 0.99))
/ current.StrainTime);
2018-12-08 14:01:26 +08:00
}
2018-04-13 17:19:50 +08:00
}
}