一开始搞这个问题很头疼,无从下手。

    1、敌人在随机地点产生后,每个敌人有要有自己自动的行走路线,目的地是保护地,而且行走路线要多样化。

    2、敌人在看到玩家时,改变行走路线,向玩家的方向行进,且到了一定距离后停下对玩家进行射击。

    3、在玩家躲起来,即敌人无法看到玩家时,敌人要继续按行进路线走到保护地前。

  后来知道了Physics.Linecast "线性投射" 这个方法,从开始位置到结束位置做一个光线投射,如果与碰撞体交互,返回真。

  这样就有一个大体的思路:

    1、给定几个大小位置合适的区域,在这几个区域中随机产生敌人。

    2、在场景中设置20~30个合适的点,作为敌人的行走路线点,确保这些点不是两两可见的(即physics.Linecase值为true)。

    3、end标签作在保护地点上。

    4、下面的方法即为求以start点为起点的敌人的行走路线,road为中间点,way数组为路线。

    void init(){
GameObject temp = start ;
while(start.transform.name!=end.transform.name){
float t = 100f ;
for(int i=; i<road.Length; i++){
if(start==road[i]||road[i].tag!="other") continue ;
if(!Physics.Linecast(start.transform.position, road[i].transform.position)){
float t1 = Vector3.Angle(road[i].transform.position-start.transform.position, end.transform.position-start.transform.position) ;
if(Mathf.Abs(t1)<t){
t = Mathf.Abs(t1) ;
temp = road[i] ;
}
}
}
way[wayCnt++] = temp ;
start = temp ;
}
}

    5、既然求出了以start为起点的敌人的路线,那么就要得到当前敌人以那个点作为start点。

      下面的方法是找出距离当前敌人最近的tag为other的点。

    GameObject FindClosestPoint() {
GameObject[] gos;
gos = GameObject.FindGameObjectsWithTag("other");
GameObject closest = null ;
float distance = Mathf.Infinity;
Vector3 position = transform.position;
foreach (GameObject go in gos) {
Vector3 diff = go.transform.position - position;
float curDistance = diff.sqrMagnitude;
if (curDistance < distance&&!Physics.Linecast(go.transform.position, position)) {
closest = go;
distance = curDistance;
}
}
return closest;
}

    6、有了上面的两个方法,就在这个敌人产生时确定了他的默认行进路线。下面的方法是让其在行进路线上移动。

    void changeRotation(){
if(Vector3.Distance(IgnoreY(transform.position), IgnoreY(nextPoint.transform.position))>0.1f){
Vector3 direction = (IgnoreY(nextPoint.transform.position)-IgnoreY(transform.position)).normalized ;
Quaternion rotation = Quaternion.LookRotation(direction);
transform.rotation = Quaternion.Lerp(transform.rotation, rotation, 0.1f);
charCtl.SimpleMove(transform.forward*) ; }else{
nextPoint = way[index++] ;
}
}

    7、当敌人看到玩家时,也就是Physical.Linecast值为false,且在一定距离内

      即(!Physics.Linecast(man.transform.position, transform.position)&&(man.transform.position - transform.position).sqrMagnitude<1000f)

      敌人要改变行进方向,当到达一定距离时,进行射击。

Vector3 t = man.transform.position - transform.position;
if(!Physics.Linecast(man.transform.position, transform.position)&&t.sqrMagnitude<1000f){
  isLook = true ;
  Vector3 direction = (IgnoreY(man.transform.position)-IgnoreY(transform.position)).normalized ;
  Quaternion rotation = Quaternion.LookRotation(direction);
  transform.rotation = Quaternion.Lerp(transform.rotation, rotation, 0.1f);
  if(t.sqrMagnitude<200f){
    if(Time.time-now>fireStepTime){
      now = Time.time ;
      animation.Play("fire") ;
      Vector3 npos = tran.position ;
//     fireClone = (GameObject)Instantiate(fireObj, npos, transform.localRotation) ;
//     Destroy(fireClone, 0.05f) ;
      Ray ray = new Ray(npos, transform.forward);
      if(Physics.Raycast(ray, out hit)){
        if(hit.transform.tag=="manCon"){
          mainCam.SendMessage("getPlayerDamage", 10f) ;
        }
      }
    }
  }
}

    8、当玩家再次消失在敌人视野中后,敌人要再次找到距离自己最近的点,并作为start点找出行进路线。

  

unity 确定敌人行走路线的更多相关文章

  1. 基于WebGL架构的3D可视化平台—实现小车行走路线演示

    小车行走路线演示New VS Old 刚接触ThingJS的时候,写的一个小车开进小区的演示,今天又看了教程中有movePath这个方法就重新写了一遍,其中也遇到了一些问题,尤其突出的问题就是小车过弯 ...

  2. 最大行走路线问题(DP)

    在一个NxN的棋盘上,每个格子里有若干个棋子,假设起点为左上角的格子,且每次只能向下或向右走一格,问怎样走才能得到最多的棋子. 这是很简单的递推题了. 因为只能向下或者向右,所以其实我们可以把棋盘看成 ...

  3. Unity攻击敌人时产生泛白效果

    Shader的代码如下,主要是将透明度为1的像素点输出为白色,其中_BeAttack表示角色被攻击的泛白状态 // Upgrade NOTE: replaced 'mul(UNITY_MATRIX_M ...

  4. 使用Unity创建塔防游戏(Part2)

    How to Create a Tower Defense Game in Unity – Part 2 原文地址:https://www.raywenderlich.com/107529/unity ...

  5. 使用Unity创建塔防游戏(Part1)

    How to Create a Tower Defense Game in Unity - Part1 原文作者:Barbara Reichart 文章原译:http://www.cnblogs.co ...

  6. 使用unity创建塔防游戏(原译)(part1)

    塔防游戏非常地受欢迎,木有什么能比看着自己的防御毁灭邪恶的入侵者更爽的事了. 在这个包含两部分的教程中,你将使用Unity创建一个塔防游戏. 你将会学到如何: 创建一波一波的敌人 使敌人随着路标移动 ...

  7. 使用Unity创建塔防游戏(Part3)—— 项目总结

    之前我们完成了使用Unity创建塔防游戏这个小项目,在这篇文章里,我们对项目中学习到的知识进行一次总结. Part1的地址:http://www.cnblogs.com/lcxBlog/p/60759 ...

  8. 【iOS】7.4 定位服务->3.2 地图框架MapKit 功能2:路线规划(导航)

    本文并非最终版本,如果想要关注更新或更正的内容请关注文集,联系方式详见文末,如有疏忽和遗漏,欢迎指正. 本文相关目录: ================== 所属文集:[iOS]07 设备工具 === ...

  9. 《Note --- Unreal 4 --- Sample analyze --- StrategyGame(continue...)》

    ---------------------------------------------------------------------------------------------------- ...

随机推荐

  1. CDH5.10 添加kafka服务

    简介: CDH的parcel包中是没有kafka的,kafka被剥离了出来,需要从新下载parcel包安装.或者在线安装,但是在线安装都很慢,这里使用下载parcel包离线安装的方式. PS:kafk ...

  2. python 之 Collections模块

    官方文档:https://yiyibooks.cn/xx/python_352/library/collections.html 参考: https://blog.csdn.net/songfreem ...

  3. OD 实验(十二) - 对一个 Delphi 程序的逆向

    程序: 运行程序 界面显示的是未注册 点击 Help -> About 点击 Use Reg Key 这里输入注册码 用 PEiD 看一下 该程序是用 Delphi 6.0 - 7.0 写的 逆 ...

  4. C++对象数组初始化

    类对象 数组 初始化可以使用构造函数初始化,同时类有不同的构造函数,可以对类对象数组元素使用不同的构造函数;

  5. Newtonsoft.Json(Json.Net)学习

    转自原文 Newtonsoft.Json(Json.Net)学习笔记 Newtonsoft.Json,一款.NET中开源的Json序列化和反序列化类库.软件下载地址: http://www.newto ...

  6. leetcode162

    class Solution { public: int findPeakElement(vector<int>& nums) { int n = nums.size(); ) { ...

  7. javax.persistence.TransactionRequiredException: No transactional EntityManager available

    在操作中加上@Transcational注解,一般是用于修改或者删除操作.

  8. ubuntu 安装 rtpengine

    摘要 RtpEngine推荐使用Debian系统,可以看出Debian系统的安装是最简单的.我是基于ubuntu18.04安装的.需要注意的是如果你的Ubuntu系统版本太低,安装时会遇到各种的版本太 ...

  9. js小功能

    1 删除左右两端的空格 //删除左右两端的空格 function trim(str) { return str.replace(/(^\s*)|(\s*$)/g, ""); } 2 ...

  10. centos7 安装wxPython

    *** exact error that occured. This usually means GTK+ is incorrectly installed.    configure: error: ...