osu/osu.Game/Screens/Play/HUD/FailingLayer.cs

49 lines
1.5 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.
using System;
using osu.Framework.Allocation;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Shapes;
using osu.Game.Graphics;
namespace osu.Game.Screens.Play.HUD
{
/// <summary>
2020-03-18 20:16:54 +00:00
/// An overlay layer on top of the playfield which fades to red when the current player health falls below a certain threshold defined by <see cref="LowHealthThreshold"/>.
/// </summary>
2020-03-18 20:16:54 +00:00
public class FailingLayer : HealthDisplay
{
private const float max_alpha = 0.4f;
private readonly Box box;
/// <summary>
/// The threshold under which the current player life should be considered low and the layer should start fading in.
/// </summary>
2020-03-18 20:16:54 +00:00
protected double LowHealthThreshold { get; set; } = 0.20f;
2020-03-18 20:16:54 +00:00
public FailingLayer()
{
RelativeSizeAxes = Axes.Both;
Child = box = new Box
{
RelativeSizeAxes = Axes.Both,
Alpha = 0
};
}
[BackgroundDependencyLoader]
private void load(OsuColour color)
{
box.Colour = color.Red;
}
protected override void Update()
{
box.Alpha = (float)Math.Clamp(max_alpha * (1 - Current.Value / LowHealthThreshold), 0, max_alpha);
base.Update();
}
}
}