60. UE5 RPG 使用场景查询系统(EQS,Environment Query System)实现远程敌人寻找攻击位置

news2025/1/15 18:22:47

UE的Environment Query System(EQS)是环境查询系统,它是UE4和UE5中用于AI决策制定过程中的数据采集和处理的一个强大工具。EQS可以收集场景中相关的数据,利用生成器(Generator)针对用户的测试(Test)去筛选符合用户提出条件的最佳项目(Item)。

EQS允许开发者设置多种查询条件和测试,以评估游戏世界中的对象和环境。它提供了可视化的测试结果,便于开发者调试和优化查询。EQS常用于AI决策制定,如寻找最佳路径、选择攻击目标或找到安全位置等。

EQS的实现原理是将场景环境划分成多个点或按场景元素Actor进行划分,然后按照相应的设定规则对划分项进行打分,最后得分最高的Item即为系统所找到的最优查询结果。EQS将这个最优查询结果告知AI,AI行为树则会对来其进行相应的决策及执行。

接下来,我们要通过EQS去实现远程敌人在于玩家中间有物体遮挡时,将会主动移动到合理的位置,进行攻击。实现这个功能过程,我们将使用到EQS的功能,对敌人周围点进行测试,首先测试出来没有被遮挡的位置,然后测试出比较方便移动的位置。
在这里插入图片描述
如果需要查看官方文档,请前往此处 https://dev.epicgames.com/documentation/zh-cn/unreal-engine/environment-query-system-node-reference-in-unreal-engine?application_version=5.3

创建EQS

接下来,我们先创建对应所需文件,由于AI相关的内容比较多,我们先分好文件夹,将对应的内容放置到对应的文件夹中,接着创建EQS文件夹。
在这里插入图片描述
创建完成后,我们打开EQS文件夹,创建场景查询
在这里插入图片描述
我们将其命名为EQ_FindRangedAttackPosition
在这里插入图片描述
接下来,我们创建一个专门用于测试使用的Pawn,它是系统内置的,方便我们调试使用。
在这里插入图片描述
接下来方便测试,我们创建一个新场景,选择新建关卡
在这里插入图片描述
创建一个基础的关卡
在这里插入图片描述
选择保存关卡
在这里插入图片描述
保存到我们的Map文件夹
在这里插入图片描述
接下来将我们制作的测试Pawn拖入到场景中,它将只显示一个胶囊碰撞体,没有其它内容显示
在这里插入图片描述
我们选中测试Pawn,将我们创建查询模板设置给它
在这里插入图片描述
这样就实现了测试使用的场景,后续我们在查询模板内实现对应的功能,就可以在测试场景里面查看。

添加生成器

我们打开场景查询器,发现里面只有一个根,下拉需要我们添加一个生成器。Generators是用于生成潜在查询目标或位置的核心组件。
在这里插入图片描述

  • Actors Of Class 此类Generator的目的是寻找某一类特定的Actor。你可以指定要寻找的Actor种类,并设置搜索半径等参数来限制搜索范围。
    在这里插入图片描述

  • Composite 复合Generator,允许你将两种或多种不同的Generator组合起来,使它们同时生效。
    在这里插入图片描述

  • Current Location 使用当前位置作为采样点。当前位置可以使用Context进行选取,或是询问者自己,或是Context中返回的内容
    在这里插入图片描述

  • Perceived Actors 通过感知组件去寻找某一类型的Actor,相当于Actors Of Class的扩展版本。
    在这里插入图片描述

  • Points:此类型Generator会在一定的范围内遍历若干个点,并筛选其中满足Test条件的点。

  1. Points Circle 环形生成器。选取方式使用参考点(一般是询问者,或是Context提供的数据)向四周转圈发射射线。如果触碰到任何物体则将碰撞位置作为采样点,如无碰撞则以设定最大半径为采样点。可以设定半径和发射间隔角度
    在这里插入图片描述

  2. Points Cone 锥形生成器
    在这里插入图片描述

  3. Points Donut 环状生成器,区别于Circle,此生成器如同水波,一层一层向外扩散,直到最大半径
    在这里插入图片描述

  4. Points Grid 简单的格子生成器,不对采样点进行路径规则校验,不可达位置也将被收集。收集方式:以参照位置(一般是询问者)为基准,垂直向上向下进行导航投射,如有导航覆盖,则返回采样点。
    在这里插入图片描述

  5. Points Pathing Grid 格子生成器,采样点必须是导航可达,需要满足导航规则校验。收集方式:以参照位置(一般是询问者)为基准,垂直向上向下进行导航投射,如有导航覆盖并且参照位置可达,则返回采样点。
    在这里插入图片描述

我们要实现敌人AI如果攻击目标前方有障碍物阻挡攻击路线时,能够切换位置去攻击,那么,我们将Points Pathing Grid 节点去实现遍历它附近的可导航到的位置点,然后进行攻击。
在这里插入图片描述
参数这里按需要调整
在这里插入图片描述
生成的点的数量影响结果以及效率,所以,需要我们按需去设置合理的参数
在这里插入图片描述

对点进行检测

前面,我们生成了周围的可移动的点,接下来,我们要实现对这些点进行检测,查找出一个最合理的点,让敌人可以移动到目标位置进行攻击。
再生成节点上面,提示我们鼠标右键点击添加测试。
在这里插入图片描述
接下来,我将从官网截图来解释每个测试的功能

  • Distance 距离测试节点,将选择器选取的点用给予和参照内容进行距离测试。距离越远则分值越大,如果希望越近分值越大请调整Score中的Scoring Equation,将线性递增改为递减(Inverse Linear)
    在这里插入图片描述

  • Dot 使用点乘的方式,为选取点打分,值域范围0-1(点乘有负数,打分无负数,正面为1,背面为0,呈现扇形左右递增向1)。也可以对结果进行绝对值设定(勾选Absolute Value,结果为点乘后绝对值值域0-1,正面1,背面1,左右两边0)。点乘中的向量选取可以使用两点方式或是Rotation方式。
    在这里插入图片描述
    在这里插入图片描述

  • Gameplay Tags 使用标签进行询问测试 GamePlay Tags本身是为Actor查询操作提供分层,一般用于查询。
    在这里插入图片描述

  • Overlap 在采样点,使用通道检测方式,返回是否有符合通道标记的内容存在。如存在返回1,反之返回0。检测形状,Box,Sphere,Capsule。用于检测查询某一个点附近是否存在某一样东西。
    在这里插入图片描述
    在这里插入图片描述

  • Pathfinding 将采样点与内容进行导航寻路器测试,可达则分数1,不可达为0。它将用于最终测试点生成,返回一个可达测试点。
    在这里插入图片描述
    在这里插入图片描述

  • Pathfinding Batch 将采样点与内容进行导航寻路器测试,可达则分数1,不可达为0。它会返回所有可达点,供下个测试项目使用。
    在这里插入图片描述
    在这里插入图片描述

  • Project 投射测试。可以用来修正生成器采样点位置。两种模式:导航投射,在采样点为基准,垂直向上向下进行导航检测,碰到导航覆盖点则修正采样点位置。形状检测,不考虑导航,只要在通道碰撞成立,则修正采样点到新的位置。
    在这里插入图片描述
    在这里插入图片描述

  • Trace 射线测试。用来测试采样点,到Context参照点之间是否存在遮挡,这是重要节点,一般可以用来寻找可以用来躲避的采样点(从采样点到敌人之间存在遮挡则认定可以躲避)。存在遮挡分数为1,不存在为0。注意:需要考虑高度问题,采样点一般均在地面,从地面直接发射射线到Context可能会出现被非常矮的物体阻挡,可以通过调整Height Offset解决此问题。
    在这里插入图片描述
    在这里插入图片描述

添加测试

前面我们讲解了每个测试节点的功能,接下来,我们将实现敌人寻找位置的功能。我们需要对所有的点进行检测,首先就是筛选掉那些无法查看到目标的点,然后将点和敌人进行距离判断,获取到一个最近的点,就是敌人需要移动到的攻击点位。
我们先添加一个Trace测试,这个测试用于检查AI是否能够直接看到目标,相当于射线检测。
在这里插入图片描述
在测试目的这里,有三个选项
在这里插入图片描述
它们的功能是筛选和评优先级
在这里插入图片描述
在检测这里,现在我们还是对AI所有者进行检测,被墙壁阻挡的点是无法通过筛选的。
在这里插入图片描述
但是我们需要筛选的目标不是AI持有者,而是玩家目标,引擎内置了两个选项
在这里插入图片描述
所以我们需要自定义一个用于获取玩家目标的,我们创建一个蓝图,继承至EnvQueryContext_BlueprintBase
在这里插入图片描述
将其命名为EQS_PlayerContext
在这里插入图片描述
我们需要重载内置的函数来实现返回,在需要调用时去实现调用
在这里插入图片描述

  • 提供单一位置:将由开发者自己定义一个位置返回。
  • 提供单一Actor:将有开发者提供一个可放置到场景中的对象返回
  • 提供位置集:需要返回一个位置数组
  • 提供Actor集:需要返回一个Actor数组

我们需要的是将玩家角色返回,所以重载提供Actor集
在这里插入图片描述
我们通过GetAllActorsOfClass在场景中寻找指定类的Actor,返回即可。
在这里插入图片描述
设置使用我们的情景
在这里插入图片描述
打开测试场景,发现,有些点被墙壁格挡无法查看到角色
在这里插入图片描述
由于红色才是留下来的点,所以,我们可以选择布尔匹配
在这里插入图片描述
在这里插入图片描述

接下来,我们使用距离测试来获取到最佳的移动点位,设置值评优先级,计算和AI的距离
在这里插入图片描述
我们会发现没有过滤的点上面都有优先级,点越绿,数值越高,优先级也就越高
在这里插入图片描述
所以我们将得分因数修改为-1
在这里插入图片描述
得到了我们理想的位置
在这里插入图片描述

在行为树中实现远程攻击

我们在远程攻击下面添加一个Run EQSQuery
在这里插入图片描述
查询模板设置我们创建的环境检测器,黑板健设置接收数据的健
在这里插入图片描述
然后增加一个MoveTo任务,移动到攻击位置
在这里插入图片描述
接着调用攻击,然后等待,我们就可以测试效果了。
在这里插入图片描述
现在,敌人自动躲避障碍物进行攻击,设置如果其他Actor遮挡了,也能够移动寻找不被躲避的位置。
在这里插入图片描述

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

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

相关文章

身份认证页面该怎么设计更加合理?

一、认证页面的作用 认证页面在应用程序中具有以下几个重要的作用: 验证用户身份:认证页面的主要作用是验证用户的身份。通过要求用户提供正确的凭据(如用户名和密码、生物特征、验证码等),认证页面可以确认用户是合法…

安卓开机启动阶段

目录 概述一、boot_progress_start二、boot_progress_preload_start三、boot_progress_preload_end四、boot_progress_system_run五、boot_progress_pms_start六、boot_progress_pms_system_scan_start七、boot_progress_pms_data_scan_start八、boot_progress_pms_scan_end九、…

Docker(三) 容器管理

1 容器管理概述 Docker 的容器管理可以通过 Docker CLI 命令行工具来完成。Docker 提供了丰富的命令,用于管理容器的创建、启动、停止、删除、暂停、恢复等操作。 以下是一些常用的 Docker 容器命令: 1、docker run:用于创建并启动一个容器。…

ubuntu22.04安装调节显示器亮度工具

1 介绍 软件名叫 DDC/CI control,官网 2 安装方法 sudo apt install intltool i2c-tools libxml2-dev libpci-dev libgtk2.0-dev liblzma-dev3 效果 进入软件,忽略告警信息

selenium 学习笔记(一)

pip的安装 新建一个txt curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py 把上面的代码复制进去后,把后缀名改为.bat然后双击运行 当前目录会出现一个这个文件 然后在命令行pyhon get-pip.py等它下好就可以了selenium安装 需要安装到工程目…

【进程空间】通过页表寻址的过程

文章目录 前言介绍页表、页框、页目录的概念页框页表页目录页表和页目录的分配 一级页表和二级页表一级页表寻址过程 二级页表寻址过程 一级页表和二级页表的对比 前言 我们知道每个进程都有属于自己的虚拟地址空间,且每个进程的虚拟地址都是统一的。要想通过虚拟地…

OrangePi AIpro测评:智能与创新的完美结合

OrangePi AIpro上手指南 简介 香橙派与华为合作发布的香橙派AiPro为Ai主力,为边缘设备的Ai计算提供了可能。 集成图形处理器,拥有8GB/16GB LPDDR4X(我这个是8G内存版本的),可以外接32GB/64GB/128GB/256GB eMMC模块&a…

【从零开始学习RabbitMQ | 第三篇】什么是延迟消息

目录 前言: 延迟消息: 延迟消息实现方式: 死信交换机: 延迟消息插件: 1.基于注解的方式 2.基于Bean的方式 总结: 前言: 在现代软件开发中,异步消息处理已成为构建可扩展、高可…

CR渲染噪点严重怎么办?常见噪点来源+排查方法

使用Corona渲染器进行渲染时,画面出现噪点是常见现象,尤其是在渲染初期。轻微的高频噪点通常是正常的,但如果经过多次渲染或长时间渲染后噪点依然明显,就可能意味着渲染设置或场景本身存在问题。虽然我们可以利用降噪功能模糊噪点…

5G专网驻网失败分析(suci无效)

suci 5G终端第一次驻网时,注册消息Registartion request中携带的5GS mobile identity要携带suci类型的mobile identity。 注册消息协议规范见5G NAS 协议3gpp TS24.501 8.2.6 Registration request。 suci协议规范参见3gpp TS24.501 9.11.3.4 5GS mobile identity …

iOS--工厂设计模式

iOS--工厂设计模式 设计模式的概念和意义类族模式UIButton作为类族模式的例子总结 三种工厂设计模式简单工厂模式(Simple Factory Pattern):代码实例 工厂方法模式(Factory Method Pattern):代码实例 抽象工…

【NumPy】全面解析NumPy的astype函数:高效数据类型转换指南

🧑 博主简介:阿里巴巴嵌入式技术专家,深耕嵌入式人工智能领域,具备多年的嵌入式硬件产品研发管理经验。 📒 博客介绍:分享嵌入式开发领域的相关知识、经验、思考和感悟,欢迎关注。提供嵌入式方向…

Python | Leetcode Python题解之第105题从前序与中序遍历序列构造二叉树

题目: 题解: class Solution:def buildTree(self, preorder: List[int], inorder: List[int]) -> TreeNode:if not preorder:return Noneroot TreeNode(preorder[0])stack [root]inorderIndex 0for i in range(1, len(preorder)):preorderVal pr…

接口性能测试复盘:解决JMeter超时问题的实践

在优化接口并重新投入市场后,我们面临着一项关键任务:确保其在高压环境下稳定运行。于是,我们启动了一轮针对该接口的性能压力测试,利用JMeter工具模拟高负载场景。然而,在测试进行约一分钟之后,频繁出现了…

前端 CSS 经典:水波进度样式

前言&#xff1a;简单实现水波进度样式&#xff0c;简单好看。 效果图&#xff1a; 代码实现&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"utf-8" /><meta http-equiv"X-UA-Compatible" cont…

产线虚拟现实vr仿真软件开发在线上能全面呈现企业品质和专业度

在数字化浪潮中&#xff0c;上海VR全景场景制作公司凭借其领先的VR全景制作技术&#xff0c;正为各行各业带来前所未有的沉浸式体验。无论是学校企业场地的生动展示&#xff0c;还是汽车内饰与外观的360度全景呈现&#xff0c;我们都能通过VR虚拟现实制作技术&#xff0c;让您的…

双击移动硬盘打不开?原因分析与数据恢复全攻略

在日常生活和工作中&#xff0c;移动硬盘作为数据存储和传输的重要工具&#xff0c;扮演着至关重要的角色。然而&#xff0c;当我们遇到双击移动硬盘无法打开的情况时&#xff0c;往往会感到十分困扰。本文将详细探讨双击移动硬盘打不开的原因&#xff0c;并提供两种有效的数据…

(C语言) 泛型表达式

文章目录 ⭐语法⭐举例&#x1f6a9;判断对象类型&#x1f6a9;判断指针&#x1f6a9;函数重载&#x1f6a9;嵌套使用 END ⭐语法 Ref: 泛型选择 (C11 起) - cppreference.com 关键词&#xff1a; Genericdefault _Generic(控制表达式 , 关联列表) (C11 起) 关联列表 类型名:…

floodfill 算法(上)

目录 图像渲染 题意&#xff1a; 题解&#xff1a; 非递归&#xff1a; 递归&#xff1a; 岛屿数量 题解&#xff1a; 非递归&#xff1a; 递归&#xff1a; 岛屿的最大面积 题解&#xff1a; 非递归&#xff1a; 递归&#xff1a; 被围绕的区域 题解&#xff1a…

【加密与解密(第四版)】第十四章笔记

第十四章 漏洞分析技术 14.1 软件漏洞原理 缓冲区溢出漏洞&#xff1a;栈溢出 堆溢出、整型溢出&#xff08;存储溢出、计算溢出、符号问题&#xff09; UAF&#xff08;Use-After-Free&#xff09;漏洞 14.2 ShellCode 功能模块&#xff1a;下载执行、捆绑、反弹shell 14.3 …