mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 18:03:11 +08:00
Take in IBindable
s and tidy up multiplier handling
This commit is contained in:
parent
161890292f
commit
9907adc337
@ -12,19 +12,39 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class RateAdjustModHelper : IApplicableToTrack
|
public class RateAdjustModHelper : IApplicableToTrack
|
||||||
{
|
{
|
||||||
private readonly BindableNumber<double> speedChange;
|
public readonly IBindableNumber<double> SpeedChange;
|
||||||
|
|
||||||
private IAdjustableAudioComponent? track;
|
private IAdjustableAudioComponent? track;
|
||||||
|
|
||||||
private BindableBool? adjustPitch;
|
private BindableBool? adjustPitch;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The score multiplier for the current <see cref="SpeedChange"/>.
|
||||||
|
/// </summary>
|
||||||
|
public double ScoreMultiplier
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
// Round to the nearest multiple of 0.1.
|
||||||
|
double value = (int)(SpeedChange.Value * 10) / 10.0;
|
||||||
|
|
||||||
|
// Offset back to 0.
|
||||||
|
value -= 1;
|
||||||
|
|
||||||
|
if (SpeedChange.Value >= 1)
|
||||||
|
value /= 5;
|
||||||
|
|
||||||
|
return 1 + value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Construct a new <see cref="RateAdjustModHelper"/>.
|
/// Construct a new <see cref="RateAdjustModHelper"/>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="speedChange">The main speed adjust parameter which is exposed to the user.</param>
|
/// <param name="speedChange">The main speed adjust parameter which is exposed to the user.</param>
|
||||||
public RateAdjustModHelper(BindableNumber<double> speedChange)
|
public RateAdjustModHelper(IBindableNumber<double> speedChange)
|
||||||
{
|
{
|
||||||
this.speedChange = speedChange;
|
SpeedChange = speedChange;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -39,8 +59,8 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
// When switching between pitch adjust, we need to update adjustments to time-shift or frequency-scale.
|
// When switching between pitch adjust, we need to update adjustments to time-shift or frequency-scale.
|
||||||
adjustPitch.BindValueChanged(adjustPitchSetting =>
|
adjustPitch.BindValueChanged(adjustPitchSetting =>
|
||||||
{
|
{
|
||||||
track?.RemoveAdjustment(adjustmentForPitchSetting(adjustPitchSetting.OldValue), speedChange);
|
track?.RemoveAdjustment(adjustmentForPitchSetting(adjustPitchSetting.OldValue), SpeedChange);
|
||||||
track?.AddAdjustment(adjustmentForPitchSetting(adjustPitchSetting.NewValue), speedChange);
|
track?.AddAdjustment(adjustmentForPitchSetting(adjustPitchSetting.NewValue), SpeedChange);
|
||||||
|
|
||||||
AdjustableProperty adjustmentForPitchSetting(bool adjustPitchSettingValue)
|
AdjustableProperty adjustmentForPitchSetting(bool adjustPitchSettingValue)
|
||||||
=> adjustPitchSettingValue ? AdjustableProperty.Frequency : AdjustableProperty.Tempo;
|
=> adjustPitchSettingValue ? AdjustableProperty.Frequency : AdjustableProperty.Tempo;
|
||||||
@ -60,25 +80,5 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
this.track = track;
|
this.track = track;
|
||||||
adjustPitch.TriggerChange();
|
adjustPitch.TriggerChange();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The score multiplier for the current <see cref="speedChange"/>.
|
|
||||||
/// </summary>
|
|
||||||
public double ScoreMultiplier
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
// Round to the nearest multiple of 0.1.
|
|
||||||
double value = (int)(speedChange.Value * 10) / 10.0;
|
|
||||||
|
|
||||||
// Offset back to 0.
|
|
||||||
value -= 1;
|
|
||||||
|
|
||||||
if (speedChange.Value >= 1)
|
|
||||||
value /= 5;
|
|
||||||
|
|
||||||
return 1 + value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user