Egret之EUI及龙骨基础
admin
2023-02-17 16:00:08
0

本篇主要内容是 , EUI 及 龙骨。

我用EUI项目进行测试,看下效果:

Egret之EUI及龙骨基础

实际上这个robot是一直在跑的 。

步骤

首先 , 在项目的egretProperties.json中增加EUI和龙骨模块如下:

1,

Egret之EUI及龙骨基础

2,使用DOS命令 : egret build -e 加入这2个模块


其次 ,注册主题(default.thm.json),要使用exml文件必须要注册

1,在resource文件加下新建default.thm.json文件,如下

Egret之EUI及龙骨基础

2,在main.ts中注册此主题:

new eui.Theme("resource/default.thm.json", this.stage);//注册主题

Egret之EUI及龙骨基础

3,需要往default.thm.json中添加基本数据

{
  "skins": {},
  "autoGenerateExmlsList": true,
  "exmls": []
}

最后 ,弹出一个简单的EUI界面

1,在resource文件夹下新建一个eui_skins文件夹用来存放exml皮肤文件

2,在eui_skins中新建一个DragonE.exml文件。

Egret之EUI及龙骨基础

3,编辑DragonE.exml文件

①,切换至设计师

Egret之EUI及龙骨基础

②,对于组件/资源没有出来的情况

如下图:

Egret之EUI及龙骨基础

解决方案如下(重置引擎):

Egret之EUI及龙骨基础

编写ui代码 DragonE_View.ts如下:

module app {
 export class DragonE_View  extends eui.Component implements eui.UIComponent {
  private com_dragon : eui.Group;
  private img_dragon : eui.Image;
  private txt_name : eui.Label;
  public constructor() {
   super();
   this.skinName = "resource/eui_skins/DragonE.exml";
  }
  protected partAdded(partName : string , instance : any):void{
   super.partAdded(partName , instance);
  }
  protected childrenCreated():void{
   super.childrenCreated();
   this.txt_name.text = "Snow";
   this.img_dragon.source = RES.getRes("egret_icon_png");
  }
 }
}

在舞台上显示ui , 在main.ts

    /**
     * preload资源组加载完成
     * Preload resource group is loaded
     */
    private onResourceLoadComplete(event: RES.ResourceEvent) {
        if (event.groupName == "preload") {
            this.stage.removeChild(this.loadingView);
            RES.removeEventListener(RES.ResourceEvent.GROUP_COMPLETE, this.onResourceLoadComplete, this);
            RES.removeEventListener(RES.ResourceEvent.GROUP_LOAD_ERROR, this.onResourceLoadError, this);
            RES.removeEventListener(RES.ResourceEvent.GROUP_PROGRESS, this.onResourceProgress, this);
            RES.removeEventListener(RES.ResourceEvent.ITEM_LOAD_ERROR, this.onItemLoadError, this);
            //this.createGameScene();
            let dragon : app.DragonE_View = new app.DragonE_View();
            this.addChild(dragon);
        }
    }

结果如下:

Egret之EUI及龙骨基础

看看default.thm.json(软件自动添加的)

Egret之EUI及龙骨基础


龙骨:

1,在resource中建一个robot文件夹,用于存储龙骨的3个文件 :

Egret之EUI及龙骨基础

2,在default.res.json中配置动画资源

Egret之EUI及龙骨基础

3,新建DragonBoneTools.ts类以创建dragonBones.EgretFactory如下:

module tools {
 /**
  * 龙骨工具
  * @author Aonaufly
  */
 export class DragonBoneTools {
  private static _instance : DragonBoneTools;
  public static get Instance() : DragonBoneTools{
   if( DragonBoneTools._instance == null ) DragonBoneTools._instance = new DragonBoneTools();
   return DragonBoneTools._instance;
  }
  /**
   * 构建龙骨 新 不需要绑定时钟
   */
  public createEff2New(dataRes: string,texJson: string,texPng: string): dragonBones.EgretFactory {
   var dragonbonesData = RES.getRes(dataRes);
   var textureData = RES.getRes(texJson);
   var texture = RES.getRes(texPng);
   let dragonbonesFactory: dragonBones.EgretFactory = new dragonBones.EgretFactory();
   dragonbonesFactory.parseDragonBonesData(dragonbonesData);
   dragonbonesFactory.parseTextureAtlasData(textureData,texture);
   return dragonbonesFactory;
   
  }
 }
}

4,更改DragonE_View.ts 以播放龙骨动画:

///
module app {
 export class DragonE_View  extends eui.Component implements eui.UIComponent {
  private com_dragon : eui.Group;
  private img_dragon : eui.Image;
  private txt_name : eui.Label;
        private egretFactory : dragonBones.EgretFactory;
  public constructor() {
   super();
   this.skinName = "resource/eui_skins/DragonE.exml";
  }
  protected partAdded(partName : string , instance : any):void{
   super.partAdded(partName , instance);
  }
  protected childrenCreated():void{
   super.childrenCreated();
   this.txt_name.text = "Snow";
   this.img_dragon.source = RES.getRes("egret_icon_png");
   this.playDragonEff();
  }
  /**
         *刷新机器人特效
         */
        public playDragonEff(): void {
            this.loadChibangByResName("Robot_json");
        }
  /**
         * 异步Robot动画资源
         */
        private loadChibangByResName(name: string): void {
            var self = this;
            RES.getResAsync(name,
                function(data: any,key: string): void {
                    if(key == "Robot_json") {
                        self.loadChibangByResName("texture_json");
                    }
                    else if(key == "texture_json") {
                        self.loadChibangByResName("texture_png");
                    }
                    else if(key == "texture_png") {
                        this.showRoleWing();
                    }
                },
                this);
        }

  /**
        * 展示Robot特效
        */
        private showRoleWing(wingId: number): void {
            this.egretFactory = tools.DragonBoneTools.Instance.createEff2New(
                "Robot_json",
                "texture_json",
                "texture_png",
                );
            let eff_robot : dragonBones.EgretArmatureDisplay = this.egretFactory.buildArmatureDisplay("robot");
            this.addChild(eff_robot);
            eff_robot.animation.play("Run",0);
            eff_robot.x = 250;
            eff_robot.y = 300;
        }
 }
}


相关内容

热门资讯

我来教教您“花花生活圈是不是有... 家人们!今天小编来为大家解答花花生活圈透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买...
玩家攻略科普“瓦力游戏可以开挂... 有 亲,根据资深记者爆料瓦力游戏是可以开挂的,确实有挂(咨询软件无需打开...
终于明白“神皇牛牛可以开挂吗?... 终于明白“神皇牛牛可以开挂吗?”(透视曝光猫腻)您好,神皇牛牛这个游戏其实有挂的,确实是有挂的,需要...
最新引进“新超圣炸/金/花可以... 最新引进“新超圣炸/金/花可以开挂吗?”(果然有透视挂)您好,新超圣炸/金/花这个游戏其实有挂的,确...
终于明白“爱来掌中宝究竟有挂吗... 有 亲,根据资深记者爆料爱来掌中宝是可以开挂的,确实有挂(咨询软件无需打...
终于明白“微信链接牛牛有挂吗?... 网上科普关于“微信链接牛牛有没有挂”话题很是火热,小编也是针对微信链接牛牛作*弊开挂的方法以及开挂对...
玩家攻略科普“墨韵麻趣怎么装挂... 有 亲,根据资深记者爆料墨韵麻趣是可以开挂的,确实有挂(咨询软件无需打开...
我来教教您“西兵互娱牛牛怎么装... 家人们!今天小编来为大家解答西兵互娱牛牛透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
终于懂了“夜猫麻将有挂吗?”(... 终于懂了“夜猫麻将有挂吗?”(果然有透视挂)您好,夜猫麻将这个游戏其实有挂的,确实是有挂的,需要了解...
【第一资讯】“花花生活圈开挂神... 有 亲,根据资深记者爆料花花生活圈是可以开挂的,确实有挂(咨询软件无需打...