UE側の設定
※ここからはプロジェクトの作成からやっていくので問題ない人はプラグインの導入まで飛ばしてもらって構いません。
新規プロジェクトの作成
まずは新規プロジェクトを作成します。
使用するテンプレートはどれでも構いませんが、プロジェクトの設定でブループリントではなくc++で作成をお願いします。
※今回はモバイルをターゲットとしていますがここも特に関係ないのでなんでもOKです。
data:image/s3,"s3://crabby-images/fc5fc/fc5fc3ada1b417820dce57e91414666a108e8814" alt=""
作成をするとVisualStudioが起動しながらプロジェクトが起動すると思います。
プラグインの導入
プロジェクトが出来たので、まずプラグインを読み込ませます。
プロジェクトとVisualStudioを終了して、先ほど作成したプロジェクトフォルダを開きます。
data:image/s3,"s3://crabby-images/bd3ad/bd3ada6dbcaae811c3f7cd36bdef4d69cc6310b6" alt=""
ここに「Library」フォルダを作成します。
data:image/s3,"s3://crabby-images/28676/28676b510d5cbedda33e9b35c1d7177424f30c1c" alt=""
「Library」フォルダ内に「Zxing」(プラグイン名)フォルダを作成して、
data:image/s3,"s3://crabby-images/8dc56/8dc56641cf812aea16baeee3b32cfa1ff402fcee" alt=""
Zxingをビルドしたときにできた「bin」「Include」「lib」フォルダをコピーします。
(libの中身のCmakeフォルダとbinの中身の.exeは削除してください)
data:image/s3,"s3://crabby-images/25312/25312e7f5a69d1a88a9ca3f6fc4740ce0113dec1" alt=""
↓
data:image/s3,"s3://crabby-images/ce560/ce5607c26605e18d75f3de4ec5ddc022b5d5ae5c" alt=""
コピーが終わったら.uprojectを右クリックして、「その他オプションを表示」(Win11)をクリックして、「Generate Visual Studio project Files」を実行します。
(いらないと思うが念のため)
data:image/s3,"s3://crabby-images/ec1ac/ec1ac23dfd469baaa7c5189e99d486646ef492bf" alt=""
.slnを開いてVisualStudioを起動させます。
ソリューションエクスプローラーから「Game」→「(プロジェクト名)」→「Sorce」→
「(プロジェクト名).build.cs」を開きます。
data:image/s3,"s3://crabby-images/59150/591500bec741fc3abd22fe75829581cd24ba6cc8" alt=""
ここにlibを読み込むプログラムを記載します。
まずはすべての前提となるフォルダまでのパスを取得できるGetを記載します。
/// <summary>
/// LibraryまでのPathを追加する
/// </summary>
private string LibraryPath
{
get { return Path.GetFullPath(Path.Combine(ModuleDirectory, "../../Library/")); }
}
data:image/s3,"s3://crabby-images/eeb3e/eeb3e2e1443d1e9901abe6a1c7111e78c16f72dd" alt=""
次にパスを読み込むプログラムを記載します。
// Zxingのパスを作成
string ZxingLibPath = Path.Combine(LibraryPath, "Zxing");
// Includeフォルダ内のパスを追加
PublicIncludePaths.Add(Path.Combine(ZxingLibPath, "include"));
// ライブラリを追加
PublicAdditionalLibraries.Add(Path.Combine(ZxingLibPath, "lib","ZXing.lib"));
// dllを追加
string ZXingDllName = "ZXing.dll";
string ZXingDllNameDllFullPath = Path.Combine(ZxingLibPath,"bin", ZXingDllName);
PublicDelayLoadDLLs.Add(ZXingDllName);
RuntimeDependencies.Add(ZXingDllNameDllFullPath);
data:image/s3,"s3://crabby-images/5c6f7/5c6f7aa74d942f20cceba6ac8c1c2350e926670d" alt=""
さらにdllのファイルをコピーする処理を追加します。
// Binaries以下にdll をコピーする
private void CopyDll(string dllName, string dllFullPath)
{
if (!File.Exists(dllFullPath))
{
Console.WriteLine("file {0} does not exist", dllName);
return;
}
string binariesDir = Path.Combine(ModuleDirectory, "../../Binaries/Win64/");
if (!Directory.Exists(binariesDir))
{
Directory.CreateDirectory(binariesDir);
}
string binariesDllFullPath = Path.Combine(binariesDir, dllName);
if (File.Exists(binariesDllFullPath))
{
File.SetAttributes(binariesDllFullPath, File.GetAttributes(binariesDllFullPath) & ~FileAttributes.ReadOnly);
}
try
{
File.Copy(dllFullPath, binariesDllFullPath, true);
}
catch (Exception ex)
{
Console.WriteLine("failed to copy file: {0}", dllName);
}
}
これを最後に追加します
string ZXingDllName = "ZXing.dll";
string ZXingDllNameDllFullPath = Path.Combine(ZxingLibPath,"bin", ZXingDllName);
PublicDelayLoadDLLs.Add(ZXingDllName);
RuntimeDependencies.Add(ZXingDllNameDllFullPath);
// コピー
CopyDll(ZXingDllName, ZXingDllNameDllFullPath);
全体像はこんな感じ。
data:image/s3,"s3://crabby-images/b9b92/b9b92e5745f2b07b7ba3c27cb2f97503e45c6f63" alt=""
これでF5を押せばプロジェクトが起動できる(はず)
プロジェクトが起動出来たらC++クラスを追加して実際にデータの読み込みができるか確認してみます。
「ツール」→「新規c++クラス」をクリックします。
data:image/s3,"s3://crabby-images/3252e/3252e5830d53bab8c92a004e901112a9a160a4fd" alt=""
とりあえずテストなのでActorを親クラスとして作成してみましょう。
「Actor」を選択して「次へ」を押します。
data:image/s3,"s3://crabby-images/238c3/238c32f1e1c545de54260c991b712466fe9aa3e2" alt=""
名前は何でもよいので適当につけてください。
その後クラスを作成を押してください。
(今回はTestZxingとしました)
data:image/s3,"s3://crabby-images/a3d47/a3d472a855611c3eef8d027f1e6cdb6175f302a3" alt=""
するとVisualStudio側に新しくcppとhのファイルが追加されると思います。
場合によってはライブコーディングが実行されると思うので、実行された場合は素直に待ちます。
ただ実行されたまま編集するのも面倒なのでいったんVisualStudioの実行を止めて、VisualStudioを終了して、.slnを再起動しましょう。
するとソリューションエクスプローラーに先ほど追加したcppとhが追加されると思います。
data:image/s3,"s3://crabby-images/0f2ad/0f2adbb2feee5307dbc27c4edcf0e3fcaacd71bd" alt=""
これでベースはできたので、次からは実際にブループリントで呼び出しができる関数を作成していきたいと思います。
コメント