1. 首先,再次被网上一大堆屎一样的资料搞得浪费了我一天时间。各种坑。

2. 本文先讲一种正确的方式,然后再列举坑。

去www.egret.com下载最新的引擎,我的最新版本是5.2.2. 然后就会被安装了一个全家桶。在里面,你还要在去点击Egret Wing,安装个开发环境。

然后,在项目的地方,新建一个游戏项目,带EUI框架:

必须注意红框的地方,避免踩坑。类型是Egret游戏项目。之后,全家桶就会默认打开Egret Wing进入开发环境。

在src目录下面,新建模板文件——新建EUI组件。

这个时候,第一个坑出现,没有default.thm.json文件。

自己new一个,里面填写{}, 放在resource目录下:

之后再新建EUI组件就没有报错了。

我新建一个叫做Helloworld的组件。

时候就会在resource/eui_skins目录下,出现了exml窗体界面文件,点击,添加一个label,名字是nameL

之后,在src目录下,修改Hellworld.js文件:

class Helloworld extends eui.Component implements  eui.UIComponent {
public nameL : eui.Label;
public constructor() {
super();
this.addEventListener(eui.UIEvent.COMPLETE, this.onComplete, this);
} protected partAdded(partName:string,instance:any):void
{
super.partAdded(partName,instance);
} protected childrenCreated():void
{
super.childrenCreated();
} protected onComplete(e):void{
this.nameL.addEventListener(egret.TouchEvent.TOUCH_TAP, this.tap, this);
} protected tap(e):void{
this.nameL.text = "HELLO WORLD";
} }

  注意这里面的坑一大堆。

1. 首先,不需要指定this.SkinName,否则微信小游戏会一大堆搓。

2. 要在构造函数监听onComplete时间,然后里面去绑定nameL的监听器。忘记什么childCreated之类的,都是坑。

最后,在Main.js的入口函数里面,:createGameScene方法,把EUI添加到舞台:

接下来跑一下,看看效果:

恩。很好,完全没有效果。因为没有加EUI的主题自动映射起,接下来,我又创建了一个EUI项目,和这个游戏项目对比来开发,差别点包括:

1. manifest.json文件,game下面添加

"bin-debug/AssetAdapter.js",

"bin-debug/ThemeAdapter.js"

2. egretProperties.json,添加eui节点:

"eui": {
"exmlRoot": [
"resource/eui_skins"
],
"themes": [
"resource/default.thm.json"
],
"exmlPublishPolicy": "commonjs"
},

3. src目录,添加AssetAdapter,ThemeAdapter

4. Main.ts,在onAddToStage方法,添加

//inject the custom material parser
//注入自定义的素材解析器
let assetAdapter = new AssetAdapter();
egret.registerImplementation("eui.IAssetAdapter", assetAdapter);
egret.registerImplementation("eui.IThemeAdapter", new ThemeAdapter());

5. Main.ts, 在loadResource添加:

await this.loadTheme();

private loadTheme() {
return new Promise((resolve, reject) => {
// load skin theme configuration file, you can manually modify the file. And replace the default skin.
//加载皮肤主题配置文件,可以手动修改这个文件。替换默认皮肤。
let theme = new eui.Theme("resource/default.thm.json", this.stage);
theme.addEventListener(eui.UIEvent.COMPLETE, () => {
resolve();
}, this);

})
}

然后在跑一下,就出现了。

最后点击发布,微信小游戏。然后打开微信的开发工具,加载导出的项目目录。全部完成!!!!

这里就在游戏项目里面成功的引入了EUI皮肤管理!

其他的一些坑再度强调:

1. EUI的类,不需要声明skinName!!! 否则比错

2. 没有XML的读取,因为使用了commonjs方式把皮肤编译成js了。如果你要xml去夹在,必错!

3. 没有什么window.DOMParser = require("./xmldom/xmldom.js").DOMParser;

那个智障的egret官方微信小游戏FAQ,直接忽略到,简直就是把你往坑再踩一脚。

http://developer.egret.com/cn/github/egret-docs/Engine2D/minigame/minigameFAQ/index.html

Egret 生成 自带EUI 的微信小游戏 踩坑!的更多相关文章

  1. 微信小程序踩坑集合

    1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=1476434678461 2:简易教程:https://mp.weixin.qq.com/debu ...

  2. 微信小程序踩坑

    微信小程序自定义属性data-xx使用注意事项 data-xx采用驼峰式命名时,数据传递打印显示(以jxsName与jxsname打印显示对比) data-xx全小写命名时,数据传递打印显示

  3. 微信小程序踩坑记

    1:微信小程序之去掉横向滑动滚动条 /** 去除横向滚动条 */ ::-webkit-scrollbar { width: 0; height: 0; color: transparent; } 2: ...

  4. 微信小程序踩坑- tabBar.list[3].selectedIconPath 大小超过 40kb

    重新启动微信小程序编辑器的时候遇到了这样的一个问题: tabBar.list[3].selectedIconPath 大小超过 40kb 微信小程序开发的过程之中总会出现这样或者那样的错误,需要我们耐 ...

  5. 微信小程序踩坑日记1——调用微信授权窗口

    0. 引言 微信小程序为了优化用户体验,取消了在进入小程序时立马出现授权窗口.需要用户主动点击按钮,触发授权窗口. 那么,在我实践过程中,出现了以下问题. . 无法弹出授权窗口 . 希望在用户已经授权 ...

  6. 微信小程序踩坑之前端问题处理篇

    近期完成了一个小程序,自己做的前后端开发.真是惨哭我了o(╥﹏╥)o,下面几点希望大家可以避雷. 首先,想先介绍一下我遇到问题的解决思路: 1.先在postman调试接口,看数据获取是否正常, 2.在 ...

  7. 微信小程序踩坑之一[thist]使用技巧

    刚上手小程序 时,习惯把this当成jquery中的$(this)来用,实际上这两个还是有差别的 在页面方法中调用其他方法,一般是用this.function(),直接调用小程序 的方法或函数则是用w ...

  8. 微信小程序踩坑之一【weui-wxss-master单选按钮图标修改思路】

    小程序原生所带的weui框架做小程序UI实在太方便了,但是他的一些细微变化也是让开发中碰到不少头疼的问题 一直以来单选多选的美化都是设计师重点表达的地方之一 而weui-wxss-master中的单选 ...

  9. 微信小程序踩坑之获取手机号

    最近在开发小程序遇到这样一个问题, 在用户点击授权后去解密手机号时会出现第一次失败,第二次成功的情况.研究了一段时间,终于找到比较合理的解决方案,在此记录并总结一下,希望可以帮助到大家. 需求描述 在 ...

随机推荐

  1. Java的慢和稳

    对Java的了解还有待进一步提升,也没有做太多实践工作.只是把脑袋当成电脑,把Java放在里边不停地转,观察它的线路.得到的总体印象加上书本参考,认为Java的应用场景是慢和稳. 学编程语言总会接触到 ...

  2. open file /var/mobile/Media/DCIM 相册中获取到的视频地址使用 报错 视频文件不存在

    从相册中获取到的视频地址 例如  file:///var/mobile/Media/DCIM/100APPLE/IMG_9876.MOV 后面再使用的时候报错 视频文件不存在  那是因为在ios10. ...

  3. MYSQL 单表一对多查询,将多条记录合并成一条记录

    一.描述: 在MySQL 5.6环境下,应工作需求:将一个表中多条某个相同字段的其他字段合并(不太会表达,有点绕,直接上图) 想要达到的效果: 实现SQL语句: SELECT a.books, GRO ...

  4. css属性之统一设置文本及div之间的对齐方式

    设为 Flex 布局以后,子元素的float.clear和vertical-align属性将失效.hdp-uf{ display: -webkit-box; /* 老版本语法: Safari, iOS ...

  5. JAVA -数据类型与表达式---字符串

    字符串 Java中,字符串就是对象,它由 String类定义.字符串是计算机程序设计中非常基础的类型,因此Java允许定义字符串常量(string literal),并以双引号作为字符串的定界符. 一 ...

  6. JavaScript复制文本探究

    JS复制文本基本分为两步-First: 选中需要复制的节点,及选区:Second: 执行document.execCommand('copy')命令复制 对于选区,属于HTMLInputElement ...

  7. PHP字符过滤方法

    function str_filter_replace($str) { if (empty($str)) return false; $str = htmlspecialchars($str); $s ...

  8. RabbitMQ 声明队列时候的参数解释

    参考链接:http://www.rabbitmq.com/releases/rabbitmq-dotnet-client/v3.6.6/rabbitmq-dotnet-client-3.6.6-cli ...

  9. 2018-2019-2 20165239 《网络对抗技术》Kali的安装 第一周

    2018-2019-<网络对抗技术> Kali安装 20165239其米仁增 一.资源下载以及工具安装 1.下载虚拟机工具VMware. 下载链接 :https://www.baidu.c ...

  10. 计算机硬件&操作系统

    一.计算机的硬件: 控制器:计算机的指挥系统 运算器:数学运算+逻辑运算 存储器I/O设备:存I取O数据   内存(内存条):短期记忆,速度快,但是断电数据会丢失:   外存(硬盘):永久记忆,速度非 ...