版权申明:

  • 本文原创首发于以下网站:
  1. 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123
  2. 优梦创客的官方博客:https://91make.top
  3. 优梦创客的游戏讲堂:https://91make.ke.qq.com
  4. 『优梦创客』的微信公众号:umaketop
  • 您可以自由转载,但必须加入完整的版权声明

目标

实现功能

道具会在豆子的坐标上随机出现

玩家吃下道具时怪物会改变颜色

道具的随机出现

在AStar算法中可以获得所有豆子的坐标集合

将该坐标集合储存起来

在创建道具时在豆子坐标集合中随机获取一个坐标最为道具创建的位置达到随机创建豆子的目的

  public void SpawnPowerUp()
{
//游戏结束后将不创建道具
if (gameOver)
return;
//使用预制体创建道具
GameObject powerUp = Instantiate(powerUpPrefab);
//道具创建的位置
powerUp.transform.position = walkableList[Random.Range(0,walkableList.Count-1)]-liftBottom;
//道具创建时设置父节点
powerUp.transform.SetParent(powerUpParent.transform);
}

怪物的改变颜色

在游戏控制器中有一个isPowerUp来决定玩家是否得到了PowerUp的道具

//获得道具时
if (GameController.gameController.isPowerUp)
{
//将怪物的颜色设置淡一些
this.GetComponent<SpriteRenderer>().material.color = new Color(0.5f,0.5f,0.8f,1.0f);
}
else
{
//道具失效后怪物的颜色将变为原来的颜色
this.GetComponent<SpriteRenderer>().material.color = Color.white;
}

完成了怪物在玩家吃到道具的时候逃跑

逻辑:

在玩家吃掉道具时,怪物会选择一个角落进行寻路,也是要转到路点移动状态。

选择一个角落时,计算怪物到角落的距离,计算玩家到角落的距离,如果是怪物的距离比较短,就放入候选角落,最后在候选角落里随机选择一个目标点。

实现:

选择角落代码:

    public Vector2 GetEscapeCorner(Vector3 monsterPos)
{
//获得逃跑目标点
List<Vector2> escapable = new List<Vector2>();
for(int i=0;i<v3corners.Length;i++)
{
Vector3 playerPos = playerTrans.position;
float dPlayer = (playerPos - v3corners[i]).magnitude;
float dMonster = (monsterPos - v3corners[i]).magnitude;
if(dMonster<dPlayer)
{
escapable.Add(corners[i].position);
}
}
Vector2 selectCorner = escapable[UnityEngine.Random.Range(0, escapable.Count)];
return selectCorner;
}

怪物内,发现玩家时的状态:

    class SeekState : WaypointState
{
public SeekState(List<Vector2> path): base(path)
{ }
public override void Update(Monster e)
{
if(GameController.instance.isPlayerPowerUp)
{
Vector2 corner = GameController.instance.GetEscapeCorner(e.transform.position);
Vector2 p = GameController.instance.leftBottom;
List<Vector2> path = e.finder.Find((Vector2)e.transform.position-p, corner-p);
for (int i = 0; i < path.Count; i++)
{
path[i] += p;
}
e.stateMaginer.ChangeState(new EscapeState(path));
return;
}
base.Update(e);
}
}

PacMan 04——道具生成吃下道具怪物的移动的更多相关文章

  1. Ubuntu 13.04/CentOS 6.4 下C++开发时的相关设置

    Ubuntu 13.04/CentOS 6.4 下C++开发时的相关设置 一.基本设置 首先,为了可以使我们的c++ 可以找到 iostream类,std标准库,我们需要在C/C++ General- ...

  2. Ubuntu 14.04 AMD 64位 下 Android Studio 的安装

    Ubuntu 14.04 AMD 64位 下 Android Studio 的安装 作者:yoyoyosiyu 邮箱:yoyoyosiyu@163.com 时间:2015年8月25日 Android ...

  3. 在ubuntu16.04+python3.5情况下安装nltk,以及gensim时pip3安装不成功的解决办法

    在ubuntu16.04+python3.5情况下安装nltk,以及gensim时pip3安装不成功的解决办法,我刚开始因为不太会用linux命令,所以一直依赖于python 的pip命令,可是怎么都 ...

  4. js递归生成树形下拉菜单

    需求:我需要把一个单表的数据转换成类似菜单那种如图所示:我呢需要把这个菜单树放入到下框里面去如图所示: 下面是实现思路:1.第一步1.1var afTypeJson=${afTypeJson}// 这 ...

  5. (NO.00004)iOS实现打砖块游戏(十六):导弹发射道具的实现(下)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 上一篇我们完成了导弹道具相关的道具制作,本篇中我们来完成其实现 ...

  6. Ubuntu 16.04 grub rescue 模式下修复 grub

      前几天整理了下电脑的分区,合并并删除一些分区,结果导致 grub 被破坏了,Ubuntu进不去了,启动后直接进入了 rescure 模式.后来又折腾了下,终于修复好了,现总结一下. 先说一下我的系 ...

  7. java动态生成带下拉框的Excel导入模板

    在实际开发中,由于业务需要,常常需要进行Excel导入导出操作.以前做一些简单的导入时,先准备一个模板,再进行导入,单有十几. 二十几个导入模板时,往往要做十几.二十几个模板.而且,当在模板中需要有下 ...

  8. 04、生成 HTMLTestRunner 测试报告

    1.HTMLTestRunner 是 Python 标准库的 unittest 模块的一个扩展.它生成易于使用的 HTML 测试报告 1>下载HTMLTestRunner.py文件,地址为: h ...

  9. ubuntu16.04在GTX1070环境下安装 cuda9.1

    设备要求 系统:Ubuntu16.04 显卡:GTX 1070 驱动:nvidia系列,显卡驱动的版本必须大于等于cuda的sh文件名里面的版本号 驱动可从 此处 下载,我已经整理好了 检查安装驱动 ...

随机推荐

  1. 《MyCat分库分表策略详解》

    在我们的项目发展到一定阶段之后,随着数据量的增大,分库分表就变成了一件非常自然的事情.常见的分库分表方式有两种:客户端模式和服务器模式,这两种的典型代表有sharding-jdbc和MyCat.所谓的 ...

  2. springcloud项目配置拓展从本地config目录加载

    本文受阿里开源的Nacos启发,应用启动后从Nacos服务加载配置到应用中,想着本地开发的时候加载配置能否从本地存储中加载,这样也能加快开发效率 首先我们来看下SpringCloud项目应用Nacos ...

  3. python 29 Socket - 套接字

    目录 Socket - 套接字 Socket - 套接字 应用层与TCP/IP协议族通信层(或传输层)之间的抽象层,是一组接口()接收数据:当接口接收数据之后,交由操作系统: 如果数据与操作系统直接交 ...

  4. Java 前后端分离项目:微人事

    本文适合刚学习完 Java 语言基础的人群,跟着本文可了解和运行项目,本示例是在 Windows 操作系统下演示. 本文作者:HelloGitHub-秦人 大家好!这里是 HelloGitHub 推出 ...

  5. 堆、栈、内存分配、==、equals、hashcode详解(转载)

    问题的引入: 问题一:String str1 = "abc";String str2 = "abc";System.out.println(str1==str2 ...

  6. 《快照读、当前读和MVCC》

    1.快照读 快照读是基于 MVCC 和 undo log 来实现的,适用于简单 select 语句,避免了幻读. 读已提交:一个事务内操作一条数据,可以查询到另一个已提交事务操作同一条数据的最新值.( ...

  7. Linux中JDK安装配置

    安装jdk 1)下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.html 我选择jdk1.8版本 2)上传至服务 ...

  8. ccpc网赛 hdu6705 path(队列模拟 贪心

    http://acm.hdu.edu.cn/showproblem.php?pid=6705 这是比赛前8题过的人数第二少的题,于是就来补了,但感觉并不难啊..(怕不是签到难度 题意:给个图,给几条路 ...

  9. 共价大爷游长沙 lct 维护子树信息

    这个题目的关键就是判断 大爷所有可能会走的路 会不会经过询问的边. 某一条路径经过其中的一条边, 那么2个端点是在这条边的2测的. 现在我们要判断所有的路径是不是都经过 u -> v 我们以u为 ...

  10. HDU - 3966 树链刨分

    题目传送门 操作就是询问某个点的值, 然后就是对一条路径上的值全部修改. 最基本的树刨题目了. 树刨的思想: 1. 对于每个点找到他的重儿子. void dfs1(int o, int u){ sz[ ...