mirror of
https://github.com/ppy/osu.git
synced 2024-11-11 12:57:36 +08:00
Add toolbar toggle buttons for hit samples
This commit is contained in:
parent
346d14d40b
commit
b561429f92
@ -3,12 +3,14 @@
|
|||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using Humanizer;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Framework.Graphics.Sprites;
|
using osu.Framework.Graphics.Sprites;
|
||||||
using osu.Framework.Input;
|
using osu.Framework.Input;
|
||||||
|
using osu.Game.Audio;
|
||||||
using osu.Game.Graphics.UserInterface;
|
using osu.Game.Graphics.UserInterface;
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
using osu.Game.Rulesets.Edit.Tools;
|
using osu.Game.Rulesets.Edit.Tools;
|
||||||
@ -73,6 +75,34 @@ namespace osu.Game.Screens.Edit.Compose.Components
|
|||||||
if (currentPlacement.HitObject is IHasComboInformation c)
|
if (currentPlacement.HitObject is IHasComboInformation c)
|
||||||
c.NewCombo = combo.NewValue == TernaryState.True;
|
c.NewCombo = combo.NewValue == TernaryState.True;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// we own SelectionHandler so don't need to worry about making bindable copies (for simplicity)
|
||||||
|
foreach (var kvp in SelectionHandler.SelectionSampleStates)
|
||||||
|
{
|
||||||
|
kvp.Value.BindValueChanged(c => sampleChanged(kvp.Key, c.NewValue));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void sampleChanged(string sampleName, TernaryState state)
|
||||||
|
{
|
||||||
|
if (currentPlacement == null) return;
|
||||||
|
|
||||||
|
var samples = currentPlacement.HitObject.Samples;
|
||||||
|
|
||||||
|
var existingSample = samples.FirstOrDefault(s => s.Name == sampleName);
|
||||||
|
|
||||||
|
switch (state)
|
||||||
|
{
|
||||||
|
case TernaryState.False:
|
||||||
|
if (existingSample != null)
|
||||||
|
samples.Remove(existingSample);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TernaryState.True:
|
||||||
|
if (existingSample == null)
|
||||||
|
samples.Add(new HitSampleInfo { Name = sampleName });
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public readonly Bindable<TernaryState> NewCombo = new Bindable<TernaryState> { Description = "New Combo" };
|
public readonly Bindable<TernaryState> NewCombo = new Bindable<TernaryState> { Description = "New Combo" };
|
||||||
@ -89,6 +119,26 @@ namespace osu.Game.Screens.Edit.Compose.Components
|
|||||||
{
|
{
|
||||||
//TODO: this should only be enabled (visible?) for rulesets that provide combo-supporting HitObjects.
|
//TODO: this should only be enabled (visible?) for rulesets that provide combo-supporting HitObjects.
|
||||||
yield return new TernaryButton(NewCombo, "New combo", () => new SpriteIcon { Icon = FontAwesome.Regular.DotCircle });
|
yield return new TernaryButton(NewCombo, "New combo", () => new SpriteIcon { Icon = FontAwesome.Regular.DotCircle });
|
||||||
|
|
||||||
|
foreach (var kvp in SelectionHandler.SelectionSampleStates)
|
||||||
|
yield return new TernaryButton(kvp.Value, kvp.Key.Replace("hit", string.Empty).Titleize(), () => getIconForSample(kvp.Key));
|
||||||
|
}
|
||||||
|
|
||||||
|
private Drawable getIconForSample(string sampleName)
|
||||||
|
{
|
||||||
|
switch (sampleName)
|
||||||
|
{
|
||||||
|
case HitSampleInfo.HIT_CLAP:
|
||||||
|
return new SpriteIcon { Icon = FontAwesome.Solid.Hands };
|
||||||
|
|
||||||
|
case HitSampleInfo.HIT_WHISTLE:
|
||||||
|
return new SpriteIcon { Icon = FontAwesome.Solid.Bullhorn };
|
||||||
|
|
||||||
|
case HitSampleInfo.HIT_FINISH:
|
||||||
|
return new SpriteIcon { Icon = FontAwesome.Solid.DrumSteelpan };
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Placement
|
#region Placement
|
||||||
|
Loading…
Reference in New Issue
Block a user