cocos2d-js 热更新详解(一)

本文将会详细讲解cocos2d-js下的热更新机制,这篇内容先给大家介绍一下两个manifest文件就当热身了。

首先介绍project.manifest:  举个例子

{

"packageUrl" : "http://192.168.1.108/games/dragon_gold",

"remoteManifestUrl" : "http://192.168.1.108/games/dragon_gold/project.manifest",

"remoteVersionUrl" : "http://192.168.1.108/games/dragon_gold/version.manifest",

"version" : "1.0.2",

"groupVersions" : {

"1" : "1.0.1",

"2" : "1.0.2"

},

"engineVersion" : "3.6",

"assets" : {

"update1" : {

"path" : "dragon_gold1.zip",

"md5" : "140caaa2a4508912424e807a941bf71",

"compressed" : true,

"group" : "1"

},

"update2" : {

"path" : "dragon_gold2.zip",

"md5" : "140caaa2a4508912424e807a941bf7bc",

"compressed" : true,

"group" : "2"

}

},

"searchPaths" : [

]

}

  • packageUrl :  远程资源的下载根路径。 (它是为“dragon_gold1.zip”服务的,没了这个根路径我们都找不到要下载的包)
  • remoteVersionUrl :远程版本文件的路径,用来判断服务器端是否有新版本的资源。
  • remoteManifestUrl :远程配置文件的路径,包含版本信息以及所有资源信息。
  • version : 配置文件对应的版本。(这个用来判断是否有新的更新包)
  • assets :这个比较重要:里面的value就是对应要更新的包,其中path是更新包的包名,md5:当在下次更新时用来比较这次与上次下载下来的manifest文件中对应的包的md5 码是否相同,不同的话需要做些处理(更新,删除操作)。compressed是用来决定下载下来的包是否需要解压。group是重中之重,它是用来实现增量跟新的,它的值与groupVersions相对应。

举个例子:有这么两个用户,第一个用户下载app之后一直没玩,第二个用户一直在玩每次有更新时第二个用户都会跟着更新,现在第二个用户当前的version为1.0.1时,他会去更新update2这个包,但是第一个用户一直没玩所以他的更新包version是1.0.0,这时他需要去更新update1和update2这两个包,
这就是一个简单的实现增量更新的例子。

(备注:当时用2.x版本引擎没提供这个功能,自己做了个增量更新功能坑了一段时间,现在引擎已经提供这个功能方便多了)。

我一直再讲project.manifest这个文件却没有说version.manifest,它其实是个简化版 的project.manifest,当我们版本已经有了几十个甚至几百个更新包时,显然下载project.manifest来判断是否有无更新是不明智的(因为更新包越多project.manifest体积变得越大,对于手机这么贵的流量下载这么大的东西是不划算的),因此此时的version.manifest用处就明显了,无论project.manifest体积多大,它永远只需要这么几行代码就可以了:

{

"packageUrl" : "http://192.168.1.108/games/dragon_gold",

"remoteManifestUrl" : "http://192.168.1.108/games/dragon_gold/project.manifest",

"remoteVersionUrl" : "http://192.168.1.108/games/dragon_gold/version.manifest",

"version" : "1.0.2",

"groupVersions" : {

"1" : "1.0.1",

"2" : "1.0.2"

...

}

}

这一节就说到这,下次开始用我目前做的一个项目来详细讲解热更新的用法。(备注:这一节是用工作时间写的,有点马虎了.......)

时间: 2024-10-21 20:56:42

cocos2d-js 热更新详解(一)的相关文章

Node.js继承中的静态类对象(《node.js开发实战详解》书中一些错误的改正)

今天气真好,最近挂掉一些面试之后心情略失落. 神马都是浮云,要永远做好世界第二. 不多提了,你问我心态为啥变好了.-------都是情怀,,. 嗯啊,最近在研究node. 别人问?你这水平还node... 哈哈哈,好伤心.... 不多提了,言归正传. 神马模块化神马的先就不多讲了,就一个module.export和export区别,后者对象的属性属于前者,逆命题不成立. 还有util.inherits(A,B)这个API注意一下A只会继承B的原型方法,原型以外的不会继承.不是说原型中数据是共享的

js new date详解

创建一个日期对象: var objDate=new Date([arguments list]); var ini_date=new Date(2014,7,0); //是代表7月最后一天 ,也就是2014-07-31 var ini_date=new Date(2014,7,1); //是代表8月第一天 ,也就是2014-08-01参数形式有 以下5种: new Date("month dd,yyyy hh:mm:ss");   new  Date("month dd,yy

【JS】☆★之详解[Object HTMLDivElement]和[Object Object]

[JS]☆★之详解[Object HTMLDivElement]和[Object Object] <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml">

Cocos2d之Node类详解之节点树(二)

一.声明 本文属于笔者原创,允许读者转载和分享,只要注明文章来源即可. 笔者使用cocos2d框架的cocos2d-x-3.3rc0版本的源代码做分析.这篇文章承接上篇<Cocos2d之Node类详解之节点树(一)>. 二.简介 节点 一个Node对象. 节点树 上篇文章介绍到,Node类有一个成员变量 Vector<Node*> _children,这是一个保存所有子节点的数组,因为Node类采用遍历树的方式获取子节点进行渲染,所以我管这两个东西的结合叫节点树. 三.源码详解 &

Cocos2d之Node类详解之ZOrder详解

一.声明 笔者以cocos2d框架的cocos2d-x-3.3rc0版本源码做分析.本文属于笔者原创,允许转载和分享,但请注明文章出处. 二.简介 ZOrder ZOrder顾名思义就是节点(Node对象)在Z轴上的排序,这样一来ZOrder越小就越优先显示.每个节点(Node对象)可以持有多个子节点,组成节点树(关于节点树的介绍查看<Cocos2d之Node类详解之节点树>一文).ZOder表示了节点树中每个子节点显示的优先级.值得注意的是,节点树中子节点的ZOder可能会一样,这种情况下父

Js apply 方法 详解

Js apply方法详解 我在一开始看到JavaScript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这里我做如下笔记,希望和大家分享..  如有什么不对的或者说法不明确的地方希望读者多多提一些意见,以便共同提高.. 主要我是要解决一下几个问题: 1.        apply和call的区别在哪里 2.        什么情况下用apply,什么情况下用call 3.        apply的其他

JS事件类型详解

一般事件 onclick IE3.N2 鼠标点击时触发 此事件 ondblclick IE4.N4 鼠标双击时触发 此事件 onmousedown IE4.N4 按下鼠标时触发 此事件 onmouseup IE4.N4 鼠标按下后松开鼠标时触发 此事件 onmouseover IE3.N2 当鼠标移动到某对象范围的上方时触发 此事件 onmousemove IE4.N4 鼠标移动时触发 此事件 onmouseout IE4.N3 当鼠标离开某对象范围时触发 此事件 onkeypress IE4.

JS变量对象详解

JS变量对象详解 开年之后工作热情一直不是很高,这几天一直处于消极怠工状态.早上不想起床,起床了不想上班.明明放假之前工作热情还一直很高,一直心心念念的想把小程序项目怼出来,结果休假回来之后画风完全不一样了.我感觉自己得了严重了节后综合征.还好撸了几篇文章,勉强表示这一周的时间没有完全浪费.这篇文章要给大家介绍的是变量对象. 在JavaScript中,我们肯定不可避免的需要声明变量和函数,可是JS解析器是如何找到这些变量的呢?我们还得对执行上下文有一个进一步的了解. 在上一篇文章中,我们已经知道

Cocos2d之Texture2D类详解之将文件加载成Texture2D对象

一.声明 笔者以cocos2d框架cocos2d-x-3.3rc0版本的源码做分析.本文为笔者原创,允许转载和分享,只要注明文章出处即可. 二.简介 Texture2D类简介 Texture2D类允许开发者用图像.文本信息和简单的数据来创建OpenGL2D纹理.被创建的纹理拥有两个维度.根据开发者创建Texture2D对象方式的不同,实际图像的尺寸可能比生成的纹理的尺寸要小,而且纹理的内容是倒置的. 像素格式 在计算机图形学中,人们用每个像素在内存中的总位数以及分别存储红.蓝.绿和alpha(阿