Unity3D 打造基于AStar的寻路与导航详解

在游戏开发中,寻路与导航是一个至关重要的功能,它能够使游戏角色自动找到最优路径,避开障碍物,实现自动导航,从而提升游戏体验。AStar(A*)算法作为一种广泛应用的寻路算法,因其高效性和准确性而备受青睐。本文将详细介绍如何在Unity3D中实现基于AStar算法的寻路与导航功能,并提供相关的技术详解和代码实现。

对惹,这里有一个游戏开发交流小组,大家可以点击进来一起交流一下开发经验呀!

技术详解

AStar算法基础

AStar算法是一种启发式搜索算法,它通过评估节点的G值(起点到当前节点的实际代价)、H值(当前节点到终点的估算代价)以及F值(G值和H值的和)来找到从起点到终点的最短路径。其核心思想是通过不断扩展当前最优的路径,直到找到终点。

Unity3D中的实现步骤

在Unity3D中实现AStar算法,大致可以分为以下几个步骤:

  1. 创建地图和节点:首先,在Unity3D中创建一个地图,可以是2D或3D的,然后将地图划分为多个节点。每个节点代表一个可行走的区域,节点之间可以通过连接线相互连接。
  2. 编写节点和地图的脚本:创建一个Node类来表示地图中的每个节点,包含节点的位置、父节点、G值、H值和F值等属性。同时,实现地图网格的表示,可以是二维数组或者更复杂的网格结构。
  3. 实现AStar算法:在Unity中创建一个AStar类,包含AStar算法的核心逻辑,如节点的评估、邻居节点的获取、开放列表和关闭列表的管理等。
  4. 控制角色移动:通过编写脚本来控制游戏角色按照AStar算法计算出的路径进行移动。

代码实现

节点类(Node)

首先,定义一个Node类来表示地图中的每个节点:

csharp复制代码
using UnityEngine;
public class Node
{
public Vector3 position;
public Node parent;
public int gCost;
public int hCost;
public int fCost => gCost + hCost;
public Node(Vector3 pos)
{
position = pos;
}
}

AStar算法类(AStar)

然后,实现AStar算法的逻辑:

csharp复制代码
using System.Collections.Generic;
using UnityEngine;
public class AStar : MonoBehaviour
{
public Transform startNode;
public Transform endNode;
public LayerMask obstacleMask;
public float nodeRadius;
private List<Node> openList = new List<Node>();
private HashSet<Node> closedList = new HashSet<Node>();
public List<Node> FindPath(Vector3 startPos, Vector3 targetPos)
{
Node startNode = new Node(startPos);
Node targetNode = new Node(targetPos);
openList.Add(startNode);
while (openList.Count > 0)
{
Node currentNode = openList[0];
for (int i = 1; i < openList.Count; i++)
{
if (openList[i].fCost < currentNode.fCost || (openList[i].fCost == currentNode.fCost && openList[i].hCost < currentNode.hCost))
{
currentNode = openList[i];
}
}
openList.Remove(currentNode);
closedList.Add(currentNode);
if (currentNode.position == targetPos)
{
return RetracePath(startNode, targetNode);
}
foreach (Node neighbour in GetNeighbours(currentNode))
{
if (!closedList.Contains(neighbour) && !Physics.CheckSphere(neighbour.position, nodeRadius, obstacleMask))
{
int newCostToNeighbour = currentNode.gCost + GetDistance(currentNode, neighbour);
if (newCostToNeighbour < neighbour.gCost || !openList.Contains(neighbour))
{
neighbour.gCost = newCostToNeighbour;
neighbour.hCost = GetDistance(neighbour, targetPos);
neighbour.parent = currentNode;
if (!openList.Contains(neighbour))
{
openList.Add(neighbour);
}
}
}
}
}
return null;
}
private List<Node> RetracePath(Node startNode, Node endNode)

更多教学视频

Unity3D​www.bycwedu.com/promotion_channels/2146264125

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/39765.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于多线程的使用方法

多线程在python中应用比较广泛&#xff0c;但是因为python中有GIL锁的缘故&#xff0c;在多线程中看起来是并发的执行的&#xff0c;在宏观上是并发执行的&#xff0c;但是在微观上是一个接着一个执行。 在python中使用多线程比较简单&#xff0c;是一套固定的模版。 from qu…

PHP利用GD库实现图片合成功能方法

在程序项目开发的过程中我们免不了要实现一种功能。例如海报的生成&#xff0c;照片和文字合成一张新的图片。php中怎么实现 实现功能 文字和照片合成一张新的照片&#xff0c;并且自适应换行并加上签名和日期&#xff0c;加上字体样式&#xff0c;下面我们就开实现该功能 实现…

Seal^_^【送书活动第8期】——《ChatGLM3大模型本地化部署、应用开发与微调》

Seal^_^【送书活动第8期】——《ChatGLM3大模型本地化部署、应用开发与微调》 一、参与方式二、本期推荐图书2.1 作者建语2.2 编辑推建2.3 图书简介2.4 前 言2.5 目 录 三、正版购买 大模型领域 既是繁星点点的未知宇宙&#xff0c;也是蕴含无数可能的广阔天地&#xff0c; 正…

深入理解 Linux 内核架构

目录 引言内核概念Linux 内核的基本组成 进程管理内存管理文件系统设备驱动网络栈内核结构 内核态与用户态内核模块系统调用中断与异常处理内核同步机制Linux 内核使用场景常用的内核命令与工具内核调试与性能优化总结 1. 引言 Linux 内核是现代计算机系统的核心组件之一&am…

python--基础知识点--协程

协程由用户态控制&#xff0c;不由内核控制1个线程中可以开很多协程协程切换是在用户态控制不由内核控制&#xff0c;切换时资源开销小使用方式&#xff1a;async def、await可等待对象(协程对象、Future对象、task对象(是Future对象的子类)->io等待)、事件循环使用场景&…

idea创建自定义的maven spark scala archetype脚手架

一&#xff1a;先创建一个Maven项目net.alchim31.maven&#xff08;选该模板&#xff0c;得要等一会儿才能加载出来&#xff09; 之后将自己的目录结构建立好&#xff0c;最好不要有空目录&#xff0c;可能会因为没有文件在install的时候编译不进去 pom中内容也按照自己的需要改…

Stable Diffusion web UI 插件

2024.7.3更新&#xff0c;持续更新中 如果需要在linux上自己安装sd&#xff0c;参考&#xff1a;stable diffusion linux安装 插件复制到 /stable-diffusion-webui/extensions 目录下&#xff0c;然后重新启动sd即可 一、插件安装方法 每种插件的安装方法可能略有不同&#xf…

苹果p12证书最简单最新申请流程

使用uniapp打包&#xff0c;在ios上打正式包需要苹果的p12证书和证书profile文件&#xff0c;点进去uniapp的ios证书申请教程&#xff0c;通篇就是使用mac电脑申请的教程&#xff0c;假如没有mac电脑就无法继续了。 因此&#xff0c;假如没有mac电脑的同志们&#xff0c;可以参…

高薪程序员必修课-Java中为什么不建议使用Executors来创建线程池?

目录 前言 原因分析 1. newFixedThreadPool 和 newSingleThreadExecutor 示例&#xff1a; 2. newCachedThreadPool 示例&#xff1a; 建议的替代方法 示例&#xff1a; 解释&#xff1a; 总结 前言 在Java中&#xff0c;Executors 类提供了几个工厂方法来创建不同类型…

RAG开源项目Qanything源码阅读3-在线推理

原文&#xff1a;前沿重器[47] | RAG开源项目Qanything源码阅读3-在线推理 项目&#xff1a;https://github.com/netease-youdao/QAnything 第一篇&#xff1a;RAG开源项目Qanything源码阅读1-概述服务 第二篇&#xff1a;RAG开源项目Qanything源码阅读2-离线文件处理 0&#x…

Pytest+Allure+Yaml+PyMsql+Jenkins+Gitlab接口自动化(五)Jenkins配置

一、背景 Jenkins&#xff08;本地宿主机搭建&#xff09; 拉取GitLab(服务器)代码到在Jenkins工作空间本地运行并生成Allure测试报告 二、框架改动点 框架主运行程序需要先注释掉运行代码&#xff08;可不改&#xff0c;如果运行报allure找不到就直接注释掉&#xff09; …

中英双语介绍美国的州:路易斯安那州(Louisiana)

中文版 路易斯安那州简介 路易斯安那州位于美国南部&#xff0c;以其丰富的历史文化、多样的自然景观和独特的音乐和美食传统而闻名。以下是对路易斯安那州的详细介绍&#xff0c;包括其地理位置、人口、经济、教育、文化和主要城市。 地理位置 路易斯安那州东临密西西比州…

鸿蒙应用开发-时间屏幕

点击下载源码&#xff1a; https://download.csdn.net/download/liuhaikang/89509449 做一个时间屏幕&#xff0c;可以点击切换白色和黑色&#xff0c;有渐变效果&#xff0c;使用到了鸿蒙的动画效果。 在这个设计中&#xff0c;我们首先引入了通用能力包&#xff0c;以实现功…

Kubernetes 离线安装的坑我采了

Kubernetes 离线安装的坑我采了 一、Error from server: Get "https://xx.xx.xx.xx:10250/containerLogs/kube-system/calico-node-8dnvs/calico-node": tls: failed to verify certificate: x509: certificate signed by unknown authority二、calico 或 pod 启动正…

cesium公交车轨迹漫游

个人博客&#xff1a;CSDN 博客-满分观察网友 z 演示地址&#xff1a;哔哩哔哩-满分观察网友 z 这是一个用 Cesium.js 做的公交车轨迹漫游&#xff0c;实现的功能有加载站点和道路轨迹点数据、监听车辆的实时位置、车辆控制器。滚动屏等等。 文章目录 1. 地图初始化2. 数据渲…

【高中数学/基本不等式】已知:x,y均为正实数,且xy+2x+y=4 求:x+y的最小值?

【问题】 已知&#xff1a;x,y均为正实数&#xff0c;且xy2xy4 求&#xff1a;xy的最小值&#xff1f; 【来源】 https://www.ixigua.com/7147585275823292942?logTagf25494de7fce23a3a3d0 【解答】 解&#xff1a; 由xy2xy4 两边加二得 xy2xy24 2 分解因式得 (x1)(…

0090__【Git系列】merge和rebase的区别

【Git系列】merge和rebase的区别_rebase和merge的区别-CSDN博客 git中rebase和merge的区别是什么-git-PHP中文网 https://blog.51cto.com/qzcsbj/9444199

从零搭建教育管理系统:Java + Vue.js 教学-02

第三步:创建实体类和 Mapper 接口 现在我们已经设计好了数据库表,接下来使用 MyBatis-Plus 将这些表映射到 Java 对象,以便在代码中轻松地进行操作。 1. 创建实体类 在 src/main/java/<your_package>/entity 目录下 (如果没有该目录,请手动创建),创建与数据库表对应…

MyBatis(20)MyBatis 事务管理如何实现

MyBatis 的事务管理是通过底层 JDBC 连接的事务管理机制来实现的。事务管理对于任何涉及多个数据库操作的应用程序来说都是至关重要的&#xff0c;它确保数据的一致性和完整性。在 MyBatis 中&#xff0c;事务管理可以通过 SQL 会话&#xff08;SqlSession&#xff09;来实现。…

【WEB前端2024】3D智体编程:乔布斯3D纪念馆-第53课-语音指令跳舞

【WEB前端2024】3D智体编程&#xff1a;乔布斯3D纪念馆-第53课-语音指令跳舞 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtns.network是一款主要由JavaScript编写的智体世界引擎&…