UE4開發(fā)插(chā)件流程
1. 直接從(cóng)Editor中生成一個空(kōng)的插件模板
2. 關(guān)掉vs,右鍵生成一下(xià)工程文件,把Plugins掃進去
3. 打開解決方案開始編寫插件
首先把(bǎ)插件的配置文TestPlugin.uplugin件改一下(被這(zhè)個坑(kēng)了兩天)
這個(gè)LoadingPhase的值(zhí)默認為Default,必須修改為PreDefault,不然重啟Editor會報關聯不上(shàng)插件源碼的(de)錯誤(wù),切記!
修改編(biān)譯(yì)模塊配置TestPlugin.Build.cs文件,c#文件
詳細代碼,裏麵有注釋(shì)
using UnrealBuildTool;
using System.IO; //路徑獲取需要用到IO
public class TestPlugin : ModuleRules
{
private string ModulePath //當前TestPlugin.Build.cs文件所在的路徑
{
get { return Path.GetDirectoryName(RulesCompiler.GetModuleFilename(this.GetType().Name)); }
}
private string ThirdPartyPath //這個插件引用的第(dì)三方(fāng)庫的目錄
{
get { return Path.GetFullPath(Path.Combine(ModulePath, "../../ThirdParty/")); }
}
private string MyTestLibPath //第三方庫MyTestLib的(de)目錄(lù)
{
get { return Path.GetFullPath(Path.Combine(ThirdPartyPath, "MyTestLib")); }
}
public TestPlugin(TargetInfo Target)
{
PublicIncludePaths.AddRange( //公有文件搜索路徑
new string[] {
"TestPlugin/Public"
// ... add public include paths required here ...
}
);
PrivateIncludePaths.AddRange(
new string[] {
"TestPlugin/Private" //私有文件搜索路(lù)徑
// ... add other private include paths required here ...
}
);
PublicDependencyModuleNames.AddRange(
new string[]
{
"Core"
// ... add other public dependencies that you statically link with here ...
}
);
PrivateDependencyModuleNames.AddRange(
new string[]
{
"CoreUObject",
"Engine",
"Slate",
"SlateCore",
// ... add private dependencies that you statically link with here ...
}
);
DynamicallyLoadedModuleNames.AddRange(
new string[]
{
// ... add any modules that your module loads dynamically here ...
}
);
LoadThirdPartyLib(Target); //加載第三方庫
}
public bool LoadThirdPartyLib(TargetInfo Target)
{
bool isLibrarySupported = false;
if ((Target.Platform == UnrealTargetPlatform.Win64) || (Target.Platform == UnrealTargetPlatform.Win32))//平台判斷
{
isLibrarySupported = true;
System.Console.WriteLine("----- isLibrarySupported true");
string PlatformSubPath = (Target.Platform == UnrealTargetPlatform.Win64) ? "Win64" : "Win32";
string LibrariesPath = Path.Combine(MyTestLibPath, "Lib");
PublicAdditionalLibraries.Add(Path.Combine(LibrariesPath, PlatformSubPath, "TestLib.lib"));//加載第三(sān)方靜態庫.lib
}
if (isLibrarySupported) //成功加載庫的情況下(xià),包含(hán)第三(sān)方庫的頭文件
{
// Include path
System.Console.WriteLine("----- PublicIncludePaths.Add true");
PublicIncludePaths.Add(Path.Combine(MyTestLibPath, "Include"));
}
return isLibrarySupported;
}
}
寫個自定義(yì)的char – TestChar,繼承自Character
先看下文件結構(gòu),需要藍圖可見的必須丟到Public下
先修(xiū)改預編譯頭文件(jiàn)TestPluginPrivatePCH.h,必須包含CoreUObject,不然編譯不過,切記!
#include "TestPlugin.h"
// UObject core#include "CoreUObject.h" //默認是不含這個的
// Actor based classes
#include "GameFramework/Character.h" //包插件中所有用的的引擎類都丟到這裏來
頭文件,正常編寫自定義的類一樣(yàng)
#pragma once
#include "GameFramework/Character.h"
#include "TestChar.generated.h"
UCLASS()
class ATestChar : public ACharacter
{
GENERATED_BODY()
public:
// Sets default values for this character\'s properties
ATestChar();
UPROPERTY(EditAnywhere, Category = "Test Char")
int32 mAge;
UPROPERTY(EditAnywhere, Category = "Test Char")
FString mName;
};
//cpp文件,包含(hán)的是預(yù)編譯(yì)文件和類(lèi)的頭文(wén)件
#include "TestPluginPrivatePCH.h"
#include "TestChar.h"
#include "TestLib.h" //引入的(de)第三方庫的頭文件
ATestChar::ATestChar() : Super()
{
mAge = myPrint("hello world", 123); //第三方庫中的方法
mName = "yangx";
}
第三方庫打成了一個(gè)靜態庫TestLib.lib
TestLib.h
#ifndef __TEST_LIB_H__
#define __TEST_LIB_H__
#include
#include
int myPrint(std::string _name, int _age);
#endif
//TestLib.cpp
#include "TestLib.h"
int myPrint(std::string _name, int _age)
{
return _age + 1000;
}
4. 編譯運行,在Editor中create一個(gè)Blueprint繼承自這個TestChar類
5. 拖到場景運行遊戲
- 上一篇:使用HTC VIVE和WISEGLOVE的VR技術實現火災現(xiàn) 2017/7/6
- 下一(yī)篇:HoloLens 開發簡要教程(Unity3d+VS2015 2017/6/29
