• 您的位置:首頁(yè) > 新聞動態 > UE4

    虛幻UE4如何鏈接第三方庫(lib和dll)

    2018/3/20      點擊:
    摘(zhāi)要:寫這個文章主要是被UE官方的wiki和answerhub誤導了很久,這本來是一個很常見和(hé)基本的問題,但是無論是官(guān)方的wiki或者是論壇上的提問都十(shí)分散亂並且充斥各種錯誤,因(yīn)此記錄下這個在(zài)開發中時常(cháng)遇到的問題。
    在開發中經常遇到的問(wèn)題就是加入某第三方庫的支持,這樣的第三方庫往往屬於無源碼(mǎ),而且可能是靜態lib或者是動態dll甚至兩者皆有。UE4的編譯管理用的是自己的UBT(unreal binary tool)因此鏈接第三方庫的工作主要是編寫UBT腳本。
    1.以插件方式集成.
    基本上這(zhè)個是*推薦的集成第三方(fāng)庫的方式,因為能夠(gòu)很好(hǎo)的隔(gé)離你的代碼和第三方(fāng)代碼的影響,在(zài)UE4的源碼裏也可以看(kàn)到很多(duō)第三方(fāng)庫都是這麽集成的,比如paper2D,leapmotion等等。在UE4中新建插件的方式略去不表,當你新建完你(nǐ)的插件之後,你會在插件的代碼目錄下看到一(yī)個
    xxx.build.cs
    接下來要做的就是修(xiū)改這個腳本:
    得到當前路徑
    1. private string ModulePath
    2. {
    3.    get { return ModuleDirectory; }
    4. }
    關於(yú)第三方庫(kù)放(fàng)的位置(zhì),一般是在plugin的源碼同級文(wén)件夾下建一個ThirdParty文件夾,裏麵放上include lib等(děng)等
    。得到ThirdParty文件夾(jiá)的路徑
    1. private string ThirdPartyPath
    2. {
    3.         get { return Path.GetFullPath(Path.Combine(ModulePath,"../../ThirdParty/")); }
    4. }
    為工程添加include第三方庫的頭文(wén)件路徑
    在模快的構造函數裏加上:
    1. PublicIncludePaths.AddRange(
    2.         new string[] { 
    3.              Path.Combine(ThirdPartyPath, "xxx", "Include"),
    4.         }
    5.         );
    6.             
    7.  
    8. PrivateIncludePaths.AddRange(
    9.         new string[] {
    10.             Path.Combine(ThirdPartyPath, "Foxit", "Include"),
    11.         }
    12.         );
    鏈(liàn)接第三方庫的Lib
    接下來需要在編譯工程時(shí)加(jiā)入(rù)第三方靜態庫的鏈接,靜態鏈接屬於工程在編(biān)譯期間做的事情,因(yīn)此這塊需要通過cs腳本完成(chéng),而dll動態鏈接(jiē)庫(kù)的(de)加載是運行期的事,因此需要在cpp文件中執行。
    我們新建一個叫LoadxxxLib的函數,並把它放在模塊的構造函數結尾執行:
    1. public bool LoadxxxLib(TargetInfo Target)
    2.     {
    3.         bool isLibararySupported = false;
    4.         if ((Target.Platform == UnrealTargetPlatform.Win64) || (Target.Platform == UnrealTargetPlatform.Win32))
    5.         {
    6.             isLibararySupported = true;
    7.             string PlatformString = (Target.Platform == UnrealTargetPlatform.Win64) ? "Win64" : "Win32";
    8.             PublicAdditionalLibraries.Add(Path.Combine(LibraryPath, PlatformString + ".lib"));
    9.             PublicDelayLoadDLLs.Add(PlatformString + ".dll");
    10.             RuntimeDependencies.Add(new RuntimeDependency(LibraryPath + PlatformString + ".dll"));
    11.         }
    12.         return isLibararySupported;
    13.     }

    這樣就可以保證在編譯期鏈接上我們的第三方lib。


    鏈接動態DLL
    這個工作需要在plugin的運行期完成,在插件的source文件下找到一個與插(chā)件名字同名的cpp文(wén)件打開。會看(kàn)到一個StartupModule的函數,我們需要在這裏得到dll文件的handle。

    在StartupModule中(zhōng)添加下麵的代碼:

    1. void FXXXModule::StartupModule()
    2. {
    3. #if PLATFORM_64BITS
    4.     FString platform = TEXT("win64.dll");
    5. #else
    6.     FString platform = TEXT("win32.dll");
    7. #endif
    8.     FString path = IPluginManager::Get().FindPlugin("XXX")->GetBaseDir(); 
    9.     FString dllpath = path + "/ThirdParty/XXX/Lib/" + platform;
    10.     PdfDllHandle = FPlatformProcess::GetDllHandle(*dllpath);
    11.     if (!PdfDllHandle)
    12.     {
    13.         UE_LOG(LogTemp, Warning, TEXT("Failed to load PDF library."));
    14.     }
    15. }
    這裏我們用(yòng)的是PluginManager找到的插件所在的路徑,值得(dé)注(zhù)意(yì)的是(shì)使用這(zhè)個函數時需要在build.cs中(zhōng)加入
    1. PrivateDependencyModuleNames.AddRange(
    2.             new string[]
    3.             {
    4.                 ...
    5.                 "Projects",
    6.             }
    7.             );

    否則工程(chéng)會鏈接出錯。


    日本中出视频|午夜免费福利在线|亚洲精品亚洲人成在线下载|国产高潮流白浆免费观看不卡|偷拍亚洲欧美|亚洲中文字幕久爱亚洲伊人|久久久久香蕉视频|国产欧美日韩一区|久久国产成人亚洲精品影院老金|久久久久中文字幕