使用JavaScript和Canvas开发游戏(三)
2 |
this .context2D.drawImage( this .backBuffer, 0, 0); |
理解了draw函数,下面再分别讲一讲addGameObject和removeGameObject函数。
/**
向gameObjects集合中添加一个GameObject
@param gameObject The object to add
*/
this.addGameObject = function(gameObject)
{
this.gameObjects.push(gameObject);
this.gameObjects.sort(function(a,b){return a.zOrder - b.zOrder;})
};
/**
从gameObjects集合中删除一个GameObject
@param gameObject The object to remove
*/
this.removeGameObject = function(gameObject)
{
this.gameObjects.removeObject(gameObject);
}
05 |
this .addGameObject = function (gameObject) |
07 |
this .gameObjects.push(gameObject); |
08 |
this .gameObjects.sort( function (a,b){ return a.zOrder - b.zOrder;}) |
14 |
this .removeGameObject = function (gameObject) |
16 |
this .gameObjects.removeObject(gameObject); |
利用addGameObject和removeGameObject(在Utils.js文件里通过扩展Array.prototype添加)函数,可以在GameObjectManager所维护的GameObject集合(即gameObjects变量)中添加和删除游戏对象。
GameObjectManager类是我们这个游戏框架中最复杂的一个类。在下一篇文章中,我们会讲解游戏框架的另外几个类:GameObject、VisualGameObject、Bounce和ApplicationManager。
好了,现在放松一下,看一看Demo吧。
建议继续学习:
- 《部落冲突》的设计 (阅读:3533)
- Canvas学习教程 : Canvas介绍 (阅读:3164)
- 手机游戏设计初体验 (阅读:3044)
- 游戏多服务器架构的一点想法 (阅读:2860)
- 使用canvas绘制时钟 (阅读:2861)
- 使用JavaScript和Canvas开发游戏 (阅读:2701)
- HTML5 Canvas(画布)教程 (阅读:2620)
- 游戏程序守护进程-Windows版 (阅读:2532)
- 游戏动作感设计初探 (阅读:2447)
- 网络游戏的社会化 (阅读:2334)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习