LayaBox腳本(TS):按鈕長按

/**
 * 長按腳本
 */
export default class UILongPress extends Laya.Script {
    /** @prop {name:longpressTime, tips:"長按時間", type:number, default:500}*/ 
    public  longpressTime: number = 500;
    /** @prop {name:isOnceFlag, tips:"是否只觸發(fā)一次長按", type:Boolean, default:true}*/
    public  isOnceFlag:Boolean = true;//是否只觸發(fā)一次長按
    public  isMouseDown:Boolean = false;//是否鼠標按下
    public  lastMouseDownTime:number = 0;//上次鼠標按下時間
    public  ownerSprite:Laya.UIComponent;

    public static  stop:Boolean = false;

    private  mLongPressHandler:Laya.Handler;
    private  mClickHandler:Laya.Handler;    
    private  mLongPressTriggleTime:number = 100;//長按時間統(tǒng)計變量,初始值給跟間隔一樣,這樣只要長按后就會立馬觸發(fā)一次
    private  mLongPressIntervalTime:number = 100;//判定長按后 每100ms觸發(fā)一次clickhander
    private  mTarget:any;

    public  get clickHandler():Laya.Handler{
        return this.mClickHandler;
    }
    public  set clickHandler(value:Laya.Handler){
        this.mClickHandler = value;
    }
    public  get longPressHandler():Laya.Handler{
        return this.mLongPressHandler;
    }
    public  set longPressHandler(value:Laya.Handler){
        this.mLongPressHandler = value;
    }

    onEnable():void {
        this.ownerSprite = this.owner as Laya.UIComponent;
        this.ownerSprite.on(Laya.Event.MOUSE_DOWN,this,this.onMouseDown);
    }
    
    onDisable():void {
        this.mClickHandler = this.longPressHandler = null
    }

    onMouseDown(e:Laya.Event):void{
        UILongPress.stop = false;
        this.mTarget = e;
        this.isMouseDown = true
        this.lastMouseDownTime = Laya.Browser.now()
        this.ownerSprite.on(Laya.Event.MOUSE_UP,this,this.onMouseUp)
        this.ownerSprite.on(Laya.Event.MOUSE_OUT,this,this.onMouseOut)
    }

    onMouseUp(e:Laya.Event):void{
        this.isMouseDown = false
        this.mClickHandler && this.mClickHandler.runWith(e)
        this.mTarget = null;
    }

    onMouseOut(e:Laya.Event):void{
        this.isMouseDown = false
        this.ownerSprite.off(Laya.Event.MOUSE_UP,this,this.onMouseUp)
        this.ownerSprite.off(Laya.Event.MOUSE_OUT,this,this.onMouseOut)
        this.mTarget = null
    }

    onUpdate():void{
        if(UILongPress.stop && this.mTarget){
            UILongPress.stop = false
            this.onMouseOut(this.mTarget);
            return;
        }
        if(this.isMouseDown && Laya.Browser.now()-this.lastMouseDownTime>this.longpressTime){
            if(this.mLongPressTriggleTime>=this.mLongPressIntervalTime){
                if(this.isOnceFlag){
                    this.cancelLongPress();
                }
                this.mLongPressHandler && this.mLongPressHandler.run();
                
                this.mLongPressTriggleTime=0;
            }else{
                this.mLongPressTriggleTime += Laya.timer.delta;
            }
        }
    }
    
    //常用腳本組件盡量重寫reset方法 可以在destroy后自動回收到對象池
    onReset():void{
        this.lastMouseDownTime=0;
        this.isMouseDown=false;
        this.longpressTime=500;
        if(this.mLongPressHandler){
            this.mLongPressHandler.recover();
            this.mLongPressHandler=null;
        }
        if(this.mClickHandler){
            this.mClickHandler.recover();
            this.mClickHandler=null;
        }
    }
    
    //當條件不滿足時,要取消長按事件
    cancelLongPress():void{
        this.isMouseDown = false
        this.ownerSprite.off(Laya.Event.MOUSE_UP,this,this.onMouseUp)
        this.ownerSprite.off(Laya.Event.MOUSE_OUT,this,this.onMouseOut)
    }
    
}

調(diào)用

const longpress:UILongPress = this.mBtnLongpress.getComponent(UILongPress);
longpress.isOnceFlag = false;
longpress.longPressHandler = Laya.Handler.create(this, this.OnBtnLongpress, null, false);
longpress.clickHandler = Laya.Handler.create(this, this.OnBtnLongpress, null, false);

private OnBtnLongpress():void{
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容