UE5.1编辑器拓展【一、脚本化资产行为,通知,弹窗,高效复制多个同样的资产】

目录​​​​​​​

插件制作

添加新的类:AssetActionUtility

添加新的模块:EditorScriptingUtilities

路径了解

添加debug的头文件

代码【debug.h】内涵注释:

写函数

.h文件

.cpp文件


插件制作

首先第一步是做一个插件:

因为是用于编辑器的,所以在模块中我们需要进行更改:

将类型改为Editor,下方的加载则是在默认之前:PreDefault.

添加新的类:AssetActionUtility

AssetActionUtility可以用于创建、删除和重命名资产,以及管理资产的引用关系。

将创建的这个类放入插件中,并命名:

此时此刻我们会发现是编译失败的,那是因为我们缺失了相关的模块。

所以我们对模块进行添加:

在添加了相应的模块之后,我们发现,竟仍然是无法识别头文件的状态:

这种时候,我们就需要去这个模块的build.cs中去查看:

在发现这个路径之后,我们来到我们现在插件的build.cs中去进行添加:

System.IO.Path.GetFullPath(Target.RelativeEnginePath) + "/Source/Editor/Blutility/Private"
System.IO.Path.GetFullPath(Target.RelativeEnginePath)是获取虚幻引擎的相对路径
"/Source/Editor/Blutility/Private"是模块文件的位置

这样就可以编译成功了。

添加新的模块:EditorScriptingUtilities

路径了解

了解一下关于路径的概念:

路径分为两种,分别是Object Path和Package Path.

假设现在有资产a在文件夹test里面:

Object Path的意思就是直接到资产的名字,那么地址就是/Game/test/a

Package Path的意思就是/Game/test/

添加debug的头文件

这个所谓的debug头文件是自己创建的,主要是为了方便使用更多的其他debug函数。

首先要准备3个头文件:

#include "Misc/MessageDialog.h"

这个头文件的作用是弹出对话框的
#include "Framework/Notifications/NotificationManager.h"
#include "Widgets/Notifications/SNotificationList.h"

这两个头文件的作用是弹出通知的

代码【debug.h】内涵注释:

这个并不用cpp文件

#pragma once
#include "Misc/MessageDialog.h"
#include "Framework/Notifications/NotificationManager.h"
#include "Widgets/Notifications/SNotificationList.h"

void DebugPrint(const FString& DebugMessage, const FColor& DebugColor)
{
	//将打印到屏幕上
	if (GEngine)
	{
		GEngine->AddOnScreenDebugMessage(-1, 8, DebugColor, DebugMessage);
	}
}

void DebugPrintLog(const FString& DebugMessage)
{
	UE_LOG(LogTemp, Warning, TEXT("%s"), *DebugMessage);
}
//弹出窗口,返回窗口类型
EAppReturnType::Type ShowMsgDialog(EAppMsgType::Type MsgType, const FString& Message,bool bShowMessageAsWarning=true )
{
	if (bShowMessageAsWarning)
	{
		FText MsgTitle = FText::FromString("!Warning!");
		//第一个输入弹出的窗口类型,第二个是警告信息,第三个是消息标题
		return FMessageDialog::Open(MsgType, FText::FromString(Message), &MsgTitle);
	}
	else
	{
		return FMessageDialog::Open(MsgType, FText::FromString(Message));
	}
}
//消息通知
void ShowNotifyInfo(const FString& Message,float FadeOutTime)
{
	FNotificationInfo NotifyInfo(FText::FromString(Message));
	NotifyInfo.bUseLargeFont = true;//是否用较大粗体显示字体
	NotifyInfo.FadeOutDuration = FadeOutTime;//淡出时间
	//添加通知
	FSlateNotificationManager::Get().AddNotification(NotifyInfo);
}

写函数

在了解了一些基本知识后,我们开始在继承了AssetActionUtility的文件的头文件中写一个复制资产的函数:

.h文件

// Fill out your copyright notice in the Description page of Project Settings.

#pragma once

#include "CoreMinimal.h"
#include "AssetActionUtility.h"
#include "QuicklyAssetAction.generated.h"

/**
 * 
 */
UCLASS()
class CUSTOMEDITOREXTEND_API UQuicklyAssetAction : public UAssetActionUtility
{
	GENERATED_BODY()
public:
	UFUNCTION(CallInEditor)
		void DuplicateAssets(int32 DuplicateNum);
};

然后到cpp文件中进行实现,实现的同时也要包含制作的debug头文件,用于debug:

.cpp文件

// Fill out your copyright notice in the Description page of Project Settings.


#include "AssetAction/QuicklyAssetAction.h"
#include "Debug.h"
#include "EditorUtilityLibrary.h"
#include "EditorAssetLibrary.h"


void UQuicklyAssetAction::DuplicateAssets(int32 DuplicateNum)
{
	if (DuplicateNum<=0)
	{
		ShowMsgDialog(EAppMsgType::Ok, "Please enter a valid value >0", true);
		return;
	}
	//获取选择的资产数据,比如获取的是一个,还是多个资产
	TArray<FAssetData> SelectedAssetsData= UEditorUtilityLibrary::GetSelectedAssetData();
	//用于计数的Counter,复制成功则+1,记录总共复制了多少资产
	uint32 Counter = 0;
	//迭代选择的SelectedAssetsData数组
	for (const FAssetData& SelectedAssetData:SelectedAssetsData)
	{
		//这里迭代的是数组中的一个资产要复制的数量
		for (int32 i = 0; i < DuplicateNum; i++)
		{
			FString SourceAssetPath = SelectedAssetData.ObjectPath.ToString();//获取资产路径【路径名字+资产名字】
			FString NewDuplicatedAssetName = SelectedAssetData.AssetName.ToString()+TEXT("_")+FString::FromInt(i+1);//新复制的资产名字
			FString NewPathName = FPaths::Combine(SelectedAssetData.PackagePath.ToString(), NewDuplicatedAssetName);//将包路径【没有资产名字的路径】和新的名字结合
			//DuplicateAsset输入的两个,第一个是源路径,第二个是目标路径 
			//这里判断是否复制资产是否有效,有效就保存,并且Counter+1
			if (UEditorAssetLibrary::DuplicateAsset(SourceAssetPath, NewPathName))
			{
				//保存资产,输入路径。  第二个输入是bool,为是否为改变后进行保存【而我们要直接保存,所以是false】
				UEditorAssetLibrary::SaveAsset(NewPathName,false);
				Counter++;
			}
		}
	}
	if (Counter>0)//这里是通知有多少资产复制成功了
	{
		ShowNotifyInfo("Duplicate Success:" + FString::FromInt(Counter) + " Files!",7);
	}
}

  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
UE5.1中封装插件并写一个例子,可以按照下面的步骤进行操作: 1. 打开UE5.1编辑器,点击“文件”->“新建项目”,选择“C++基础代码”作为项目类型,填写项目名称和路径,点击“创建项目”。 2. 在新建项目中,打开“插件”->“新建插件”,填写插件名称和路径,点击“创建插件”。 3. 在插件目录下,创建一个名为“Source”的文件夹,并在其中创建一个名为“Public”的文件夹,用于存放插件的公共头文件。 4. 在“Public”文件夹中创建一个名为“PluginName.h”的头文件,用于定义插件的基本信息和接口函数。 5. 在“Source”文件夹中创建一个名为“PluginName.cpp”的源文件,用于实现插件的接口函数和逻辑代码。 6. 在“PluginName.h”头文件中定义插件的基本信息,例如插件名称、版本号、作者等。 7. 在“PluginName.h”头文件中声明插件的接口函数,例如初始函数、卸载函数、执行函数等。 8. 在“PluginName.cpp”源文件中实现插件的接口函数和逻辑代码,例如初始函数中可以进行插件的初始操作,卸载函数中可以进行插件的卸载操作,执行函数中可以实现插件的具体功能。 9. 编译插件,并将生成的插件文件(.dll或.so文件)复制UE5.1编辑器的插件目录中。 10. 在UE5.1编辑器中启用插件,并在编辑器中实现插件的具体功能。 例如,可以创建一个名为“HelloPlugin”的插件,实现一个简单的功能:在编辑器中显示“Hello Plugin!”的消息框。 具体步骤如下: 1. 新建一个C++基础代码项目,命名为“HelloPlugin”。 2. 新建一个插件,命名为“HelloPlugin”,路径为“HelloPlugin/Plugins”。 3. 在“HelloPlugin/Plugins/HelloPlugin/Source”目录下创建一个名为“Public”的文件夹,在其中创建一个名为“HelloPlugin.h”的头文件,代码如下: ``` #pragma once #include "CoreMinimal.h" class FHelloPlugin { public: static void StartupModule(); static void ShutdownModule(); static void SayHello(); }; ``` 4. 在“HelloPlugin/Plugins/HelloPlugin/Source”目录下创建一个名为“HelloPlugin.cpp”的源文件,代码如下: ``` #include "HelloPlugin.h" #include "MessageDialog.h" void FHelloPlugin::StartupModule() { FMessageDialog::Open(EAppMsgType::Ok, FText::FromString("Hello Plugin!")); } void FHelloPlugin::ShutdownModule() { } void FHelloPlugin::SayHello() { FMessageDialog::Open(EAppMsgType::Ok, FText::FromString("Hello Plugin!")); } IMPLEMENT_MODULE(FHelloPlugin, HelloPlugin) ``` 5. 编译插件,并将生成的“HelloPlugin.dll”文件复制UE5.1编辑器的插件目录中。 6. 启用插件,在UE5.1编辑器中打开“插件”->“已启用的插件”,勾选“HelloPlugin”。 7. 在UE5.1编辑器中,点击“蓝图”->“创建基于Actor的类”,创建一个名为“HelloActor”的Actor类。 8. 在“HelloActor”的构造函数中,调用“FHelloPlugin::SayHello()”函数,代码如下: ``` #include "HelloActor.h" #include "HelloPlugin.h" AHelloActor::AHelloActor() { FHelloPlugin::SayHello(); } ``` 9. 编译项目,并在场景中添加一个“HelloActor”实例,可以看到编辑器出“Hello Plugin!”的消息框,说明插件已经成功封装并实现了一个例子。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

多方通行8

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值