From c234196ff4f3ccc62e1f3eca25d9f6a15f163c47 Mon Sep 17 00:00:00 2001 From: DetectiveBaldi <86160807+CaptainBaldi@users.noreply.github.com> Date: Tue, 21 Nov 2023 10:25:55 -0500 Subject: [PATCH] Make `FlxMouse._cursor` public (#2969) * Update FlxMouse.hx * Make `_cursor` public * Some fixes * Update FlxMouse.hx * add deprecation warning --------- Co-authored-by: George Kurelic --- flixel/input/mouse/FlxMouse.hx | 58 ++++++++++++++++++++-------------- 1 file changed, 35 insertions(+), 23 deletions(-) diff --git a/flixel/input/mouse/FlxMouse.hx b/flixel/input/mouse/FlxMouse.hx index b06076c640..53c3ae090f 100644 --- a/flixel/input/mouse/FlxMouse.hx +++ b/flixel/input/mouse/FlxMouse.hx @@ -51,6 +51,11 @@ class FlxMouse extends FlxPointer implements IFlxInputManager * sits at the right "height". Not used on flash with the native cursor API. */ public var cursorContainer(default, null):Sprite; + + /** + * The current cursor bitmap, if there is one. To set, use the `load` function. + */ + public var cursor(default, null):Null; /** * Used to toggle the visiblity of the mouse cursor - works on both @@ -192,11 +197,8 @@ class FlxMouse extends FlxPointer implements IFlxInputManager var _rightButton:FlxMouseButton; #end - /** - * This is just a reference to the current cursor image, if there is one. - */ - var _cursor:Bitmap = null; - + @:deprecated("_cursor is deprecated, use the new, public cursor, instead") + var _cursor(get, set):Bitmap; var _cursorBitmapData:BitmapData; var _wheelUsed:Bool = false; var _visibleWhenFocusLost:Bool = true; @@ -244,9 +246,9 @@ class FlxMouse extends FlxPointer implements IFlxInputManager public function load(?Graphic:Dynamic, Scale:Float = 1, XOffset:Int = 0, YOffset:Int = 0):Void { #if !FLX_NATIVE_CURSOR - if (_cursor != null) + if (cursor != null) { - FlxDestroyUtil.removeChild(cursorContainer, _cursor); + FlxDestroyUtil.removeChild(cursorContainer, cursor); } #end @@ -257,25 +259,25 @@ class FlxMouse extends FlxPointer implements IFlxInputManager if ((Graphic is Class)) { - _cursor = Type.createInstance(Graphic, []); + cursor = Type.createInstance(Graphic, []); } else if ((Graphic is BitmapData)) { - _cursor = new Bitmap(cast Graphic); + cursor = new Bitmap(cast Graphic); } else if ((Graphic is String)) { - _cursor = new Bitmap(FlxAssets.getBitmapData(Graphic)); + cursor = new Bitmap(FlxAssets.getBitmapData(Graphic)); } else { - _cursor = new Bitmap(new GraphicCursor(0, 0)); + cursor = new Bitmap(new GraphicCursor(0, 0)); } - _cursor.x = XOffset; - _cursor.y = YOffset; - _cursor.scaleX = Scale; - _cursor.scaleY = Scale; + cursor.x = XOffset; + cursor.y = YOffset; + cursor.scaleX = Scale; + cursor.scaleY = Scale; #if FLX_NATIVE_CURSOR if (XOffset < 0 || YOffset < 0) @@ -288,8 +290,8 @@ class FlxMouse extends FlxPointer implements IFlxInputManager throw "Negative scale isn't supported for native cursors."; } - var scaledWidth:Int = Std.int(Scale * _cursor.bitmapData.width); - var scaledHeight:Int = Std.int(Scale * _cursor.bitmapData.height); + var scaledWidth:Int = Std.int(Scale * cursor.bitmapData.width); + var scaledHeight:Int = Std.int(Scale * cursor.bitmapData.height); var bitmapWidth:Int = scaledWidth + XOffset; var bitmapHeight:Int = scaledHeight + YOffset; @@ -301,10 +303,10 @@ class FlxMouse extends FlxPointer implements IFlxInputManager _matrix.scale(Scale, Scale); _matrix.translate(XOffset, YOffset); } - cursorBitmap.draw(_cursor.bitmapData, _matrix); + cursorBitmap.draw(cursor.bitmapData, _matrix); setSimpleNativeCursorData(_cursorDefaultName, cursorBitmap); #else - cursorContainer.addChild(_cursor); + cursorContainer.addChild(cursor); #end } @@ -314,7 +316,7 @@ class FlxMouse extends FlxPointer implements IFlxInputManager */ public function unload():Void { - if (_cursor != null) + if (cursor != null) { if (cursorContainer.visible) { @@ -322,7 +324,7 @@ class FlxMouse extends FlxPointer implements IFlxInputManager } else { - _cursor = FlxDestroyUtil.removeChild(cursorContainer, _cursor); + cursor = FlxDestroyUtil.removeChild(cursorContainer, cursor); } } } @@ -419,7 +421,7 @@ class FlxMouse extends FlxPointer implements IFlxInputManager } cursorContainer = null; - _cursor = null; + cursor = null; #if FLX_NATIVE_CURSOR _matrix = null; @@ -693,7 +695,7 @@ class FlxMouse extends FlxPointer implements IFlxInputManager } else { - if (_cursor == null) + if (cursor == null) load(); #if FLX_NATIVE_CURSOR @@ -756,5 +758,15 @@ class FlxMouse extends FlxPointer implements IFlxInputManager _globalScreenY = record.y; updatePositions(); } + + inline function get__cursor() + { + return cursor; + } + + inline function set__cursor(value:Bitmap) + { + return cursor = value; + } } #end