当前位置: 首页 > article >正文

UE_C++ —— Gameplay Tags

目录

一,Defining Gameplay Tags

Adding Tags in Project Settings

Importing Tags from Data Table Assets

Defining Tags with C++

二,Using Defined Gameplay Tags

Applying Tags to Objects

Evaluating Tags with Conditional Functions

三,Advanced Topics

Setting Tag Editing Restrictions

Streamlining Tag Access in C++


        Gameplay Tags 是用户定义的字符串,充当概念性的分层标签;可应用于项目中的对象,并对其求值以驱动你的Gameplay实现,类似于检查布尔值或标记;

可使用它们传达许多不同的概念,包括:

  • 对象的属性,如 Character.Enemy.Zombie
  • 对象在执行或能够执行的事情,如 Movement.Mode.Swimming
  • 游戏事件和触发器,如 GameplayEvent.RequestReset

        Gameplay Tags 有任意数量的分层级别,以 . 字符分隔表示;如,标签 Event.Movement.Dash 有三个级别,其中 Event 是层级中最宽泛的标识符,而 Dash 是最具体的;

一,Defining Gameplay Tags

        必须将Gameplay Tags添加到标签字典,以便虚幻引擎识别它们;可以使用以下某种方法添加(或删除)标签:

  • 直接在 项目设置(Project Settings) 中添加或删除;
  • 从 数据表(Data Table) 资产导入;
  • 使用C++定义;

        以上所有方法都在 项目设置(Project Settings) 的 GameplayTags 分段中下设置;

Adding Tags in Project Settings

        定义新Gameplay Tags的最简单方式是,直接在 项目设置(Project Settings) 中添加;

  • 启用 Import Tags From Config;这会导入 .ini 文件中的所有Gameplay Tags,包括 Config/DefaultGameplayTags.ini 以及 Config/Tags 中的所有标签;
  • (可选)点击 Add new Gameplay Tag source 按钮,在 Config/Tags 中创建新的源 .ini 文件来存储Gameplay Tags;为项目的各个方面创建单独的源文件,可能对于大型项目的组织和协作很有用;
  • 点击 Gameplay Tag List 条目旁边的 Manage Gameplay Tags 按钮;这会打开 GameplayGameplay Tag Manager 窗口;
  • 在 Gameplay Tag Manager 窗口中,点击左上角的 添加(Add (+)) 按钮;
  • 输入所需的 Name 、 Comment 和 Source;Comment显示在标签的提示文本上,Source 是存储标签的 .ini 文件;
  • 点击 Add New Tag 按钮;

        可重命名、删除、复制标签或向其添加新的子标签,方法是在列表中右键点击它并从快捷菜单中选择相应选项;若标签的来源不是 .ini 文件,则不能在 Gameplay Tag Manager 窗口中重命名或删除;

注,可以使用文本编辑器编辑标签 .ini 源文件,但必须重启编辑器才能加载更改;

Importing Tags from Data Table Assets

        可使用行类型 GameplayTagTableRow 从 Data Table 资产导入Gameplay Tags;使用此方法可以:

  • 在 Data Table Editor 中管理标签;
  • 在编辑器运行期间更改数据表;
  • 通过将 .csv 或 .json 文件作为数据表导入来添加标签;

要从数据表导入标签,请在 Project Settings 中执行以下操作:

  • 点击 Gameplay Tag Table List 旁边的 Add Element (+) 按钮;
  • 点击新索引的下拉菜单并选择数据表;
Defining Tags with C++

        可使用 NativeGameplayTags.h 中定义的宏,来通过C++定义Gameplay Tags:

  • UE_DECLARE_GAMEPLAY_TAG_EXTERN :在 .h 文件中用于声明 .cpp 文件中定义的标签;
  • UE_DEFINE_GAMEPLAY_TAG :在 .cpp 文件中用于定义 .h 文件中声明的标签,不带提示文本注释;
  • UE_DEFINE_GAMEPLAY_TAG_COMMENT :在 .cpp 文件中用于定义 .h 文件中声明的标签,带有提示文本注释;
  • UE_DEFINE_GAMEPLAY_TAG_STATIC :在 .cpp 文件中用于定义仅对定义文件可用的标签;不同于其他 DEFINE 宏,这不应该与 DECLARE 宏调用配对;

注,必须将 GameplayTags 模块添加到项目的 Build.cs 文件,才能在C++中访问Gameplay Tags功能;

//Example Implementation
// In .h file
UE_DECLARE_GAMEPLAY_TAG_EXTERN(Movement_Mode_Walking);

// In .cpp file
UE_DEFINE_GAMEPLAY_TAG_COMMENT(Movement_Mode_Walking, "Movement.Mode.Walking", "Default Character movement tag");

二,Using Defined Gameplay Tags

        经过定义后,可将标签应用于对象并对标签求值,以在项目中驱动Gameplay;

Applying Tags to Objects
  • 将 Gameplay Tag Container (FGameplayTagContainer) 类型变量添加到对象;此变量存储多个Gameplay Tags;
  • 使用“添加Gameplay标签”(AddTagAddTag)函数将指定标签添加到容器;

注,可直接使用Gameplay Tag(FGameplayTagFGameplayTagFGameplayTag)类型变量,但对象往往有多个标签,因此经常需要Gameplay Tag Containers;

Evaluating Tags with Conditional Functions

        可基于对象的标签来驱动Gameplay实现;要对存储在对象的Gameplay Tag Containers中的标签求值,可以使用各种条件函数,如:

  • 有标签(HasTag)
  • 有任何标签(HasAny)
  • 有所有标签(HasAll);

        除了 HasAll 之类的 All 函数之外,使用空的Gameplay Tag Containers作为输入参数调用条件函数会返回false;这是因为,容器中的所有标签在源集内都没有缺失;

Gameplay Tag Queries

        Gameplay Tag Query(FGameplayTagQuery)类型变量组合了条件函数,以更直白精简的方式建立复杂逻辑;

Gameplay Tag查询支持以下表达式:

  • Any Tags Match :测试是否能在容器中发现查询中的至少一个标签;
  • All Tags Match :测试查询中的所有标签是否都在容器中;如查询为空,这会返回true;
  • No Tags Match :测试查询中的所有标签是否都不在容器中;如果查询为空,这会返回true;

此外,查询支持基于子表达式求值的以下根表达式:

  • Any Expressions Match :测试是否有任何子表达式返回true;
  • All Expressions Match :测试是否所有子表达式都返回true;如没有子表达式,这会返回true;
  • No Expressions Match :测试是否没有子表达式返回true;如没有子表达式,这会返回true;

三,Advanced Topics

Setting Tag Editing Restrictions

        可限制用户对Gameplay Tag进行编辑(在任意层级级别);

        要限制编辑,请在 Project Settings 的 Advanced Gameplay Tags > Advanced 下进行以下设置:

  • Restricted Config Files:用于存储受限制标签的 .ini 文件列表,这些标签与具有编辑权限的 所有者(Owners) 列表配对;
  • Restricted Tag List :显示 Gameplay Tag Manager 窗口,可在该窗口中修改受限制标签;

        如有用户(非列表中的所有者)尝试编辑受限制的标签,将弹出警告消息,要求用户确认自己已获得所有者的编辑授权;如用户无法确认,则不会做出编辑;

注,受限制的标签在创建之后,不能在编辑器中删除;要删除受限制的标签,必须直接编辑 .ini 文件;

Streamlining Tag Access in C++

        可使用 ​​​​​​​IGameplayTagAssetInterface 改进Gameplay标签实现;该接口提供了以下优势:

  • 不用显式将对象转型就可以获取对象的标签;
  • 可以为每种可能的类型编写自定义代码;

        实现该接口并重载 GetOwnedGameplayTags ​函数,就能创建一种能够被蓝图访问的方法,来为 Gameplay Tag Container 填充与该对象关联的标签;在大部分情况下,这意味着将基类中的标签复制到新容器中,但实现可以从多个容器收集标签,或调用蓝图函数以访问蓝图声明的标签或对象需要的任意内容;


http://www.kler.cn/a/559565.html

相关文章:

  • PyTorch torch.logsumexp 详解:数学原理、应用场景与性能优化(中英双语)
  • Docker 镜像操作笔记
  • Python--函数进阶(上)
  • Python 依赖包管理工具:uv
  • AI(14)-prompt
  • scrapy pipelines过滤重复数据
  • FPGA中利用fifo时钟域转换---慢时钟域转快时钟域
  • 三级分类bug解决
  • YOLOv11-ultralytics-8.3.67部分代码阅读笔记-loaders.py
  • nextjs项目搭建——头部导航
  • 如何使用Python快速开发一个带管理系统界面的网站-解析方案
  • 【DeepSeek-R1背后的技术】系列十一:RAG原理介绍和本地部署(DeepSeek+RAGFlow构建个人知识库)
  • 游戏开发 游戏项目介绍
  • 深入解析浏览器渲染全流程:从URL输入到页面渲染的底层原理与性能优化(附实战代码)
  • seacms V9 SQL报错注入
  • Obsidian·Copilot 插件配置(让AI根据Obsidian笔记内容进行对话)
  • 【GPU驱动】OpenGLES图形管线渲染机制
  • PHP脚本示例
  • 【CSS】---- CSS 变量,实现样式和动画函数复用
  • 一种简单有效的分析qnx+android智能座舱项目中的画面闪烁的方法(8155平台)