Unreal Engine 5 C++: 编辑器工具编写入门(中文解释)

目录

准备工作

1.创建插件

2.修改插件设置

快速资产操作(quick asset action) 自定义编辑器功能

0.创建编辑器button,测试debug message功能

 大致流程

详细步骤

1.ctrl+F5 launch editor

2.创建新的cpp class,derived from AssetActionUtility (如下图)

3.ACCESS HEADER FILE

Header File

Blutility

4.DECLARE A FUNCTION放进编辑器中

UFUNCTION(CallInEditor)

key (-1)

版本bug:editor面板没有Scripted Asset Action...

补充:GEngine

详细解释

1. GEngine 是什么?

2. 常见用途

3. 注意事项

4. 示例代码

总结

待更新

1.add prefix

2.batch duplication

3.remove unused assets

4.create editor message

5.dynamically load other modules to help fix up redirectors from code


准备工作

1.创建插件

插件名字不可修改

2.修改插件设置

.uplugin 是 Unreal Engine 插件的描述文件,它以 JSON 格式存储插件的元数据和配置信息,用于定义插件的基本属性、模块、依赖项以及启用方式。

在.uplugin文件中

  • Type: Runtime是游戏实时使用的插件,Editor是编辑器使用的插件
  • LoadingPhase改成PreDefault,插件会在游戏模块前被加载

ctrl+B编译

快速资产操作(quick asset action) 自定义编辑器功能

we create three custom editor functionalities that could allow us to automatically add prefix to assets, batch duplication, and remove unused assets from selection.我们主要会制作三个编辑器工具:批量添加前缀,批量复制,批量移除无用资产。另外还有创建编辑器信息、修复重定向器

——————————————————————————————————————————

0.创建编辑器button,测试debug message功能

 大致流程

  • 对于actions to assets, 有一个built-in class叫做AssetActionUtility
  • 我们创建一个class,derived from AssetActionUtility
  • 我们创建一个function inside that class,Mark as UFUNCTION(CallInEditor)

详细步骤

1.ctrl+F5 launch editor
2.创建新的cpp class,derived from AssetActionUtility (如下图)
  • 放在新创的插件模块里,name后面可以选择插件模块(我的插件是SuperManager(editor))(不是默认的ExtendEditor(Runtime)模块)
  • class name起名叫做QuickAssetAction,
  • 路径在SuperManager下新建一个AssetAction文件夹。
  • Class type选public,header file will be put into public folder, and cpp file will be in private folder.

3.ACCESS HEADER FILE
Header File

头文件(Header File)是编程中常用的一种文件类型,尤其在 CC++ 语言中尤为重要。它们主要用于声明函数、类、宏、常量和其他编程元素,以便在多个源文件(.c 或 .cpp 文件)之间共享和重用代码。

头文件通常以 .h.hpp 为扩展名,包含了程序中需要共享的声明部分,而具体的实现部分则放在源文件(.cpp)中。通过包含头文件,多个源文件可以访问和使用这些声明,从而实现代码的模块化和组织。

在QuickAssetAction.h里

#include "AssetActionUtility.h"

如果#include下面有red squiggle,means无法access这个 header file,证明这个headerfile在一个我们无法access的module里。

去VS右边的search solution explorer搜索,会找到AssetActionUtility.h在Blutility下

Blutility

"Blutility" 是 Unreal Engine 中的一个功能,是 "Blueprint Utility" 的缩写,专门用于创建可以在编辑器内执行的 Blueprint 工具或功能。它允许开发者通过 Blueprint 脚本创建自定义的编辑器实用工具,从而自动化一些常见的任务,提高工作效率。

去插件的build.cs SuperManager.Build.cs文件里找到PublicDependencyModuleNames.AddRange();部分加入"Blutility"

此时出现identifier"UAssetActionUtility" is undefined.证明还有一些private include path我们需要去include

clear search, 然后去到Blutility.Build.cs文件,会看到一个

PrivateIncludePaths.Add("Editor/Blutility/Private");

by default, anything in private folder, we do not have the access to, unless we add it to this include path.

去插件的build.cs SuperManager.Build.cs文件里找到 PrivateIncludePaths.AddRange();部分加入System.IO.Path.GetFullPath(Target.RelativeEnginePath)+"/Source/Editor/Blutility/Private"(是按private文件层级)

System.IO.Path.GetFullPath(Target.RelativeEnginePath)+"/Source/Editor/Blutility/Private"

depending where your engine is installed, the path for the engine folder varies from computer to computer, System.IO.Path.GetFullPath(Target.RelativeEnginePath) this big chunk simply means engine path.

总结:在SuperManager.Build.cs里加入如下代码↓

		PrivateIncludePaths.AddRange(new string[] {System.IO.Path.GetFullPath(Target.RelativeEnginePath)+"/Source/Editor/Blutility/Private"//"D:\\Epic Games\\UE_5.2\\Engine\\Source\\Editor\\Blutility\\Private"//Path.Combine(Target.RelativeEnginePath, "Source", "Editor", "Blutility", "Private")});PublicDependencyModuleNames.AddRange(new string[]{"Core","Blutility"// ... add other public dependencies that you statically link with here ...});

4.DECLARE A FUNCTION放进编辑器中

在QuickAssetAction.h里,declare a function(如下图),我们就可以在右键时加一个按键。

public:UFUNCTION(CallInEditor)void TestFuckingFunc();
};
UFUNCTION(CallInEditor)
  • UFUNCTION 是 Unreal Engine 的一个宏,用于向 Unreal Engine 的反射系统注册函数。通过这个宏,你可以为函数指定各种属性和功能。

  • CallInEditor 是这个 UFUNCTION 宏中的修饰符,表明该函数可以在 编辑器中 调用。它的作用是在不运行游戏的情况下,在 Unreal Editor 的界面中手动触发该函数。常用于创建在编辑器中帮助开发的功能,如自动化工具、批量处理任务等。

void TestFuckingFunc();

  • 这是一个函数声明,名为 TestFuckingFunc,返回类型为 void(即无返回值)。这个函数没有参数。

5.编写打印debug message的功能

创建DebugHeader.h  (里面声明print和print log两个function,然后QuickAssetAction.cpp里调用这个头文件)省的一直写GEngine

#pragma oncevoid Print(const FString& Message, const FColor& Color)
{if (GEngine){GEngine->AddOnScreenDebugMessage(-1, 8.f, Color, Message);}
}void PrintLog(const FString& Message)
{UE_LOG(LogTemp, Warning, TEXT("%s"),*Message);
}

                                                   8.f是debugMessage显示8秒的意思

6.去QuickAssetAction.cpp里具体实现QuickAssetAction.h声明的这个TestFuckingFunc功能

头文件声明函数,而具体的实现部分则放在源文件(.cpp)中。


#include "AssetAction/QuickAssetAction.h"
#include "DebugHeader.h"void UQuickAssetAction::TestFuckingFunc()
{Print(TEXT("I hate the plugin"), FColor::Cyan);PrintLog(TEXT("杀杀杀"));//if (GEngine) //{//	GEngine->AddOnScreenDebugMessage(-1, 8.f, FColor::Yellow, TEXT("I hate this plugin"));//}
}

key (-1)

// key 为 0 的调试消息
GEngine->AddOnScreenDebugMessage(0, 5.f, FColor::Green, TEXT("Message with key 0"));

// key 为 2 的调试消息
GEngine->AddOnScreenDebugMessage(2, 5.f, FColor::Blue, TEXT("Message with key 2"));

// 再次调用 key 为 0,会替换之前 key 为 0 的消息
GEngine->AddOnScreenDebugMessage(0, 5.f, FColor::Red, TEXT("Updated message with key 0"));

key只会覆盖相同编号的message,which means, 下一个key是-1时就会覆盖它

10.这时候创建一个Blueprint,右键,就可以在Scripted Asset Action里看到自定义的这个TestFuckingFunc

版本bug: 面板没有Scripted Asset Action...(黑字英文为讲师回答)

This is a bug reappearing in versions above 5.2.  To get rid of it, you'll need to create  an AssetActionUtilityBlueprint asset for debugging.(Valid for 5.3 and above)

这是一个在5.2以上版本重复出现的bug,你需要创建一个AssetActionUtilityBlueprint资产用于debug。

1. An AssetActionUtilityBlueprint asset

Go to your plugin's content folder. Very important. Not your project's content folder. 亲测直接在content folder里创建EditorUtilityBlueprint (can rename it EUB_dummy) 并reparent也可以(parent class改为QuickAssetAction)(默认的parent class是Asset Action Utilities)

Right mouse click your content browser, go to EditorUtilities, select EditorUtilityBlueprint , a window will pop out,select AssetActionUtility, then an asset will appear. Double click to open that asset, click file and select reparent blueprint(如下图). In the selection panel, type in the C++ class we created. In my case, it's called QuickAssetAction. Click compile and save, and now you should see ScriptedAssetAction.

2.I can't see new menu entry created after I create a new CallInEditor function in C++(这个bug我没有遇到)

In case you run into this issue as well, you just need to manually open the debug asset we created. Click compile and save again. That should do the trick.

Keep this newly created asset in your plugin's content folder during development. 

补充:GEngine

“GEngine” 通常出现在 Unreal Engine(虚幻引擎) 的 C++ 编程中。它是一个全局指针,指向当前运行的引擎实例,允许开发者在代码中访问引擎的各种功能,比如日志记录、调试信息输出、渲染管理等。

详细解释

1. GEngine 是什么?

在 Unreal Engine 中,GEngine 是一个全局变量,类型为 UEngine*。它提供了一种访问引擎核心功能的便捷方式。通过 GEngine,你可以执行诸如打印调试信息、访问渲染设置、管理游戏状态等操作。

2. 常见用途
  • 打印调试信息: 使用 GEngine 可以在游戏窗口中显示调试信息,这对于调试非常有用。

    if (GEngine)
    {GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("Hello, Unreal!"));
    }//此代码会在游戏屏幕上显示一条持续 5 秒的红色调试信息“Hello, Unreal!”。
    
  • 访问引擎功能: 你可以通过 GEngine 访问引擎的各种子系统,例如渲染、声音、输入等。

    if (GEngine && GEngine->GameViewport)
    {// 例如,获取当前视口大小FVector2D ViewportSize;GEngine->GameViewport->GetViewportSize(ViewportSize);UE_LOG(LogTemp, Log, TEXT("Viewport Size: %f, %f"), ViewportSize.X, ViewportSize.Y);
    }
    
3. 注意事项
  • 空指针检查: 在使用 GEngine 之前,最好检查它是否为 nullptr,以避免潜在的崩溃。

  • if (GEngine)
    {// 安全地使用 GEngine
    }
    
  • if (GEngine)
    {// 安全地使用 GEngineGEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("Hello, Unreal!"));
    }
    else
    {// 处理 GEngine 为 nullptr 的情况UE_LOG(LogTemp, Warning, TEXT("GEngine is not available."));
    }
    

  • 性能考虑: 虽然 GEngine 很有用,但过度依赖全局变量可能会影响代码的可维护性和测试性。尽量在需要的地方使用,并考虑依赖注入或其他设计模式来减少对全局变量的依赖。

  • 仅在适当的上下文中使用GEngine 通常在游戏运行时有效,但在编辑器模式或某些特殊情况下可能不可用。因此,确保在适当的上下文中使用它。

4. 示例代码

以下是一个在角色类中使用 GEngine 打印玩家位置的示例:

#include "GameFramework/Actor.h"
#include "Engine/Engine.h"void AMyCharacter::PrintPlayerLocation()
{if (GEngine){FVector Location = GetActorLocation();FString LocationString = FString::Printf(TEXT("Player Location: X=%f, Y=%f, Z=%f"), Location.X, Location.Y, Location.Z);GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Green, LocationString);}
}//这个函数获取角色的位置并在屏幕上显示出来,持续 5 秒,颜色为绿色。

总结

总结:GEngine 是 Unreal Engine 中一个非常有用的全局指针,允许开发者在 C++ 代码中方便地访问引擎的各种功能。正确使用 GEngine 可以大大简化调试和开发过程,但也要注意其使用场景和潜在的风险。

——————————————————————————————————————————

待更新

1.add prefix

2.batch duplication

3.remove unused assets

4.create editor message

5.dynamically load other modules to help fix up redirectors from code

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

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

相关文章

基于PHP的CRM管理系统源码/客户关系管理CRM系统源码/php源码/附安装教程

源码简介: 这是一款基于PHP开发的CRM管理系统源码,全称客户关系管理CRM系统源码,它是由php源码开发的,还附带了一整套详细的安装教程哦! 功能亮点: 1、公海管理神器:不仅能搞定公海类型&…

【自然语言处理】补充:布尔模型

【自然语言处理】补充:布尔模型 布尔检索是指针对查询的检索,布尔查询是指利用AND,OR或者NOT操作符将词项连接起来的查询,例如:信息AND检索、信息OR检索、信息AND检索AND NOT教材 Google的高级搜索/布尔查询 Google的AND—百度 “ 手机 报价 ”Google的NOT—百度 “ 手机…

关于MATLAB计算3维图的向量夹角总是不正确的问题记录

文章目录 问题描述解决方法完整代码 问题描述 因为最近在做无人机的一个项目,所以需要画出无人机的轨迹,然后再提取特征值,我这里在计算夹角的时候发现为什么在视觉上明明看的是钝角但是实际计算出来却是锐角的角度。 如下图所示&#xff0c…

Spring面试题合集

Spring 1.谈谈你对Spring的理解 首先Spring是一个轻量级的开源框架,为Java程序的开发提供了基础架构支持,简化了应用开发,让开发者专注于开发逻辑; 同时Spring是一个容器,它通过管理Bean的生命周期和依赖注入&#…

无处不在的人工智能

文章目录 引言科幻电影中的AI《她》:人工智能的爱情《我,机器人》:AI的觉醒 人工智能的发展现状专用人工智能的突破通用人工智能的起步 结语 引言 在21世纪的今天,人工智能(AI)已经成为推动社会发展的关键…

英集芯IP5902:集成电压可调异步升压转换充电管理功能的8位MCU芯片

英集芯IP5902是一款集成了9V异步升压转换、锂电池充电管理及负端NMOS管的8-bit MCU芯片,外壳采用了SOP16封装形式,高集成度和丰富的功能使其在应用时只需很少的外围器件,就能有效减小整体方案的尺寸,降低BOM成本,为小型…

dockercompose指定配置文件

dockercompose指定配置文件 文件名字必须是以下的集中形式: docker-compose.yaml docker-compose.yml compose.yaml compose.yml 其他名字就失败的。 一般白眉大叔都是用 compose.yaml 这个格式, 用习惯了。 但是我们必须知道它有几种格式都是可以…

聚焦于 Web 性能指标 TTI

在优化网站性能的过程中,我们经常遇到一个“为指标而优化”的困境。指标并不能真正反映用户体验,而应该最真实地反映用户行为。 在本节中,我们将研究 TTI(Time to Interactive)。在深入探讨这个话题之前,我…

信奥初赛解析:1-3-计算机软件系统

知识要点 软件系统是计算机的灵魂。没有安装软件的计算机称为“裸机”,无法完成任何工作硬件为软件提供运行平台。软件和硬件相互关联,两者之间可以相互转化,互为补充 计算机软件系统按其功能可分为系统软件和应用软件两大类 一、系统软件 系统软件是指…

HTTP中的event-stream,eventsource,SSE,chatgpt,stream request,golang

我们都知道chatgpt是生成式的,因此它返回给客户端的消息也是一段一段的,所以普通的HTTP协议无法满足,当然websocket是能满足的,但是这个是双向的通信,其实 SSE(Server-Sent Events) 正好满足这个…

【操作教程】视频监控系统EasyCVR视频汇聚管理平台如何添加用户和角色?

视频监控平台/视频监控系统EasyCVR视频汇聚管理平台以其强大的拓展性、灵活的部署方式、高性能的视频能力和智能化的分析能力,为各行各业的视频监控需求提供了优秀的解决方案。通过简单的配置和操作,用户可以轻松地进行远程视频监控、存储和查看&#xf…

永磁同步电机谐波抑制算法(8)——基于神经网络的傻瓜式(无需知道谐波频率)谐波抑制

1.简介 前面的内容已经介绍了很多谐波抑制的方法:多同步、PIR、陷波器等等。也介绍了比较多的谐波来源:死区(5、7、11、13等次相电流谐波)、绕组不对称(基波不等幅值、3次相电流谐波)等等。 上述的方法都…

vue3集成google第三方登陆

网上资源很多,但乱七八糟,踩坑几小时后,发现下面的方式没问题。 npm install vue3-google-login 插件文档:vue3-google-登录 (devbaji.github.io) 修改main.js import ./assets/main.css import { createApp } from vue impor…

Dockerfile部署xxljob

使用Dockerfile部署xxljob 1. 背景 我们在使用定时任务调度时,通常会使用xxljob容器化部署xxljob,通常使用 docker pull xuxueli/xxl-job-admin:2.4.0 拉取镜像并启动容器。这种方式对于x86架构服务器来说,没有任何问题。但是在arm架构的服…

结构体、共用体、Makefile

一、结构体 1.1 结构体变量的初始化和赋值的方式 struct Student{int id;char name[32];int score; } struct Student s; s.id 1001; strcpy(s.name,"zhangsan"); s.score 98; struct Student{int id;char name[32];int score; }s; s.id 1001; strcpy(s.name,&…

数据清洗与预处理:从网页中提取的数据处理技术

目录 引言 一、数据清洗与预处理概述 1.1 数据清洗的定义 1.2 数据清洗的重要性 二、数据清洗与预处理的步骤 2.1 数据获取 2.2 数据去重 2.3 缺失值处理 2.4 异常值处理 2.5 数据格式化与标准化 2.6 数据转换与编码 2.7 数据整合与关联 2.8 数据可视化 三、技术…

C++11——function与bind

包装器 function包装器function的介绍function的使用function的使用场景function的意义 bind包装器bind的介绍bind的使用 function包装器 function的介绍 function是用来包装函数的,所以叫做包装器或者适配器,fuction的本质其实是一个类模板。 functio…

基于多域名,通过云运营商弹性负载,Nginx配置等基于的多租户系统部署

已经开发好久的系统,因为业务上没有需求,没有做上线部署,此系统为多租户系统,原来设计是通过租户码参数来识别的,每个租户访问,需要传自己的码过来,才能确定是哪个租户登录系统, 今…

数据结构和算法之树形结构(1)

文章出处: 数据结构和算法之树形结构(1) 关注码农爱刷题,看更多技术文章!! 树形结构是数据结构四种逻辑结构之一,也是被广泛使用的一种逻辑结构,它描述的是数据元素之间一对多的逻辑关系。树是一种非线性的数据结构&a…

SOMEIP_ETS_119: SD_Indicate_wrong_l4proto_param

测试目的: 验证DUT能够拒绝一个引用了带有错误l4proto参数(既不是UDP也不是TCP)的IPv4端点选项的SubscribeEventgroup消息,并以SubscribeEventgroupNAck作为响应。 描述 本测试用例旨在确保DUT遵循SOME/IP协议,当接…