Cocos2d-HTML5入门第三天

  次阅读 作者:智能小宝 来源:互联网 2015-09-27 15:28 我要评论(0)

第二天掠过,不要在意细节。

第三天了,目前只搭了个hello world版本,而且换了三个版本,到现在仍旧不知道怎么开发游戏。

在上一篇文章搭建的基础上,分析一下结构。

抛开游戏不说,只谈b/s的b,顺着一开始的入口index.html页面。

眼前一个标准的H5页面

一个html5的新标签canvas,俩个js文件。

打开第一个文件cocos2d/cocos2d-html5/CCBoot.js

2千多行代码,粗略从头读到尾巴,发现里边无非就是定义了一个cc的命名空间,当做全局变量对象,这个cc对象加了很多方法和属性。

代码一开始添加了一些常用的工具方法

比如

cc.newElement = function (x) {

return document.createElement(x);

};

cc._addEventListener = function (element, type, listener, useCapture) {

element.addEventListener(type, listener, useCapture);

};

封装了新建元素结点和捕获事件监听的方法。

顺着下看,cc对象又挂了一个属性:game对象,对象里面挂了一些配置信息对象,从字面量看是一些帧速度,依赖包,引擎路径等配置。

还有一些方法比如说run,应该是游戏开始方法;

有个_initConfig应该是初始化游戏,比如引进依赖脚本,图片等。

最后在2184行有一句cc.game._initConfig();

然后回头看了下_initConfig();方法

原来里面是读取我们主目录下的project.json文件,然后把project.json的信息初始化合并进self.config,有点类似jQuery插件开发的option有木有,比如说,project文件配置的js脚本路径,引擎engineDir路径,模块名字等。并没有我想象那样一开始就加载文件……

ok,目前为止大概了解CCBoot.js的作用了。定义了cc,然后初始化了一些配置信息。

接着看看inde.html引进的第二个文件main.js

cc.game.onStart = function(){

var designSize = cc.size(480, 800);

var screenSize = cc.view.getFrameSize();

if(!cc.sys.isNative && screenSize.height

看到了熟悉的cc和里面挂在的game,onStart在这里被定义了,再回头看CCBoot.js,在game对象里面被声明缺省为null,然后在run方法有调用到。

run: function (id) {

var self = this;

var _run = function () {

if (id) {

self.config[self.CONFIG_KEY.id] = id;

}

if (!self._prepareCalled) {

self.prepare(function () {

self._prepared = true;

});

}

if (cc._supportRender) {

self._checkPrepare = setInterval(function () {

if (self._prepared) {

cc._setup(self.config[self.CONFIG_KEY.id]);

self._runMainLoop();

self._eventHide = self._eventHide || new cc.EventCustom(self.EVENT_HIDE);

self._eventHide.setUserData(self);

self._eventShow = self._eventShow || new cc.EventCustom(self.EVENT_SHOW);

self._eventShow.setUserData(self);

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...