Cocos creator热更新

下面是本人的集成步骤:

**1.**从官网上下载version_generator.js,放到新建的工程hotUpdateTry文件下,

然后构建一下你的工程(本人使用defalut,调试模式做的测试)。

**2.**页面写完后构建一下,找到把刚刚构建的jsb-default下的res和src文件。

**3.**打开终端,进入hotUpdateTry目录下(cd hotUpdateTry的路径),回车,执行命令:

node version_generator.js -v 1.0.0 -u http://你的服务器地址/tutorial-hot-update/remote-assets/ -s build/jsb-default/ -d assets/

解释:-v 1.0.0 意思是版本号1.0.0,

http://你的服务器地址/ 是服务器地址

tutorial-hot-update/remote-assets/ 是你要放到服务器上的代码文件

更新的资源主要是构建后的res和src文件。

-d assets/ 该命令执行完会在assets文件下生成两个文件:version.manifest和project.manifest,这两个文件很重要,服务器上也要根据这两个文件来判断是不是要更新版本和下载代码。

这些做完后,你可以仿照官方热更新demo给你的场景中加上热更新按钮。点击更新等。

重点来了:

服务器上的代码应该放什么呢?

你可以看看官方demo中的remote-assets文件,这个就是服务器上要放的代码。也就是项目构建代码后的核心代码。remote-assets这个里面包含res,src和刚刚生成的project.manifest,version.manifest。这几个文件。这个是不是很熟悉?你可以把这四个文件都放到tutorial-hot-update/remote-assets/下。然后把tutorial-hot-update文件上传服务器。

服务器上的tutorial-hot-update/remote-assets/下的代码目录

按照你刚刚命令行敲的,你服务器代码代码结构需这样:

http://你的服务器地址/tutorial-hot-update/remote-assets/。

如果你想改后面的文件夹名字,你就也需要改你刚刚的命令行或者直接改project.manifest,version.manifest文件里的热更新地址为你实际的服务器地址及文件夹名字。

注意:

本地的打包后的apk或者ipa更新的话会对比服务器上的project.manifest,version.manifest版本号。当服务器版本号高于你现在安装的这个版本的时候,才会下载服务器上的代码,然后你安装的应用内容才会自动更新。注意两个文件版本号都改。

这样,用户安装完你的应用后,只要你的应用版本和服务器版本作对比,版本号低于服务器就更新代码,用户安装的应用就自动更新了,不用重新去应用商店下载了。

这个热更新主要是用于ios和安卓的。

提示:

其实项目除了第一次构建会生成很多文件外,后来只要已build过,再build,frameworks文件夹基本不变,只变外面的内容,代码和资源文件核心内容就在于src,res文件,你打包的时候可以注意一下,更改这些文件夹,页面就跟着改变了。所以把这些重要文件放到服务器就可以了。

这里很重要!!!

当你遇到你的文件下载完自动重启了游戏还是原来的界面并没有更新的时候!!!注意检查你的main.js代码!!

main.js

就是这个代码:

**if (cc.sys.isNative) {
**

var hotUpdateSearchPaths = cc.sys.localStorage.getItem('HotUpdateSearchPaths');

if (hotUpdateSearchPaths) {

jsb.fileUtils.setSearchPaths(JSON.parse(hotUpdateSearchPaths));

}****}

**
**

正常情况下时自动生成的,但是本人遇到好多次它并没有自动生成,这时候你把这句代码复制到这里就可以了,然后运行你本地代码,发现更新成功!!不再是旧界面。

**
**

服务器的话,本人使用的mamp和mamp pro,安装后,启动mamp把需要更新的代码放到它的安装目录的 /Applications/MAMP/htdocs下就可以了,访问目录名字一般是这样的:http://192.168.xx.xxx/tutorial-hot-update/remote-assets/

想测试你的代码是否在服务器上正常访问可以尝试一下这样:

http://localhost/tutorial-hot-update/remote-assets/project.manifest

博客

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

被以下专题收入,发现更多相似内容