如何解决和回避Egret开发中遇到的坑

 我来答
美娣娅整形美容
2017-11-10 · 超过16用户采纳过TA的回答
知道答主
回答量:44
采纳率:83%
帮助的人:19.7万
展开全部

导入fairygui库(坑点)

将bin目录下文件保存到 项目根目录/libs/fairygui/目录下

将libs目录下文件保存到 项目根目录/libs/rawinflate/目录下 

注意如果rawinflate 目录下扮败没有rawinflate.js,则复制rawinflate.min.js保存为rawinflate.js

(egret在本地调试调用的是.js文件,如果不存在则会报错,未找到Zlib库)


在egretProperties.json文件中添加(重点)

{
"name": "rawinflate",
"path": "./libs/rawinflate"
},
{
"name": "fairygui",
"path": "./libs/fairygui"
}

测试UI案例

将导出的资源添加到resource/fairygui/目录下

修改default.res.json文件,导出的图片文件注意TankGame@atlas0命名规范

{
"groups": [
{
"keys": "TankGame,TankGame@atlas0",
"name": "preload"
}
],
"resources": [
{
"name": "TankGame",
"type": "bin",
"url": "fairygui/TankGame.fui"脊缺巧
},
{
"name": "TankGame@atlas0",
"type": "image",
"url": "樱键fairygui/TankGame@atlas0.png"
}
]
}

修改Main.ts文件

protected startCreateScene(): void {
fairygui.UIPackage.addPackage("TankGame")
this.addChild(fairygui.GRoot.inst.displayObject)
let uiPanel = new UIPanel()
}

class UIPanel {
private root: fairygui.GComponent;

public constructor() {
this.root = fairygui.UIPackage.createObject("TankGame","Main").asCom;
this.root.setSize(fairygui.GRoot.inst.width,fairygui.GRoot.inst.height)
fairygui.GRoot.inst.addChild(this.root)
}
}

演示效果

启帆信息
2024-11-19 广告
启帆信息是英伟达中国区代理商,原厂授权代理,提供全面的软件技术解决方案以及NVIDIA以太网产品、交换机等产品,欢迎前来咨询!... 点击进入详情页
本回答由启帆信息提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式