学んだこと、試したこと、気づいたことをまとめています。
はじめに
構造体
Structure
追記(2022/10/17)
下記の「Struct作成」の方法を使ったことが原因かは分かりませんが、プロジェクトを開けなくなりました。BlueprintFunctionLibraryを使えば、EnumやStructだけでなく関数も定義できるので良ければそちらを使ってください。ソースファイルを削除したりしないので、おそらく安全だと思います。記述の仕方はこの記事で書いてあることと同じです。
1.New C++ Class…を選択。
data:image/s3,"s3://crabby-images/1a440/1a44089894ab136e3765563a54ecbef5e15ae4da" alt=""
2.C++でNoneのクラスを作成する。(Structのクラスはない。)
data:image/s3,"s3://crabby-images/015c4/015c40430c52e59a2822b0955b6c779e76807269" alt=""
3.名前をつけて作成。ここでは名前をGridIndexとしている。ソースファイルは削除する。(エクスプローラーで)。
data:image/s3,"s3://crabby-images/935b0/935b01c1424da09be43a5e2638e273425bff236c" alt=""
data:image/s3,"s3://crabby-images/a77ac/a77acd4db9bdfc0f0676f0e40315b6a2f839bf38" alt=""
4.ヘッダファイルを書き換える。(ここでは2つの整数を宣言した。)
#pragma once
#include "GridIndex.Generated.h"
USTRUCT(BlueprintType)
struct FGridIndex
{
GENERATED_BODY()
UPROPERTY(BlueprintReadWrite)
int32 X = 0;
UPROPERTY(BlueprintReadWrite)
int32 Y = 0;
};
👇UPROPERTYについてはこちらの記事をどうぞ。
調べたこと
data:image/s3,"s3://crabby-images/db878/db8784f743c897318f81e732d4c698951ca90747" alt=""
data:image/s3,"s3://crabby-images/b302d/b302d9e798df8f2326eaaadbf315ea6e6af490b4" alt=""
data:image/s3,"s3://crabby-images/be3c4/be3c495ed487a2cbb947f28f7b8c7f1718e18474" alt=""
data:image/s3,"s3://crabby-images/f679c/f679c042d12b25ea47f40939ec289e00f2a4df95" alt=""
data:image/s3,"s3://crabby-images/ec73e/ec73e2d22e92359c3b11e729073d82b430e5612e" alt=""
data:image/s3,"s3://crabby-images/2f677/2f67748f59f22284965305050d7460aa289b11bf" alt=""
値の設定
記述の型
構造体名.変数名 = 値;
例
FGridIndex Index;
Index.X = 10;
Index.Y = 15;
Structの変数の値を、コンストラクタで変更できるようにする。
ヘッダファイルにおいて、FORCEINLINEを使って記述する。
ここでコンストラクタとは、FGridIndex();というStructと同じ名前の関数のことを指している。
例
コンストラクタに引数を1つ渡すと、XとYの両方に適用。
コンストラクタに引数を値を2つ渡すと、はじめの値はXに、つぎの値はYに適用。
GridIndex.h
#pragma once
#include "GridIndex.Generated.h"
USTRUCT(BlueprintType)
struct FGridIndex
{
GENERATED_BODY()
FORCEINLINE FGridIndex();
explicit FORCEINLINE FGridIndex(int32 InValue);
explicit FORCEINLINE FGridIndex(int32 InX, int32 InY);
UPROPERTY(EditAnywhere, BlueprintReadWrite)
int32 X = 0;
UPROPERTY(EditAnywhere, BlueprintReadWrite)
int32 Y = 0;
};
FORCEINLINE FGridIndex::FGridIndex()
{
}
FORCEINLINE FGridIndex::FGridIndex(const int32 InValue) : X(InValue), Y(InValue)
{
}
FORCEINLINE FGridIndex::FGridIndex(const int32 InX, const int32 InY) : X(InX), Y(InY)
{
}
コンストラクタによる値の設定を使ったBPを作成した。
Structのヘッダファイルのincludeを忘れないように気を付ける。
MyActor.h
#include "GridIndex.h"
UFUNCTION(BlueprintPure, Category = "Actor Functions")
void OutGridIndices(FGridIndex& Index1, FGridIndex& Index2);
MyActor.cpp
void AMyActor::OutGridIndices(FGridIndex& Index1, FGridIndex& Index2)
{
Index1 = FGridIndex(3, 4);
Index2 = FGridIndex(15);
}
data:image/s3,"s3://crabby-images/4189d/4189d6ef53a2b8ce2feec0a9573ad4f15530cd21" alt=""
Structを作成するBPを作成した。
MyActor.h
#include "GridIndex.h"
UFUNCTION(BlueprintPure, Category = "Actor Functions")
FGridIndex MakeGridIndex(int32 InX, int32 InY);
MyActor.cpp
FGridIndex AMyActor::MakeGridIndex(int32 InX, int32 InY)
{
return FGridIndex(InX, InY);
}
data:image/s3,"s3://crabby-images/5b528/5b5287dbf3f506a257b2e2b6b80fbbbba80de936" alt=""
意味:明示的な
発音:eksplísɪt(米国英語)
反意語:implicit 暗黙の
(関連)
explicitな定義
explicit FORCEINLINE FGridIndex(int32 InValue);
implicitな定義
FORCEINLINE FGridIndex(int32 InValue);
implicitではできるが、explicitではできない表現
FGridIndex Index = 4;
上の表現は、次の表現と同じ。
FGridIndex Index = FGridIndex(4);
explicitはコンストラクタを明示的に使う必要がある。
implicitではコンストラクタを省略できる。もちろん省略しなくても大丈夫。
indexの複数形
発音:índəsìːz(米国英語)
2つのStructをOutputするだけのBP。引数2つをimplicitに記述する方法が分からなかった。
GridIndex.h
FORCEINLINE FGridIndex(int32 InValue);
FORCEINLINE FGridIndex(int32 InX, int32 InY);
MyActor.h
#include "GridIndex.h"
UFUNCTION(BlueprintPure, Category = "Actor Functions")
void OutGridIndices(FGridIndex& Index1, FGridIndex& Index2);
MyActor.cpp(引数2つは諦めた。)
void AMyActor::OutGridIndices(FGridIndex& Index1, FGridIndex& Index2)
{
Index1 = FGridIndex(3,4);
Index2 = 15;
}
👇両方とも4が出力。
Index1 = (3,4);
👇両方とも3が出力。
Index1 = 3,4;
UEのC++内では、クラスと同じ名前の変数と認識。BeginPlayより先に処理。
AMyActor::AMyActor()
data:image/s3,"s3://crabby-images/60fa5/60fa50d3e01238858b3b57f9b9dbfd60e9b08bf4" alt=""
演算子の設定
Struct間の演算子を定義する。また、それを用いてBPを作ってみる。
2つの整数が両方とも等しいとき、==だと定義した。
GridIndex.h
struct FGridIndex
{
// 該当箇所以外省略
bool operator==(const FGridIndex& V) const;
};
FORCEINLINE bool FGridIndex::operator==(const FGridIndex& V) const
{
return X == V.X && Y == V.Y;
}
MyActor.h
UFUNCTION(BlueprintPure, Category = "Actor Functions")
bool GridEquals(FGridIndex Index1, FGridIndex Index2);
MyActor.cpp
bool AMyActor::GridEquals(FGridIndex Index1, FGridIndex Index2)
{
if (Index1 == Index2)
{
return true;
}
else
{
return false;
}
}
data:image/s3,"s3://crabby-images/2ee1b/2ee1b33f2f76eaa8fad24bfc8249571f124a37e5" alt=""
2つの整数のうち少なくとも1つが等しくないとき、!=だと定義した。
GridIndex.h
struct FGridIndex
{
// 該当箇所以外省略
bool operator!=(const FGridIndex& V) const;
};
FORCEINLINE bool FGridIndex::operator!=(const FGridIndex& V) const
{
return X != V.X || Y != V.Y;
}
MyActor.h
UFUNCTION(BlueprintPure, Category = "Actor Functions")
bool GridNotEquals(FGridIndex Index1, FGridIndex Index2);
MyActor.cpp
bool AMyActor::GridNotEquals(FGridIndex Index1, FGridIndex Index2)
{
if (Index1 != Index2)
{
return true;
}
else
{
return false;
}
}
data:image/s3,"s3://crabby-images/becbd/becbd3a30b83fb8f809f96241c38a58d956d21e8" alt=""
2種類の整数を、それぞれ足し合わせるように定義した。
GridIndex.h
struct FGridIndex
{
// 該当箇所以外省略
FGridIndex operator+(const FGridIndex& V) const;
};
FORCEINLINE FGridIndex FGridIndex::operator+(const FGridIndex& V) const
{
return FGridIndex(X + V.X, Y + V.Y);
}
MyActor.h
UFUNCTION(BlueprintPure, Category = "Actor Functions")
FGridIndex GridAdd(FGridIndex Index1, FGridIndex Index2);
MyActor.cpp
FGridIndex AMyActor::GridAdd(FGridIndex Index1, FGridIndex Index2)
{
return Index1 + Index2;
}
data:image/s3,"s3://crabby-images/c2f83/c2f8339ac41bdd846eb79ea025f1a4783622933c" alt=""
コンストラクタとStruct間の演算子をしようせずに、減算のBPを作ってみた。
MyActor.h
UFUNCTION(BlueprintPure, Category = "Actor Functions")
FGridIndex GridSubtract(FGridIndex Index1, FGridIndex Index2);
MyActor.cpp
FGridIndex AMyActor::GridSubtract(FGridIndex Index1, FGridIndex Index2)
{
FGridIndex Index;
Index.X = Index1.X - Index2.X;
Index.Y = Index1.Y - Index2.Y;
return Index;
}
このくらい単純な計算の場合、このやり方でも良さそう。
引数の数が増えたり計算量が増えてきたときに、コンストラクタや演算子の設定が役に立つと思う。
data:image/s3,"s3://crabby-images/44be7/44be7998bc4a8b970b11b3d97291ddcfe1eb9eda" alt=""
その他
Ctrl + F:複数選択。
Esc:選択解除。
data:image/s3,"s3://crabby-images/276dd/276dd15d3fa4458098f8be26af75d7deee7cbbe5" alt=""
自作のStructを使っても、とくに問題なくTMapを作れた。
MyActor.h
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "MyActor")
TMap<AMyActor*, FGridIndex> GridMap;
data:image/s3,"s3://crabby-images/0a960/0a9607f949c1555cf5794b3d0b4fe694c4097a0a" alt=""
Wildcardとは繋げた変数に応じて形を変えてくれるピン。自作の構造体はダメみたい。少なくともデフォルトでは。
data:image/s3,"s3://crabby-images/cd806/cd806567762544b56bee7d582f1e1f0d33ebcdc6" alt=""
👇一覧。
data:image/s3,"s3://crabby-images/08fad/08fad32e639dd6c7d9da6d31545b6aefb0868778" alt=""
👇参考動画
data:image/s3,"s3://crabby-images/724c2/724c293308d3cda4e690826eb02363beeb1ccedb" alt=""
Twitterしてます
ブログの更新をお知らせ
コメント