H5游戏框架设计

-前言-

**以下内容均是个人的一些小想法**

-正文-

当我们写出了一套自己的游戏框架之后,我们就能在以后每次开发新项目的时候,快速复用以往的经验积累。一个框架的好处就是复用性,在开发一个新项目的时候,能快速专注于新游戏的业务逻辑。我们在写游戏框架的时候,应满足MVC设计思想,做到逻辑分离。这样,在我们开发项目的时候,功能与功能直接的耦合就能降到相对较低的水平,我们更能协作开发。

首先作为一个MVC的框架,应该包括,Control模块,View模块,Data模块(Model),每一个功能模块由一个Manager去管理持有这三个模块,从而形成一个功能的基础。

Control模块可以获取得到View中的界面,也可以获取得到Data中的数据。

这三个模块在Manager初始化时也应该存在一定先后顺序。应该首先初始化数据模块——>界面模块——>控制器模块,在释放的时候则顺序相反。

每一个功能模块都是一个Manager,这个Manager则持有相关逻辑,界面,数据等对象。

Control模块

一个功能模块可以包含多个Control,每个Control可能处理的事情都不一样,可能是对界面某个地方做处理,只要我们分得够细,Control也就可以有很多个。只是说有没有这个必要性而已。

View模块

View模块同样也可以多个,View里面一般持有控制对象的原始图元数据等,都会暴露接口,提供给Control控制

Data模块

Data模块是存储这个模块对应的数据,生命周期是模块初始化到模块卸载期间,对应的我们游戏一般存在的玩家数据等全局数据,生命周期更短。

框架能力及分级

框架在设计之初都会进行层次分级,哪个粒度的结构处理哪个粒度的事情,这样一层一层的最终到我们的业务逻辑。

首先,我们程序一般入口为Main函数,这时候我们就可以启动我们框架。

一般一个框架最基础要包括如下能力:

  • 游戏数据管理(DataModule)
  • UI管理(2D界面的管理能力)
  • 网络通信(http通信,WebSocket通信)
  • 游戏业务逻辑的管理
  • 平台化

这上面有些是游戏引擎提供的,我们只需要做一点封装,比如Laya本来就有Pool(资源池),我们只需要在上层逻辑封装Pool实现自己的资源池即可。

H5游戏框架设计_第1张图片

以上可以基本形成一个游戏框架的结构。一个GameCenter可以由很多模块组成,不止上面图上所列举的,不过也要保证模块之间的粒度是尽量相同的。

上面每个模块中可能又包含很多具体的功能对象。以下为一个MVC框架的设计

H5游戏框架设计_第2张图片

上面的MVCable就是最开始我们所说的Manager,持有Control、View、Data对象

-结语-

我们设计的框架不可能满足任何场景,有时遇到需要修改的时候,就需要作出一定修改。另外MVC的设计思路也不是没有缺点,在第一次接触你框架的人多数都不是很懂,因为MVC的设计一般是比较绕的,代码也比较散,不过等你熟悉了这套设计思路之后,就会知道写代码是多么的丝滑。

你可能感兴趣的:(H5,前端经验)