cocos2d-x-3.3-023-仿微信飞机大战-总体分析和建模

松高歌
2023-12-01

原文同步发布于我的wiki,查看原文或更新请移步:点击打开链接


总体分析

  • 一开始得想明白了的问题

    1. 游戏里面的可见元素,采用is-a精灵,还是采用has-a精灵好: 直接继承精灵使用于相对简单的情形;而对于复杂的UI构成采用组合策略, 这时候用继承Node,并采用has-a精灵的关系是不错的选择。
    2. 子弹发射这个动作的思考(包括产生敌机,英雄出场,补给出场等都适用这个问题),cocos提供的导演和场景是用于流程控制的;层是画布;而精灵则是画布上的元素,故在发射或者创建一个子弹时要指定他所属于的画布。之后子便弹自个儿播放动画玩耍了。
    3. 层的使用,为了将相对独立的ui展示分离,使得代码耦合降低,将不同功能放到不同的层是个很好做法,如背景层,控制层等。
    4. 速度是每秒多少个像素点? 这个问题适用于其他元素,比如生命值,攻击力,飞行速度如何取值等。在真真的游戏开发团队里, 这个工作应该是有专们团队进行策划的。我们这里就初步按照跑出来的效果进行调整了。
    5. 怎么根据剧情或者关卡产生画布上的角色呢?提供一个关卡管理器,他的动力源是调度器。给他设置一个调度器回调,然后在回调里面不停的根据当前关卡的设置产生敌人,类似actionManager。
    6. 游戏的整个过程就是拍电影: 总导演安排好人架好了摄像机,选好了拍摄场景,决定场景是否切换,这些大事儿总导演负责。细节交个手下的副导演, 副导演找群众演员,找主角,负责安排出场顺序,负责驱动场上的逻辑-碰撞监测。每个关卡的剧本是不一样的。剧本管理员专门负责剧情的配置管理。
    7. 主角和群众演员根据剧情配置分别化不同的妆,带不同的装备,不同的技能等。
    8. UI按钮的显示和主角的关系: 我的理解是这两者应该不是is-a, has-a的关系,而是发布订阅的关系。
  • 一点拓展思考

    1. 也看了一些例子,包括上一篇提到的专栏,碰撞检测是通过‘副导演(或者谁谁谁)持有子弹数组,敌人数组,来两重循环进行碰撞检测’吗? 我的想法是, 碰撞检测相关代码由cocos的框架来实现并提供回调,客户端代码不用保留两个数组并循环, 而是让发射的子弹自己进行碰撞检测,并根据相应回调进行状态切换,这样的游戏代码看上去更具美感点。
    2. 由上面的‘碰撞检测’的问题引出本问题,采用上面的碰撞检测方案的话, 游戏里面的精灵元素更像'提线木偶', 每一帧里'副导演'都要喊'进行碰撞检测了', ‘碰撞了就攻击了’。。。 这会累死副导演的。 若精灵元素可自行检测碰撞,并根据相关回调进行状态切换,播放不同的动画效果等,就可以将‘副导演’里面的逻辑代码放入不同的精灵元素中,这样的代码耦合性会降低,封装性更好,更容易扩充。
    3. 物理引擎可以满足上述需求么?
    4. 答案见下一节。

物品详细分析

 飞机: 我方战斗机, 敌人飞机, 都是飞机, 阵营不同而已
 飞机可被伤害
 飞机可被修复
 飞机有枪
 飞机用枪发射子弹
 飞机有飞行速度
 飞机有方向
 飞机能得到补给

 枪:发射子弹
 枪有子弹
 不同类型的枪一次发射的子弹数量不同,发射的子弹也不同

 子弹:有杀伤力,体现为威力
 子弹杀伤敌人后自己的生命周期也结束了
 子弹无眼?子弹有眼?即子弹可以伤害同一阵营的人么?先无眼吧,不纠结
 子弹有速度
 子弹有起始位置
 子弹有方向

 补给-血包:+血用
 补给-双排枪:换枪,子弹打光后再换回默认的枪
 补给-炸弹:给飞机挂几颗导弹,发射后全屏灭怪
 补给有速度
 补给有起始位置
 补给有方向

建立类族

类图如下

https://github.com/cheyiliu/All-in-One/raw/master/res/cocos2d/warofairplain.jpg

说明

  • 飞机系
Role:  角色类定义,属性有:队伍,血量,攻击力,资源等; 
行为有:判断是敌是友,攻击,被攻击,获得各种补给; 
提供静态工厂方法

RoleHero: 英雄,属性有:多把枪用于远程攻击;可以获得各种补给等;

RoleEmemy: 敌人:只能有攻击和被攻击行为。
RoleEnemy有3个子类,代表大中小型敌人,负责用不同的资源来实例化
  • 补给系
Supply: 补给类,定义了基本方法;和工厂方法。
Supply有3个子类,负责不同的补给工作。

  • 枪支弹药系
Gun: 枪,功能是开火发射子弹;包含静态工厂方法。
Gun有3个子类,装有不同的子弹,代表不同的枪。
Bullet: 子弹基类,属性有威力,资源等;行为有杀伤;同时有静态工厂方法
(后期开发看需求是否需要单独分离出工厂类)
Bullet有3个子类,代表不同类型的子弹。
  • 一点说明
为何要提供这么多子类呢, 每个系统有好几个子类, 
我的想法是在选用不同资源代表不同类型的物体时不想用太多的if else。
不子类化那么父类将承载过多的判断语句。

上述的补给系,枪支弹药系都作用于飞机系。

代码草稿




 类似资料: