导航系统

1.导航系统的简单实现

实现俩个点之间让物体自动移动

效果图


图1-1

1.先创建如图1-1所示场景


图1-2

2.物体层次分布如图1-2所示         设置left与right为图1-3所示


图1-3

3为player.添加Nav Mesh Agent组件设置对应值(图1-4)

图1-4

4.烘焙场景点击Window-》Navigition到达如图1-5所示箭头指向部分全部打钩


图1-5

5.,在点击到Bake界面出现如图1-6所示根据需求设置

图1-6

实现脚本

using UnityEngine;

using System.Collections;

public class playerMove : MonoBehaviour{ 

   public Transform[] targets;//目标  

  NavMeshAgent _Player_agent; 

   int Index = 0; 

   public void Awake()    {        

_Player_agent = GetComponent();

_Player_agent.speed = 4;

}

// Use this for initialization

void Start()

{

_Player_agent.destination = targets[Index].position;//寻路目标

InvokeRepeating("Patrol", 7f, 7f);

}

//巡逻方法

void Patrol()

{

if (_Player_agent.remainingDistance<0.5f)

{

if (Index < targets.Length - 1)

{

Index++;

}

else

{

Index = 0;

}

_Player_agent.destination = targets[Index].position;//寻路目标

}

}

}

6.把脚本挂在Player上在如图1-7所示地方值改为2


图1-7


7.会出现如图1-8所示

图1-8

将lefttager与righttager分别拖进去,表示的是俩个移动目标的点,运行后,物体会在这俩个点之间移动

NavMeshAgent重要属性



图1-9

二.实例二

效果图(图中4个物体会经过不同的路线去对面的高台上在返回到原来的位置通过移动球体可以阻挡物体的移动)


图2-1

1.设置俩快地板为如图2-2所示

图2-2

2.在有高台的那块地板上添加组件off Mesh Link如图2-3移动行俩个空物体的位置(高台与地面跳转的俩个位置)拖进如图中箭头所指位置


图2-3

3.添加烘焙场景点击Window-》Navigition到达如图2-4所示箭头指向部分添加俩个层bridg1与bridg2


图2-4

4.设置俩个桥的Navigation Area(层)分别为bridg1与bridg2如图2-5


图2-5

5.在Nav Mesh Agent 下设置层如图2-6

图2-6


图2-7

6.为球体添加动态阻碍物,添加组件Nav mesh Obstacle如图2-8(通过移动球体的位置可以阻碍物体的移动)

图2-8

7.为物体添加脚本并将俩个位置拖进去

图2-9

代码实现

using UnityEngine;

using System.Collections;

public class play : MonoBehaviour{ 

   public Transform[] _play;  

  NavMeshAgent _nma;

    int Index=0;  

  public void Awake()  

  {       

_nma = GetComponent();

_nma.speed = 4;

}

// Use this for initialization

void Start()

{

_nma.destination = _play[Index].position;

InvokeRepeating("A",7f,7f);

}

void A()

{

if (_nma.remainingDistance<0.5f)

{

if (Index < _play.Length - 1)

{

Index++;

}

else

{

Index = 0;

}

_nma.destination = _play[Index].position;

}

}

// Update is called once per frame

void Update()

{

_nma.destination = _play[Index].position;

}

}

三.实例三

实例图(点击按钮会改变线路,使得桥进行切换,桥的设置如实例二一样,添加俩个层分别使用不同的层)

图3-1

在之前的基础上,就是添加了画线的功能

在脚本挂好如图3-2所示后1与2为俩个位置,3与4为俩个桥


图3-2

如图3-3为物体添加Line Renderer组件如图箭头所指可以改变画出来线的粗细


图3-3

实现代码1

using UnityEngine;

using System.Collections;

public class CubePath : MonoBehaviour{  

  NavMeshAgent _navMeshAg;   

LineRenderer _lineRender;//画线  

  NavMeshPath _NavMeshPath;    //   

 public void Awake()    {       

 _navMeshAg = GetComponent();      

  _lineRender = GetComponent();

_NavMeshPath = new NavMeshPath();

}

void Update()

{

DrawPath();

}

void DrawPath()

{

bool havaPath = _navMeshAg.CalculatePath(_navMeshAg.destination,_NavMeshPath);

if (havaPath)

{

Vector3[] pathCorners = _NavMeshPath.corners;

_lineRender.SetVertexCount(pathCorners.Length + 2);//路径里的拐点不包含起始点

_lineRender.SetPosition(0, transform.position);//起点

 for (int i = 1; i <pathCorners.Length+1; i++)

            {

                _lineRender.SetPosition(i, pathCorners[i - 1]);

            }

            _lineRender.SetPosition(pathCorners.Length+1,_navMeshAg.destination);

        }

    }

}

实现代码2

using UnityEngine;

using System.Collections;

public class CubeMove : MonoBehaviour{ 

   public Transform[] targets; 

   NavMeshAgent _agent;

    float time = 0; 

   public float timeInterVal = 2; 

   int index = 0;  

 public GameObject brige1;

    public GameObject brige2;

    public void Awake()  

  {       

 _agent = GetComponent();

}

void Start()

{

_agent.areaMask = 9;//Walkble brige1

brige2.transform.Rotate(0, 90, 0);

_agent.destination = targets[index].position;

}

void Update()

{

if (_agent.remainingDistance<0.5)

{

time += Time.deltaTime;

if (time>=timeInterVal)

{

time = 0;

index++;

index %= targets.Length;

_agent.destination = targets[index].position;

}

}

}

bool isBrige1_open = true;

bool isBrige2_open = false;

//按钮开关函数

public void Brige1_Open()

{

if (!isBrige1_open)

{

_agent.areaMask = 9;//Walkble brige1

brige1.transform.localRotation = new Quaternion();

brige2.transform.Rotate(0, 90, 0);

isBrige1_open = true;

isBrige2_open = false;

}

}

public void Brige1_Close()

{

if (isBrige1_open)

{

_agent.areaMask = 17;

brige2.transform.localRotation = new Quaternion();

brige1.transform.Rotate(0, 90, 0);

isBrige1_open = false;

isBrige2_open = true;

}

}

public void Brige2_Open()

{

if (!isBrige2_open)

{

Brige1_Close();

}

}

public void Brige2_Close()

{

if (isBrige2_open)

{

Brige1_Open();

}

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • Nav Mesh Agent 自动寻路(添加在移动的物体上) Off Mesh Link分离路面(添加在跳跃的起始...
    胤醚貔貅阅读 265评论 0 0
  • title: 翻译|React-navigation导航系统(2)date: 2017-03-28 07:48:3...
    smartphp阅读 7,917评论 2 23
  • 秋风桂香浓 夜长霜露深 静水浮弦月 风过竹影舞 闲步入寒园 幽思潜入眉 口念如来语 轻吟佛祖经 吾身本性善 也有龌...
    玫瑰圣典CC阅读 130评论 0 0
  • 阅读 喜欢上看书,那是高中时候的事了。刚进高中,不知怎么的,很不适应新环境,也没什么朋友。适逢高中每个学期都有必读...
    高晓松他侄子阅读 309评论 1 5