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

news2024/11/15 11:58:22

目录

准备工作

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 once

void 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)
    {
        // 安全地使用 GEngine
        GEngine->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.coloradmin.cn/o/2151396.html

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

相关文章

Linux系统编程(基础指令)上

1.Linux常见目录介绍 Linux目录为树形结构 /:根目录,一般根目录下只存放目录,在Linux下有且只有一个根目录。所有的东西都是从这里开始。当你在终端里输入“/home”,你其实是在告诉电脑,先从/(根目录&…

科研绘图系列:R语言散点图和小提琴图(scatter plot violin plot)

文章目录 介绍加载R包导入数据数据预处理函数画图系统信息介绍 提取模型的结果并对模型的结果进行可视化。 加载R包 library(ggplot2) library(ggridges) library(patchwork) library(party) library(caret) library(dplyr

惠海H6118 DC-DC 降压恒流芯片30V36v40V48V降12V9V24V36V 1.2A大电流 调光降压芯片IC舞台灯

H6118是一款连续电感电流导通模式的降压型LED恒流驱动器,用于驱动一个或多个LED灯串。H6118工作电压从4V到30V,提供可调的输出电流,最大输出电流可达到1.2A。 H6118内置功率开关管,采用高端电流检测电路,支持PWM模式调…

微信小程序拨打电话点取消报错“errMsg“:“makePhoneCall:fail cancel“

问题:微信小程序中拨打电话点取消,控制台报错"errMsg":"makePhoneCall:fail cancel" 解决方法:在后面加上catch就可以解决这个报错 wx.makePhoneCall({phoneNumber: 181********}).catch((e) > {console.log(e) //用…

win10下使用docker、k8s部署java应用

在上一篇文章 Windows10上Docker和Kubernetes的安装 中,已经介绍了在 Windows10上安装Docker和Kubernetes ,有了这个环境基础之后,就可以用来部署服务了 在项目目录下新建Dockfile文件,内容如下(请根据实际情况调整&am…

八股文-多线程、并发

八股文-多线程、并发 最近学到了一种方法,可以用于简历项目经验编写以及面试题目的回答 STAR法则:在什么背景下,你需要解决什么问题,你做了啥,得到了什么结果 情境(Situation): 描…

Python用TOPSIS熵权法重构粮食系统及期刊指标权重多属性决策MCDM研究|附数据代码...

原文链接:https://tecdat.cn/?p37724 在当今世界,粮食系统的稳定性至关重要。尽管现有的全球粮食系统在生产和分配方面表现出较高的效率,但仍存在大量人口遭受饥饿以及诸多粮食安全隐患。与此同时,在学术领域,准确评估…

JDK如何下载源码?

文章目录 JDK如何下载源码?JDK源码介绍下载JDK源码idea配置源码路径 JDK如何下载源码? JDK(Java Development Kit)是开发Java应用程序的基础工具包,包含了编译、运行和调试Java应用程序所需的所有工具。JDK源码主要指…

notepad++的json查看

json文件查看 因为接触到3dtile模型,所以经常需要和json打交道,但是很多模型是下面这种情况,不好阅读,所以可以使用notepad的插件查看 正常打开是这样的 加载notepad插件 搜索json下载安装就可以了 如果网络抽象,下载…

苹果解锁工具iToolab UnlockGo 中文安装版(附教程+补丁) 2024年6月ios17.4.1可用(记得点赞)解压密码请看文章!!! 评论区获取最新链接

UnlockGo 允许您非常轻松地绕过 iPhone 的密码并获得对设备的完全访问权限。它在以下场景中很有用。 在几分钟内删除 iPhone/iPad 上的各种锁定。 解锁 4 位/6 位密码、Touch ID 和 Face ID 删除没有密码的 iCloud 免费锁 无需密码即可从 iPhone/iPad/iPod 中删除 Apple ID…

手写Spring

简单实现Spring基于注解配置 ComponentScan Target(ElementType.TYPE) Retention(RetentionPolicy.RUNTIME) public interface ComponentScan {String value() default ""; } 相当于component-scan HspSpringConfig ComponentScan(value "spring.write.com…

初始泛型【超级详细哦~】

初始泛型【超级详细哦~】 1、包装类1.1 基本数据类型和对应的包装类1.2 装箱和拆箱1.3 自动装箱和拆箱 2、泛型2.1 什么是泛型2.2 泛型的语法2.3泛型的使用2.4 泛型的上界2.4.1 语法2.4.2 示例 1、包装类 1.1 基本数据类型和对应的包装类 1.2 装箱和拆箱 int i10;//装箱操作&a…

聊聊Thread Local Storage

聊聊ThreadLocal 为什么需要Thread Local StorageThread Local Storage的实现PThread库实现操作系统实现GCC __thread关键字实现C11 thread_local实现JAVA ThreadLocal实现 Thread Local Storage 线程局部存储,简称TLS。 为什么需要Thread Local Storage 变量分为全…

元学习的简单示例

代码功能 模型结构:SimpleModel是一个简单的两层全连接神经网络。 元学习过程:在maml_train函数中,每个任务由支持集和查询集组成。模型先在支持集上进行训练,然后在查询集上进行评估,更新元模型参数。 任务生成&…

STM32G431RBT6(蓝桥杯)串口(发送)

一、基础配置 (1) PA9和PA10就是串口对应在单片机上的端口 注意:一定要先选择PA9的TX和PA10的RX,再去打开异步的模式 (2) 二、查看单片机的端口连接至电脑的哪里 (1)此电脑->右击属性 (2)找到端…

AI视觉算法盒是什么?如何智能化升级网络摄像机,守护全方位安全

在智能化浪潮席卷全球的今天,以其创新技术引领行业变革,推出的集高效、智能、灵活于一体的AI视觉算法盒。这款革命性的产品,旨在通过智能化升级传统网络摄像机,为各行各业提供前所未有的安全监控与智能分析能力,让安全…

SpringCloud构建工程

一、新建数据库和表&#xff0c;并填写测试数据 二、创建父级工程 1、创建maven工程 2、工程名字OfficeAutomation 3、pom.xml文件中添加依赖 <properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.encodin…

领域驱动DDD三种架构-分层架构、洋葱架构、六边形架构

博主介绍&#xff1a; 大家好&#xff0c;我是Yuperman&#xff0c;互联网宇宙厂经验&#xff0c;17年医疗健康行业的码拉松奔跑者&#xff0c;曾担任技术专家、架构师、研发总监负责和主导多个应用架构。 技术范围&#xff1a; 目前专注java体系&#xff0c;以及golang、.Net、…

第二十节:学习Redis缓存数据库实现增删改查(自学Spring boot 3.x的第五天)

这节记录下如何使用redis缓存数据库。 第一步&#xff1a; 先在服务器端安装redis&#xff0c; 下载地址&#xff1a;Releases tporadowski/redis GitHub。 第二步&#xff1a; 安装redis客户端可视化管理软件redisDesktopmanager Redis Desktop Manager - Download 第…

GAMES101(13节Ray Tracing)

Ray Tracing 基本原理&#xff1a; 我们知道为什么会看到物体的颜色&#xff0c;因为光线照射物体&#xff0c;未被吸收的光线反射到人眼&#xff0c;因此&#xff0c;我们看到的颜色&#xff0c;就是光的一部分&#xff0c;光线追踪就是模拟这个过程 光线假设&#xff1a; …