From 82ba27fa75b720a3ce8e0c34470d50e88a9c407c Mon Sep 17 00:00:00 2001 From: Cameron Taylor Date: Tue, 31 Dec 2024 18:48:40 -0800 Subject: [PATCH] fix: change `clickSound` and `hoverSound` in `FlxSlider` into a `FlxSound`s --- flixel/addons/ui/FlxSlider.hx | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/flixel/addons/ui/FlxSlider.hx b/flixel/addons/ui/FlxSlider.hx index c8b97410..97b59454 100644 --- a/flixel/addons/ui/FlxSlider.hx +++ b/flixel/addons/ui/FlxSlider.hx @@ -7,11 +7,13 @@ import flixel.group.*; import flixel.math.FlxMath; import flixel.math.FlxPoint; import flixel.math.FlxRect; +import flixel.sound.FlxSound; import flixel.text.FlxText; import flixel.util.FlxColor; import flixel.util.FlxDestroyUtil; import flixel.util.FlxSpriteUtil; + /** * A slider GUI element for float and integer manipulation. * @author Gama11 @@ -71,13 +73,15 @@ class FlxSlider extends #if (flixel < "5.7.0") FlxSpriteGroup #else FlxSpriteCon /** * Sound that's played whenever the slider is clicked. + * No sound is set by default, you must call one of the load methods from `FlxSound` to set it (e.g. `clickSound.loadEmbedded()`). */ - public var clickSound:String; + public var clickSound:FlxSound; /** * Sound that's played whenever the slider is hovered over. + * No sound is set by default, you must call one of the load methods from `FlxSound` to set it (e.g. `clickSound.loadEmbedded()`). */ - public var hoverSound:String; + public var hoverSound:FlxSound; /** * The alpha value the slider uses when it's hovered over. 1 to turn the effect off. @@ -213,6 +217,12 @@ class FlxSlider extends #if (flixel < "5.7.0") FlxSpriteGroup #else FlxSpriteCon _color = Color; _handleColor = HandleColor; + clickSound = new FlxSound(); + hoverSound = new FlxSound(); + + FlxG.sound.defaultSoundGroup.add(clickSound); + FlxG.sound.defaultSoundGroup.add(hoverSound); + // Create the slider createSlider(); } @@ -291,7 +301,7 @@ class FlxSlider extends #if (flixel < "5.7.0") FlxSpriteGroup #else FlxSpriteCon #if FLX_SOUND_SYSTEM if (hoverSound != null && !_justHovered) { - FlxG.sound.play(hoverSound); + hoverSound.play(); } #end @@ -305,7 +315,7 @@ class FlxSlider extends #if (flixel < "5.7.0") FlxSpriteGroup #else FlxSpriteCon #if FLX_SOUND_SYSTEM if (clickSound != null && !_justClicked) { - FlxG.sound.play(clickSound); + clickSound.play(); _justClicked = true; } #end @@ -438,6 +448,9 @@ class FlxSlider extends #if (flixel < "5.7.0") FlxSpriteGroup #else FlxSpriteCon _bounds = FlxDestroyUtil.put(_bounds); + clickSound = FlxDestroyUtil.destroy(clickSound); + hoverSound = FlxDestroyUtil.destroy(hoverSound); + super.destroy(); }