| Package | flash.ui | 
| Class | public final class Mouse | 
| Inheritance | Mouse  Object | 
| Language Version: | ActionScript 3.0 | 
| Runtime Versions: | AIR 1.0, Flash Player 9 | 
More examples
Learn more
Related API Elements
| Property | Defined By | ||
|---|---|---|---|
|  | constructor : Object 
	 A reference to the class object or constructor function for a given object instance. | Object | |
| cursor : String [static]  
	The name of the native cursor. | Mouse | ||
| supportsCursor : Boolean [static] [read-only] 
	 Indicates whether the computer or device displays a persistent cursor. | Mouse | ||
| supportsNativeCursor : Boolean [static] [read-only]  
	Indicates whether the current configuration supports native cursors. | Mouse | ||
| Method | Defined By | ||
|---|---|---|---|
|  | 
	 Indicates whether an object has a specified property defined. | Object | |
| [static] 
  	 Hides the pointer. | Mouse | ||
|  | 
	 Indicates whether an instance of the Object class is in the prototype chain of the object specified 
	 as the parameter. | Object | |
|  | 
	 Indicates whether the specified property exists and is enumerable. | Object | |
| [static]  
	Registers a native cursor under the given name, with the given data. | Mouse | ||
|  | 
     Sets the availability of a dynamic property for loop operations. | Object | |
| [static] 
  	 Displays the pointer. | Mouse | ||
|  | 
	 Returns the string representation of this object, formatted according to locale-specific conventions. | Object | |
|  | 
	 Returns the string representation of the specified object. | Object | |
| [static]  
	Unregisters the native cursor with the given name. | Mouse | ||
|  | 
	 Returns the primitive value of the specified object. | Object | |
| cursor | property | 
| supportsCursor | property | 
supportsCursor:Boolean  [read-only] | Language Version: | ActionScript 3.0 | 
| Runtime Versions: | Flash Player 10.1, AIR 2 | 
Indicates whether the computer or device displays a persistent cursor.
The supportsCursor property is true on most desktop computers
	 and false on most mobile devices.
Note: Mouse events can be dispatched whether or not this property is true.
	 However, mouse events may behave differently depending on the physical characteristics of the pointing device.
Implementation
    public static function get supportsCursor():BooleanRelated API Elements
Example ( How to use this example )
import flash.events.*;
import flash.display.*;
import flash.ui.Mouse;
import flash.text.TextField;
var supportsCursorTxt:TextField = new TextField();
supportsCursorTxt.width = 200;
supportsCursorTxt.border = true;
addChild(supportsCursorTxt);
addEventListener (MouseEvent.CLICK, getScreenKeyboardType);
function getScreenKeyboardType(e:MouseEvent):void{
    supportsCursorTxt.text= "Supports Cursor is : " + String(flash.ui.Mouse.supportsCursor);
}
if(Mouse.supportsCursor) {
    //Game acts as before
} else {
    if(Capabilities.touchscreenType == TouchscreenType.STYLUS ){
        //The Game has to change so that the character is chasing the location of the stylus as 
        //it's dragged around. Some of the animations will have to change
    }else if(Capabilities.touchscreenType = TouchscreenType.FINGER){
        //Same as above, except that the hit-area is larger for a finger.
    }else{
        //There's no pointing device at all. The developer designs some sort of custom cursor to 
        //be controlled with key presses or similar input
    }
}
| supportsNativeCursor | property | 
| hide | () | method | 
 public static function hide():void| Language Version: | ActionScript 3.0 | 
| Runtime Versions: | AIR 1.0, Flash Player 9 | 
Hides the pointer. The pointer is visible by default.
Note: You need to call Mouse.hide() only once, regardless of
	 the number of previous calls to Mouse.show().
Related API Elements
| registerCursor | () | method | 
 public static function registerCursor(name:String, cursor:MouseCursorData):void| Language Version: | ActionScript 3.0 | 
| Runtime Versions: | Flash Player 10.2, AIR 1.5 | 
Registers a native cursor under the given name, with the given data.
Parameters
| name:String | |
| cursor:MouseCursorData | 
| show | () | method | 
 public static function show():void| Language Version: | ActionScript 3.0 | 
| Runtime Versions: | AIR 1.0, Flash Player 9 | 
Displays the pointer. The pointer is visible by default.
Note: You need to call Mouse.show() only once, regardless of
	 the number of previous calls to Mouse.hide().
Related API Elements
| unregisterCursor | () | method | 
- Declare the following instance properties: cursorof type CustomCursor,childof type CustomButton, andgutterof type uint.
- Assign childto a new CustomButton instance, set its x and y coordinates to 10 pixels each, and then add the instance to the display list. The CustomButton class overrides thedownState,upState,overState, andhitTestStateproperties in SimpleButton. Each of these properties instantiates a ButtonDisplayState object, which draws a different square, depending on the state of thechildinstance.
- The childinstance is then used to add aMOUSE_OVERevent listener andmouseOverHandler()listener method, along with aMOUSE_OUTevent listener and associatedmouseOutHandler()method.
- The event listeners work as follows:
  - mouseOverHandler: Hides the "normal" pointer and adds a- MOUSE_MOVElistener, which processes the mouse moves using- mouseMoveHandler(), described below.
- mouseOutHandler: When the mouse moves outside the custom button, the "normal" pointer is shown, the- MOUSE_MOVEevent listener is removed, and the custom cursor's visibility is set to- false.
- mouseMoveHandler: Moves the custom cursor around wherever the pointer is moved and sets the custom cursor's visibility to- true.
 
- Back in the MouseExampleconstructor, the cursor property is assigned to a new CustomCursor object and then added to the display list usingaddChild(). The CustomCursor class draws a small nearly black square in place of the "normal" pointer whenever the mouse is overchild.
- A fourth event listener of type MOUSE_LEAVEis added, with the associatedmouseLeaveHandler()method. In this method (called if the mouse leaves the Stage),mouseOutHandler()is passed a newmouseMovelistener object, which essentially removes the pointer so it is not left on the Stage.
package {
    import flash.display.Sprite;
    import flash.display.DisplayObject;
    import flash.ui.Mouse;
    import flash.events.*;
    public class MouseExample extends Sprite {
         private var cursor:CustomCursor;
         private var child:CustomButton;
         private var gutter:uint = 10;
        public function MouseExample() {
            child = new CustomButton();
            child.x = gutter;
            child.y = gutter;
            addChild(child);
            child.addEventListener(MouseEvent.MOUSE_OVER, mouseOverHandler);
            child.addEventListener(MouseEvent.MOUSE_OUT, mouseOutHandler);
            cursor = new CustomCursor();
            addChild(cursor);
            stage.addEventListener(Event.MOUSE_LEAVE, mouseLeaveHandler);
        }
        private function mouseOverHandler(event:MouseEvent):void {
            trace("mouseOverHandler");
            Mouse.hide();
            child.addEventListener(MouseEvent.MOUSE_MOVE, mouseMoveHandler);
        }
        private function mouseOutHandler(event:MouseEvent):void {
            trace("mouseOutHandler");
            Mouse.show();
            child.removeEventListener(MouseEvent.MOUSE_MOVE, mouseMoveHandler);
            cursor.visible = false;
        }
        private function mouseMoveHandler(event:MouseEvent):void {
            trace("mouseMoveHandler");
            cursor.x = event.localX;
            cursor.y = event.localY;
            event.updateAfterEvent();
            cursor.visible = true;
        }
        private function mouseLeaveHandler(event:Event):void {
            trace("mouseLeaveHandler");
            mouseOutHandler(new MouseEvent(MouseEvent.MOUSE_MOVE));
        }
    }
}
import flash.display.Shape;
import flash.display.SimpleButton;
    
class CustomButton extends SimpleButton {
    var upColor:uint = 0xFFCC00;
    var overColor:uint = 0xCCFF00;
    var downColor:uint = 0x00CCFF;
    var size:uint = 80;
    
    public function CustomButton() {
        downState = new ButtonDisplayState(downColor, size+10);
        overState = new ButtonDisplayState(overColor, size);
        upState = new ButtonDisplayState(upColor, size);
        hitTestState = new ButtonDisplayState(upColor, size);
    }
}
class ButtonDisplayState extends Shape {
    var bgColor:uint;
    var size:uint;
    
    public function ButtonDisplayState(bgColor:uint, size:uint) {
        this.bgColor = bgColor;
        this.size = size;
        draw();
    }
    
    private function draw():void {
        graphics.clear();
        graphics.beginFill(bgColor);
        graphics.drawRect(0, 0, size, size);
        graphics.endFill();
    }
}
    
class CustomCursor extends Shape {
    var bgColor:uint = 0x333333;
    var size:uint = 10;
    
    public function CustomCursor() {
        visible = false;
        draw();
    }
    
    private function draw():void {
        graphics.clear();
        graphics.beginFill(bgColor);
        graphics.drawRect(0, 0, size, size);
        graphics.endFill();
    }
}
Thu Dec 6 2018, 01:12 PM -08:00
 Hide Inherited Public Properties
 Hide Inherited Public Properties Show Inherited Public Properties
 Show Inherited Public Properties