Egret之EUI及龙骨基础

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

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

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

步骤

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

1,

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

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

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

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

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

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

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

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

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

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

3,编辑DragonE.exml文件

①,切换至设计师

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

如下图:

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

编写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);
        }
    }

结果如下:

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

龙骨:

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

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

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 以播放龙骨动画:

///<reference path="./../tools/DragonBoneTools.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;
        }
 }
}
时间: 2024-10-01 07:36:50

Egret之EUI及龙骨基础的相关文章

Egret之eui.Scroller

(纯码农制作 ,不喜勿喷)先看看结果 : 一 : Cell(render) Skin 的制作: 看结果是横向的滚动 , 向左 . 如果第一次显示第二个cell , 那么需向左滑动Cell的宽度 + Cell直接的横向的间隔(我这里设为10,往下看↓), 那么一个需要向左偏移110 .(当然 , 内边距左为0↓) 二:Scroller Skin的制作 三 :Cell代码: module demo{ /** * scroll Cell * @author Husz */ export class S

Egret之微信小游戏基础Bug修复

一 : 第三方类库未定义 如 : smallLib类库 解决方案: 找到wxgame.ts , 在onFile方法中加入 if(filename == "libs/modules/smallLib/smallLib.js" || filename == "libs/modules/smallLib/smallLib.min.js"){ content += ";window.smallLib = smallLib;" } 二:第二加载问题 使用U

Egret之美术字批处理尝试(基础)

一 : 应用情景① , 如果游戏需要进军海外的时候,需要将一些通用的美术字批量转换成外语版的.本篇是基于 ps 2015 cc批量处理文本的初始探索 , 有不少的局限性. 二 : 步骤1` 新建一个文本图层aaaa , 其余的都去掉 , 如下图: 2`新建一个excel文件 , 并在里面写入替换的文本.注意头部名称:name(自定义的) 3`将excel导出(另存)为txt文件(aaa.txt) , 文本格式如下: 4`图像->变量->定义 5`图像->变量->数据组 6`文件-&

egret游戏入门之学习资源篇

最近因需要,入手H5游戏. 写游戏当然需要有引擎. H5游戏开发:游戏引擎入门推荐 如何选择 H5 游戏引擎 白鹭引擎和layabox哪个好用,哪个技术更成熟 ? LayaBox 与 Egret 选择哪个呢? Egret 4.1.6 和 LayaBox(LayaAir 2.0) 的 易用性 对比 经过初步分析和咨询,基本确认Egret和LayaAir, 个人讲真从官网和社区逛过后.真心喜欢LayaAir一些.但是最后还是选择了这一只白鹭. 要学习当然要有学习资源. Egret官网 其首页的新闻动

Html5 Egret游戏开发 成语大挑战(三)开始界面

本篇需要在前面的素材准备完毕,才可以开始,使用egret的eui结合代码编辑,快速完成基本的界面搭建,这里写的可能比较细,目的是减少大家对于其中一些操作疑问,我去掉了很多无用的步骤,以最精简的流程来完成,如果比较熟练的话,这些操作只需要不到15分钟就完全可以搞定. 特别说明:如果已经对EUI 有基础了解的童鞋,可以直接跳过这篇,因为实在是太简单了. 创建一个exml的皮肤,这里特别说一下,到现在仍然对于项目中的“包”和“目录”有什么具体区别仍然还是不是很清晰,反正对我来说就是一个目录,习惯性的会

Html5 Egret游戏开发 成语大挑战(九)设置界面和声音管理

在上一篇中,简单的使用界面元素快速实现了一个游戏中的二级页面,这种直接在游戏页面上做UI的做法并不太好,原因是,UI会让游戏的压力变大,即使它是隐蔽的,如果同样的功能在其它的地方也是一样的,那么就要写多个同样的逻辑吗?例如设置界面,游戏中的设置界面基本上功能都是一样,如果每个UI中都做一遍,是多么愚蠢的办法?在UI的代码设计中,一般来说,单独的功能不会在其它的地方用到,如GameOver,就直接写在UI里,而如果是通用功能,则最好的做法是做一个通用的单例类或者工厂类在需要的时候将它们初始化,在多

Html5 Egret游戏开发 成语大挑战(一)开篇

最近接触了Egret白鹭引擎,感觉非常好用,提供了各种各样的开发工具让开发者和设计者更加便捷,并且基于typescript语言开发省去了很多学习成本,对于我们这种掉微软坑许久的童鞋来说,确实很有吸引力,在开发中最浪费时间就是设计和调试的阶段,js的语言过于自由,自由到有时候写错了都不知道,但typescript可以使用开发IDE帮助排错和调试,不得不说确实很有效率,在这之前,我在egret论坛里发了几个小游戏做练手,最近的一个<疯狂猜歌名>在素材齐备的情况下,仅用了不到1天的时间完成了开发,以

EUI库 - EXML

  EXML是可以运行时加载解析的   <e:Skin class="skins.ButtonSkin" states="up,down,disabled" minHeight="50" minWidth="100" xmlns:e="http://ns.egret.com/eui"> <e:Image width="100%" height="100%&qu

Html5 Egret游戏开发 成语大挑战(四)选关界面

通过前面的开始界面基本上了解了eui的使用方法,可以简单快速的制作一个UI界面,本篇使用第二界面选关界面展示更为难一点的代码控制,来展现关卡地图的内容,请确保素材和资源完整,可以在前面的教程中找到下载. 选关界面和开始界面不太一样,请参考开篇的结构图,需要一个推进式上下拉动的地图界面,创建基本的exml和开始界面是一样的,这里的名字叫“SceneLevelsSkin”,在组件库中把Scroller组件拖进去并给其下属内容命名group_levels,用来承载地图内容,最后加一个返回按钮. <?x