ブループリント内で使うためのクラスは UBlueprintFunctionLibrary を継承します。
作成手順
ソースファイルの作成
コンテンツブラウザの右クリックメニューより[New C++ Class] を選択します。
data:image/s3,"s3://crabby-images/90fb7/90fb7ef9ffb0ce6c0614dbaf14ded4c8ea6f0b85" alt=""
[Blueprint Function Library] → [Next] を選択。
data:image/s3,"s3://crabby-images/51eb0/51eb0e1bec69be5533cb7fe082efb187de295afc" alt=""
クラス名を命名し、公開・非公開クラスのいずれかを選択し[Create Class] で作成します。今回は Public クラスとしています。
data:image/s3,"s3://crabby-images/fca5a/fca5a7057ed6a16b06b6ae268070f845daade916" alt=""
data:image/s3,"s3://crabby-images/58248/58248c53949ce98b2f8f0ed592aa0e39c986c4ea" alt=""
ソースコードの編集
生成されたファイルの中身を確認し、ブループリントから呼び出したい関数を定義します。試しに静的関数を追加してみました。
#pragma once
#include "CoreMinimal.h"
#include "Kismet/BlueprintFunctionLibrary.h"
#include "MyBlueprintFunctionLibrary.generated.h"
/**
*
*/
UCLASS()
class MYPROJECT_API UMyBlueprintFunctionLibrary : public UBlueprintFunctionLibrary
{
GENERATED_BODY()
// 追加
UFUNCTION(BlueprintCallable, Category = "MyBlueprintFunctionLibrary")
static void Setup();
};
#include "MyBlueprintFunctionLibrary.h"
// 追加
void UMyBlueprintFunctionLibrary::Setup()
{
UE_LOG(LogTemp, Log, TEXT("called!!!"));
}
ここではSetup という関数を追加しています。内容はただデバッグログを出力するだけのものです。こちらかけたらコンパイルしておきます。
ブループリント で使う
作成したクラスを呼び出してみます。レベルブループリントを開き先ほど作成したクラスの関数(ノード)を検索すると出てきます。
data:image/s3,"s3://crabby-images/f02b4/f02b47b97a0ecb20eab5fa0ab09617c320ff56dd" alt=""
結果
無事に関数が呼び出されました。
data:image/s3,"s3://crabby-images/f6ef3/f6ef3f59ca46ca327ccad9f30189ccbb5a883043" alt=""