UE5.3 虚幻引擎 Windows插件开发打包(带源码插件打包、无源码插件打包) ...

打印 上一主题 下一主题

主题 838|帖子 838|积分 2514

0 引言

   随着项目体量的增大,全部代码功能都放一起很难管理。以是有什么办法可以将大模块划分成一个个小模块吗。固然有,由于虚幻引擎本身就遇到过这个问题,他的办理办法就是使用插件的形式开发。
    例如,一个团队开发了文件I/O模块插件,另一个团队开发了网络模块,那么大家各个模块可以同一的组合,那样虚幻引擎的功能就可以快速状态。
  1 快速入门

1.1 新建插件的前提

   创建插件之前,必须已经有一个UE C++的工程
  1.2 创建插件步调

   

  • 打开【编辑】-【插件】面板

  • 点击左上角【添加】按钮,添加插件。选择空白插件模版,然后设置好插件名称等内容,举行创建。

  • 创建成功后的VS目次如下所示:
    每个文件的内容看文章的第三部分。

   

  • 打开【工具】栏新建C++类,父类选择【蓝图函数库】(相当于C++的全局函数,其他蓝图类可以直接使用)
  


  

  • 选择新建C++类的位置,即是哪个模块的C++类。

   

  • 随后在 UGlobalFunction 类中添加一个静态函数 PrintNumer007(注意,一定要静态函数才行)

  • 这个函数要让蓝图使用必要添加对应的宏 UFUNCTION(BlueprintCallable)

   

  • 编译工程(天生办理方案),测试函数是否可以正常使用。任意在一个蓝图类中右键搜索函数名,可以搜索到就说明功能可以正常使用。

  此时插件的功能就制作完成,只必要打包插件即可。
1.3 打包插件

   

  • 打包插件之间必要在插件的.uplugin做一些配置,确保WhitelistPlatforms是“Win32","Win64”,Type是“Runtime”。

   

  • 打开【编辑】-【插件】面板,点击【包】,举行插件打包。



   

  • 测试打包后的插件可否正常使用(注意:测试的工程一定要与插件编译的版本保持划一,即都是UE4.27版本或者UE5.0版本)
   

  • 将Plugins目次直接拷贝到别的工程下即可
    测试的工程是纯蓝图工程或者C++工程都可以



  2 无源代码的插件制作

   为什么可以不用源码:插件编译后天生了动态库文件,若是删除插件源码的话,就不能再举行编译。以是就不必要让插件编译,bUsePrecompiled = true; 就可以不让插件编译。(就和使用动态库一样,只必要保存头文件,另有动态库文件就可以让别人使用)
    注意:无源码插件是在已经打包好插件的基础上,举行一些修改。然后再将步伐给别人使用。
   

  • 将打包后的插件Source文件夹中的Private文件夹删除

   

  • 必要修改.Build.cs文件内容

   

  • 得到了最终的文件目次,如下所示,我们只必要把插件目次下的文件拷贝到别的UE工程的Plugins文件夹下即可使用插件。

  3 插件详细介绍

3.1 插件的使用方法

   插件有两种使用方法:
  

  • 安装到引擎目次
    你可以将插件直接放到C:\Program Files\Epic Games\UE_5.0\Engine\Plugins\Marketplace目次下,也可以放到这个的上级目次。Marketplace目次一般存放的是虚幻阛阓中下载的插件,我也风俗将本身做的插件放到这个目次,看个人风俗了。

   

  • 安装到工程目次
    如果必要举行工程拷贝的话,将插件安装到工程目次中是最简单的,别人不必要再去引擎中配置一下你工程中的插件。而是可以直接把插件也拷贝过去。
    将插件放到工程的Plugins目次下即可,如果没有该目次则新建一个。

  3.1 UE 预置插件模版

   在UE中新建插件时,有很多 UE 预置的插件模版,如下图所示:

  3.1.1 空白

   

  • 使用少少量的代码创建一个空白插件
  • 如果想要从头开始设置,或创建一个不可见的插件,请选择此模版。用此模板创建的插件将会出如今编辑器的插件列表中,但不会注册任何按钮或菜单输入。
    该模板创建出来,只包罗下面这些最基本的文件。

  3.1.2 纯内容

   

  • 创建一个值包罗内容的空白插件。
  • 这个模板创建出来是真正意义上的空白插件,什么都没有(一般不会用这个模板)。不会天生C++代码。
  3.1.3 编辑器独立窗口

   

  • 创建一个插件,其将在关卡编辑器的工具栏中添加一个按钮;点击按钮可调出一个空白独立选项卡窗口
  • 该插件的代码,如下图所示:内容就多了很多,用于完成按钮点击变乱,另有窗口调用等功能。

  3.1.4 编辑器工具栏按钮

   

  • 创建一个插件,其将在关卡编辑器的工具栏中添加一个按钮。
  • 首先在创建的"OnButtonClick"变乱中实现一些内容
   

  • 插件的代码如图所示:

  3.1.5 编辑器模式

   

  • 创建一个将含有编辑器模式的插件。
  • 其将包罗工具包范例,以指定出如今**“模式”选项卡**(在植物、地形等选项卡旁边)中的UI。其也将包罗最基础的UI,展示编辑器交互和取消/复兴功能的使用。
   

  • 插件的代码如图所示:可以发现代码量增多了。
  • 【注意】必要编译下插件再打开工程才能瞥见插件的UI。

  3.1.6 第三方库

   

  • 创建一个使用已包罗第三方库的插件。
  • 这可用作范例,展示怎样自行包罗、加载和使用第三方库
   

  • 该模版包括了一个测试用的三方库,然后另有怎样使用该三方库的代码

  3.1.7 蓝图库

   

  • 创建一个含有蓝图函数库的插件。
  • 如果创建静态蓝图节点,请选择此模板
   

  • 代码布局如图所示:

  3.2 插件中文件的寄义

   

  • 插件中包罗很多文件夹和文件

  • Binaries:编译后的dll文件存放位置
  • Content:游戏资源Asset文件存放位置
  • Intermediate:编译的中间文件存放位置
  • Resources:一般为图片图标的存放位置
  • Source:代码存放位置
  • .uplugin文件:插件项目配置文件,JSON格式
  • .Build.cs文件:每个 .build.cs 文件声明派生自 ModuleRules 基类的类,并设置属性控制器从构造函数举行编译的方式。由虚幻编译工具编译,并被构造来确定团体编译环境。使用 C# 语法。
  

  • ***.uplugin文件详解
  1. {
  2.         "FileVersion": 3,
  3.         "Version": 1,
  4.         "VersionName": "1.0",
  5.         "FriendlyName": "HHW_PluginTest",
  6.         "Description": "TestPlugin",
  7.         "Category": "Other",                                // 类目名即在插件浏览器中所属的类目
  8.         "CreatedBy": "hhw",
  9.         "CreatedByURL": "",
  10.         "DocsURL": "",
  11.         "MarketplaceURL": "",
  12.         "SupportURL": "",
  13.         "CanContainContent": true,
  14.         "IsBetaVersion": false,
  15.         "IsExperimentalVersion": false,
  16.         "Installed": false,                                        // 默认启用或禁用状态,在插件浏览器中可以控制加载卸载插件模块
  17.         "Modules": [                                                // 描述模块名、运行类型、加载时机、支持平台等信息
  18.                 {
  19.                         "Name": "HHW_PluginTest",
  20.                         "Type": "Runtime",                        // 有多种:Runtime,RuntimeNoCommandlet,Developer,Editor,EditorNoCommandlet,Program
  21.                         "LoadingPhase": "Default",
  22.                         "WhitelistPlatforms": [                // 支持的平台
  23.                                 "Win32",
  24.                                 "Win64"
  25.                         ]
  26.                 }
  27.         ]
  28. }
复制代码

  • ***.Build.cs文件
  1. // Copyright Epic Games, Inc. All Rights Reserved.
  2. using UnrealBuildTool;
  3. public class HHW_PluginTest : ModuleRules
  4. {
  5.         public HHW_PluginTest(ReadOnlyTargetRules Target) : base(Target)
  6.         {
  7.                 PCHUsage = ModuleRules.PCHUsageMode.UseExplicitOrSharedPCHs;
  8.                 // 将bUsePrecompiled设置为true后,就不会让插件编译
  9.                 //bUsePrecompiled = true;
  10.                 //PrecompileForTargets = PrecompileTargetsType.None;
  11.                 PublicIncludePaths.AddRange(
  12.                         new string[] {
  13.                                 // ... add public include paths required here ...
  14.                         }
  15.                         );
  16.                                
  17.                 PrivateIncludePaths.AddRange(
  18.                         new string[] {
  19.                                 // ... add other private include paths required here ...
  20.                         }
  21.                         );
  22.                        
  23.                 PublicDependencyModuleNames.AddRange(
  24.                         new string[]
  25.                         {
  26.                                 "Core",
  27.                                 // ... add other public dependencies that you statically link with here ...
  28.                         }
  29.                         );
  30.                        
  31.                 PrivateDependencyModuleNames.AddRange(
  32.                         new string[]
  33.                         {
  34.                                 "CoreUObject",
  35.                                 "Engine",
  36.                                 "Slate",
  37.                                 "SlateCore",
  38.                                 // ... add private dependencies that you statically link with here ...       
  39.                         }
  40.                         );
  41.                
  42.                 DynamicallyLoadedModuleNames.AddRange(
  43.                         new string[]
  44.                         {
  45.                                 // ... add any modules that your module loads dynamically here ...
  46.                         }
  47.                         );
  48.         }
  49. }
复制代码
4 插件开发常见问题

   

  • 增删代码时,没有更新VistualStudio项目(uproject文件上右键点击Generate Vistual Studio project files可更新重载项目代码)
  • .Build.cs 代码语法错误导致编译错误。
  • .uplugin内容语法错误导致启动失败。
  • 第三方库路径配置错误,导致引入失败,头文件找不到或者链接lib文件失败。
  • 引擎版本与插件版本不划一导致插件模块丢失不能使用。
  • 插件的"Installed": false,或者插件欣赏器中没有启动插件,导致插件模块没有找到。
  • 插件的Module下的"Type"配置与实际项目运行类型不划一。
  • .插件的Module下的"LoadingPhase"配置与项目实际使用插件模块机遇不划一,导致插件模块没有找到。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

祗疼妳一个

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表