Egret与FairyGUI的小技巧记录(持续更新)

1.如何在egret中使用fairygui的像素点击测试?

        fairygui并没有针对egret实现pixelHitTest,原因不详。考虑到fairygui中的UIContainer是用hitarea来测试点击的,所以针对这一点做了一些处理:

//重写fairygui UIContainer hitTest 方法
UIContainer.prototype.$hitTest = function(stageX:number, stageY:number):DisplayObject {
    let ret:DisplayObject = egret.DisplayObjectContainer.prototype.$hitTest.apply(this, [stageX, stageY]);
    if (ret == this) {
    if (!this.touchEnabled || this._hitArea == null)
        return null;
    }
        return ret;
}

        有点暴力,舍弃了hitarea,会不会引发其他问题有待考证。

        然后我们还需要设置相应的Bitmap的pixelHitTest属性为true,这里举例是自己封装的Eloader中添加如下函数:

public set pixelHitTest(val:boolean) {
    let loader:GLoader = this.img
    if (loader.content instanceof Bitmap){
        loader.content.pixelHitTest = val;    }
}

        其中的img是fairyGUI的Gloader。

        搞定。

©️2020 CSDN 皮肤主题: 大白 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值