unity 确定敌人行走路线
一开始搞这个问题很头疼,无从下手。
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 确定敌人行走路线的更多相关文章
- 基于WebGL架构的3D可视化平台—实现小车行走路线演示
小车行走路线演示New VS Old 刚接触ThingJS的时候,写的一个小车开进小区的演示,今天又看了教程中有movePath这个方法就重新写了一遍,其中也遇到了一些问题,尤其突出的问题就是小车过弯 ...
- 最大行走路线问题(DP)
在一个NxN的棋盘上,每个格子里有若干个棋子,假设起点为左上角的格子,且每次只能向下或向右走一格,问怎样走才能得到最多的棋子. 这是很简单的递推题了. 因为只能向下或者向右,所以其实我们可以把棋盘看成 ...
- Unity攻击敌人时产生泛白效果
Shader的代码如下,主要是将透明度为1的像素点输出为白色,其中_BeAttack表示角色被攻击的泛白状态 // Upgrade NOTE: replaced 'mul(UNITY_MATRIX_M ...
- 使用Unity创建塔防游戏(Part2)
How to Create a Tower Defense Game in Unity – Part 2 原文地址:https://www.raywenderlich.com/107529/unity ...
- 使用Unity创建塔防游戏(Part1)
How to Create a Tower Defense Game in Unity - Part1 原文作者:Barbara Reichart 文章原译:http://www.cnblogs.co ...
- 使用unity创建塔防游戏(原译)(part1)
塔防游戏非常地受欢迎,木有什么能比看着自己的防御毁灭邪恶的入侵者更爽的事了. 在这个包含两部分的教程中,你将使用Unity创建一个塔防游戏. 你将会学到如何: 创建一波一波的敌人 使敌人随着路标移动 ...
- 使用Unity创建塔防游戏(Part3)—— 项目总结
之前我们完成了使用Unity创建塔防游戏这个小项目,在这篇文章里,我们对项目中学习到的知识进行一次总结. Part1的地址:http://www.cnblogs.com/lcxBlog/p/60759 ...
- 【iOS】7.4 定位服务->3.2 地图框架MapKit 功能2:路线规划(导航)
本文并非最终版本,如果想要关注更新或更正的内容请关注文集,联系方式详见文末,如有疏忽和遗漏,欢迎指正. 本文相关目录: ================== 所属文集:[iOS]07 设备工具 === ...
- 《Note --- Unreal 4 --- Sample analyze --- StrategyGame(continue...)》
---------------------------------------------------------------------------------------------------- ...
随机推荐
- c++ 搜索二叉树 插入,删除,遍历操作
搜索二叉树是一种具有良好排序和查找性能的二叉树数据结构,包括多种操作,本篇只介绍插入,排序(遍历),和删除操作,重点是删除操作比较复杂,用到的例子也是本人亲自画的 用到的测试图数据例子 第一.构建节点 ...
- poj-2828 Buy Tickets(经典线段树)
/* Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 10207 Accepted: 4919 Descr ...
- Java toString()方法
JDK API java.lang 的Object类中的toString()方法 toString public String toString() 返回该对象的字符串表示.通常,toString 方 ...
- Linux无法登录,显示module is unknown,一闪而过
1.使用单用户模式登录系统(不作介绍) 2.查看日志:vim /var/log/secure 3.记忆起曾经配置oracle添加过该参数 vim/etc/pam.d/login中加入了: sessio ...
- nginx与tomcat整合
nginx与tomcat整合 1. 在/usr/local/nginx/conf下面添加文件proxy.conf # cat /usr/local/nginx/confg/proxy.conf p ...
- Java Ant Build详解
转载地址:http://www.cnblogs.com/wufengxyz/archive/2011/11/24/2261797.html 1,什么是antant是构建工具2,什么是构建概念到处可查到 ...
- C# List对于自定义对象的比较判断
实际开发中,我们经常会把同类型的一系列对象封装到List集合中,当我们有需要在封装对象到List集合中时,排除重复的对象,这时直接使用: if(!List.Contains(obj)) { List. ...
- LUA和C#关于字符串中\0的处理
LUA中: local s = "hello\0\0dddddddd" print(s) --hello C#中: string s = "hello\0\0dddddd ...
- Java实现主线程等待子线程
本文介绍两种主线程等待子线程的实现方式,以5个子线程来说明: 1.使用Thread的join()方法,join()方法会阻塞主线程继续向下执行. 2.使用Java.util.concurrent中的C ...
- knockout的监控数组实现
knockout应该是博客园群体中使用最广的MVVM框架,但鲜有介绍其监控数组的实现.最近试图升级avalon的监控数组,决定好好研究它一番,看有没有可借鉴之处. ko.observableArray ...