HW7-智能巡逻兵

一、作业要求

智能巡逻兵
游戏设计要求:

  • 创建一个地图和若干巡逻兵;
  • 每个巡逻兵走一个3~5个边的凸多边型,位置数据是相对地址。即每次 确定下一个目标位置,用自己当前位置为原点计算;
  • 巡逻兵碰撞到障碍物如树,则会自动选下一个点为目标;
  • 巡逻兵在设定范围内感知到玩家,会自动追击玩家;
  • 失去玩家目标后,继续巡逻;
  • 计分:每次甩掉一个巡逻兵计一分,与巡逻兵碰撞游戏结束;

程序设计要求:

  • 必须使用订阅与发布模式传消息、工厂模式生产巡逻兵

二、相关知识

1.订阅与发布模式(观察者模式)
在这里插入图片描述

也称为观察者模式(Observer Pattern)

  • 发布者与订阅者没有直接的耦合
  • 是实现模型与视图分离的重要手段
  • 例如:数据DataSource对象,就是Subject。任何使用该数据源 的显示控件,如Grid都会及时更新。

实现:
定义事件源
在这里插入图片描述

在这里插入图片描述

2.工厂模式的设计
为什么需要工厂对象

  • 游戏对象的创建与销毁高成本,必须减少销毁次数。如:游戏中子弹
  • 屏蔽创建与销毁的业务逻辑,使程序易于扩展

实现示例DiskFactory:
在这里插入图片描述
设计读图:这是一个带游戏对象缓存的工厂类

  • 前面游戏,由导演、场记、运动管理师、演员构成。
  • 新游戏中,场记请了记分员、飞碟管理员
  • 其中记分员按飞碟的数据计分,记分员拥有计分规则
  • 场记只需要管理出飞碟规则与管理碰撞就可以了

三、关键部分的实现

1.巡逻兵工厂
主要负责用预制创建四个士兵、点击重新开始之后销毁士兵并重新创建。

public List<GameObject> GetPatrols()
    {
   
        firstController = SSDirector.getInstance().currentScenceController as FirstController;
        if (!isProduce)
        {
   
            int index = 0;
            float[] posZ = {
    3.75f, -3.75f };
            float[] posX = {
    3.75f, -3.75f };
            for (int i = 0; i < 2; i++)
            {
   
                for 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值