项目发布小游戏指南
5.1.2 以后的项目
- 使用引擎为 5.1.2 引擎以上(包括 5.1.2)按照文档流程发布即可。
5.1.2 以前的项目
由于目前的 5.0.x 引擎的项目不能直接升级到 5.1.x,需要我们手动建立一个空的 5.1.2 eui 项目,然后将原项目代码复制过去。
- 首先我们使用 launcher 创建一个 5.1.2 新项目。
- 然后将现有游戏逻辑和资源拷贝至新项目中主要包括 src 目录、resource 目录、修改配置文件 egretProperties 后续无论是 HTML5 版本,iOS / Android 版本还是小程序版本,均使用这个新项目进行后续开发。
- 全部拷贝以后,先测试下在 H5 中是否正常运行,一定要保证在 H5 中可以正常运行,再进行后续的操作。
- 还要将
ThemeAdapter
类中的getTheme
方法替换如下代码:
public function getTheme(url: string, onSuccess: Function, onError: Function, thisObject: any): void {function onResGet(e: string): void {onSuccess.call(thisObject, e);}function onResError(e: RES.ResourceEvent): void {if (e.resItem.url == url) {RES.removeEventListener(RES.ResourceEvent.ITEM_LOAD_ERROR, onResError, null);onError.call(thisObject);}}if (typeof generateEUI !== 'undefined') {egret.callLater(() => {onSuccess.call(thisObject, generateEUI);}, this);}else {RES.addEventListener(RES.ResourceEvent.ITEM_LOAD_ERROR, onResError, null);RES.getResByUrl(url, onResGet, this, RES.ResourceItem.TYPE_TEXT);}}
注意事项:
小程序和小游戏中都移除了动态执行代码的能力,包括以下调用方式:eval 函数、setTimeout、 setInterval 函数第一个参数传入代码字符串执行、使用 Function 传入字符串构造函数、使用 GeneratorFunction 传入字符串构造生成器函数、
项目中使用了 egret.getDefinitionByName() 方法,需要将要反射的类挂载到全局 window 对象上,例:window["object1"] = object1 的方式。
项目中使用了自定义组件,需要将自定义组件挂载到全局 window 对象上,例:window["CustomCom"] = CustomCom 的方式。
检查是否使用了嵌入EXML到代码中,例:
const className = "skins.ButtonSkin";const exmlText = `<e:Skin class="${className}" states="up,over,down,disabled" xmlns:s="http://ns.egret.com/eui"> ...</e:Skin>`;
如果有需要改成单独的皮肤文件。
ts 代码和 eui 是不允许相同的命令空间,例如:
<?xml version="1.0" encoding="utf-8" ?><e:Skin class="ui.MyButtonSkin" states="up,down,disabled" minHeight="50" minWidth="100" xmlns:e="http://ns.egret.com/eui"></e:Skin>
namespace ui {export class TestNameSpace {public constructor() {egret.log("测试命令空间输出");}}}