data:image/s3,"s3://crabby-images/c6bf4/c6bf4656e1f117160033f0e3e3ab054194ba740d" alt="見出し画像"
UE5 C++&BP 04【Blueprint版】Componentを追加する
Unreal Engine 5から始める C++ & Blueprint執筆のために朝活続いています。
やはり目標が決まると、朝起きる力がもらえます。
寒さに負けない!
公開するまでに何を書けばいいか、頭の中にあるロードマップをGitHubに書き起こしました。
基本文法のタスクがすべて「Shipped Zenn Book」に移動すれば公開です。
data:image/s3,"s3://crabby-images/287cc/287ccc92aaa6c4a1d95f8ff6b12f08179ecd50d0" alt=""
Zennに進捗報告をするScrapを作成しました。
逐一、出来上がったところまで報告します。
前回は「変数を作成して取得・設定する」方法について調査しました。
今回は「Componentを追加する」方法について調査していきます。
【Blueprint版】Componentを追加する
学習用の新規レベル「Chapter_2_5_Component」を作成する
学習用の新規レベルを作成します。
[File]から[New Level…]を選択します。
data:image/s3,"s3://crabby-images/d5a41/d5a417e101e373db92d5775512b46fe3b0f573e9" alt=""
[Default]を選択します。
data:image/s3,"s3://crabby-images/d9cd8/d9cd87585a248d0e82942cf2198467d87d0bd14e" alt=""
「Maps」フォルダに「Chapter_2_5_Component」を入力し、[Save]ボタンをクリックします。
data:image/s3,"s3://crabby-images/2698a/2698ad4fdd5bd230390dbb3b49e5db26d1501abe" alt=""
Engine ContentからStaticMeshとMaterialをコピーする
「Engine Content」に入っているStaticMeshをプロジェクトフォルダにコピーして使用します。
[Content Browser]の[Settings]ボタンをクリックし、[Show Engine Content]を有効にします。
data:image/s3,"s3://crabby-images/d2363/d23639d5c7530d7b54a54c965ecebe840d100756" alt=""
[Show Engine Content]を有効にすると[Content Browser]が表示されます。
「Engine Content」から「StaticMesh」と「Material」をコピーするので、「CPP_BP」に「Materials」、「Meshes」フォルダを作成します。
data:image/s3,"s3://crabby-images/038d2/038d2a02bb02cceac36f780952f4eb633fd242cf" alt=""
「Engine Content」の「BasicShaps」フォルダに移動します。
「BasicShaps」フォルダには、PlaceActorからDrag&DropでViewportに追加することが出来るプリミティブのメッシュが格納されています。
data:image/s3,"s3://crabby-images/3b156/3b1561bd2b42d1436accc7f50adcc9a12a004f8a" alt=""
[Engine Content]を直接変更してしまうと、他のプロジェクトでEngine Contentを使用している箇所にも影響してしまいます。
[Engine Content]のStaticMesh「Cube」を先ほど作成した「Meshes」フォルダにコピーします。
data:image/s3,"s3://crabby-images/2fc9d/2fc9db717eee47a219565aa770bfc52af123d883" alt=""
「Meshes」フォルダに「Cube」がコピーされました。
名前を「SM_SampleCube」に変更します。
data:image/s3,"s3://crabby-images/5bb6a/5bb6a4f7b6de7c80cfc67f4aeb7ebcf0b6e75313" alt=""
「SM_SampleCube」の質感を設定するためのMaterial「BasicShapeMaterial」を「Materials」フォルダにコピーします。
「BasicShapesフォルダ」の「BasicShapeMaterial」を「Materials」フォルダにDrag&Drop > [Copy Here]を選択
data:image/s3,"s3://crabby-images/19b8a/19b8a5689e47c82ccb3298c85d51926096d5786e" alt=""
> [Copy Here]を選択
「Materials」フォルダに「BasicShapeMaterial」がコピーされます。
名前を「M_SampleMaterial」に変更します。
data:image/s3,"s3://crabby-images/4024d/4024de8dcbaaf2ef631a67fb8ac442cf6959c3de" alt=""
「Meshes」フォルダの「SM_SampleCube」をダブルクリックしてStaticMesh Editorを開きます。
data:image/s3,"s3://crabby-images/c2f5a/c2f5a08ccb31f7d32dcdc7164c2c3d69beb21825" alt=""
StaticMesh Editorの[Detil]パネルでMaterialを「M_SampleMaterial」に設定します。
data:image/s3,"s3://crabby-images/7db26/7db26a1f3e73f91462322d9e5b8623c380ede8dd" alt=""
Cubeの質感が、「M_SampleMaterial」で設定している白い色に変わります。[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/3d888/3d8885b6f6229e52e542c812635c51325d38946a" alt=""
Content Browserの「SM_SampleCube」のサムネイルも「M_SampleCube」の質感が反映されました。
data:image/s3,"s3://crabby-images/e6b06/e6b067b26aa60d52d194970c85f5d791f3e59c6d" alt=""
StaticMeshComponentを追加する
「Component(コンポーネント)」を追加します。
UnrealEngineのComponentは「Actor(俳優)」の「Component(部品、構成要素)」といった意味です。レベルに配置することが出来るBlueprintの構成要素を組み込みます。
「BP_SampleActor」をダブルクリックしてBlueprint Editorを開きます。
data:image/s3,"s3://crabby-images/4c704/4c7041299eecb0023ee7ed716523657ff4e21186" alt=""
「Component」は「Viewport」タブで確認しながら、「Component」パネルからコンポーネント追加・設定します。
data:image/s3,"s3://crabby-images/c89cb/c89cb7d9b6e3ce6454fe4feba83510bfbc138d17" alt=""
[Static Mesh Component]を追加します。
[Component]パネルの[Add]ボタンから[Static Mesh]を選択します。
data:image/s3,"s3://crabby-images/7db67/7db67789eaa9fee2cc015c30c7ee1f2b24719971" alt=""
[Component]パネルに[StaticMesh]が追加されます。
[StaticMesh]Componentの[Detail]パネルから先ほど準備した「SM_SampleCube」を設定します。
data:image/s3,"s3://crabby-images/a6379/a63797b0511dfa33ba2b0ea20341ae469025b721" alt=""
[Detail]パネルの[StaticMesh]のリストをクリックし、「SM_SampleCube」を検索して選択します。
data:image/s3,"s3://crabby-images/56683/56683a38848ebe1e8b5ab879a86b738aa5d8eff3" alt=""
Viewportタブに「SM_SampleCube」が表示されます。
[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/42255/422555dbbbb8ffa36056d0801734c777581c9c40" alt=""
Level Editorに戻り、「BP_SampleActor」をDrag&Dropします。
Viewportで確認したStaticMeshComponentが表示されます。
コントローラーのアイコンが表示されているActorの水色の矢印の先に移動させます。
コントローラのアイコンはPlayerStartというPlayした時にプレイヤーの開始位置になります。水色の矢印はPlay開始時にプレイヤーの向いている方向です。
data:image/s3,"s3://crabby-images/f23ce/f23cee703a1e0a6eda3f6a136b73915e32422bae" alt=""
[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/9affc/9affcaba0a27babcd268c3269aa73e4351c4547f" alt=""
SM_SampleMeshが表示されます。
data:image/s3,"s3://crabby-images/f527f/f527fa5dd7f026e86ee2313f11414e92e54df664" alt=""
ArrowComponentを追加する
「Cube」は前後左右が分からないので、方向を表示する「ArrowComponent」を追加します。
「BP_SampleActor」をダブルクリックしてBlueprint Editorを開きます。
data:image/s3,"s3://crabby-images/e88a6/e88a678cfad55a4f732179d764dfa1588a513a23" alt=""
[Component]パネルの[Add]ボタンをクリックし、[Arrow]で検索し、[Arrow]を選択します。
data:image/s3,"s3://crabby-images/aa694/aa6948540c6466658ca1fc9bc816e266b83fbf4a" alt=""
Viewportタブを確認すると、赤い矢印が表示されます。
data:image/s3,"s3://crabby-images/303ab/303abdb5768ec1e044f5cc3960fbd8bff20e007c" alt=""
Cube内に埋もれているので、矢印が確認しやすいように移動します。
data:image/s3,"s3://crabby-images/9a89e/9a89ef69f6588a6f9c1ef3c6e8e5e29614a849ac" alt=""
ArrowComponentをStaticMeshComponentにアタッチする
StaticMeshComponentを移動させた時に、ArrowComponentを一緒に移動できるように設定します。
図のようなStaticMeshComponentとArrowComponentが同じ階層にある場合に、StaticMeshComponentを移動させるとStaticMeshComponentのみが移動します。
data:image/s3,"s3://crabby-images/5afb4/5afb4c6312e0721f1f2edec5d6193af4573d0d0c" alt=""
[ArrowComponent]を[StaticMeshComponent]にDrag&Dropします。
[ArrowComponent]を[StaticMeshComponent]にAttach(取り付ける)する。と言います。
(他には、ArrowComponentをStaticMeshComponentの子にする。)
data:image/s3,"s3://crabby-images/80a4d/80a4d73c14889eb01f03eb532e8d54def03b932c" alt=""
ComponentをAttachすると親子関係ができます。
親である[StaticMeshComponent]を移動すると、子である[ArrowComponent]が一緒に移動します。
data:image/s3,"s3://crabby-images/fe0a2/fe0a2e46629791579ed328e3aa463732ce8df835" alt=""
子である[ArrowComponent]を移動しても、親である[StaticMeshComponent]は移動しません。
親は子に影響を及ぼしますが、子は親に影響しません。
data:image/s3,"s3://crabby-images/7dbd5/7dbd5b6d1742503899f0ddc0bb47417d4acb81c4" alt=""
ComponentのAttach(親子関係)が把握できたので、[ArrowComponent]と[StaticMeshComponent]の位置を元に戻します。
[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/4e798/4e7981660964e2783e1a700e9240f109063afbf8" alt=""
LevelEditorのViewportに配置した「BP_SampleActor」を確認します。
[ArrowComponent]が表示されているので、[Cube]の向きが確認できます。
data:image/s3,"s3://crabby-images/8f9ea/8f9ead2a48b026efc7ef69633d2f0ed8745ed64a" alt=""
[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/9affc/9affcaba0a27babcd268c3269aa73e4351c4547f" alt=""
[ArrowComponent]はPlayすると表示されません。
[ArrowComponent]は配置した時に方向を確認するために使用するComponentです。
data:image/s3,"s3://crabby-images/780a1/780a1d7c3b7f86c788b3b6391258a254f7992173" alt=""
PointLightComponentを追加する
Cubeの前方にLight追加することで、[Play]ボタンを押した後にもCubeの前方が分かるようにします。
「BP_SampleActor」をダブルクリックしてBlueprint Editorを開きます。
data:image/s3,"s3://crabby-images/e88a6/e88a678cfad55a4f732179d764dfa1588a513a23" alt=""
[StaticMesh]を選択し、[Add]ボタンをクリックします。
data:image/s3,"s3://crabby-images/796cb/796cba8cd7f04fa42f79a6844ed079c3fa968298" alt=""
[Component]パネルの[Add]ボタンをクリックし、[Point]で検索し、[Point Light]を選択します。
data:image/s3,"s3://crabby-images/e1daf/e1daf7feb65a4835acb2c372130bfad4a27e09f2" alt=""
[StaticMesh]を選択した状態で、Componentを追加すると、子としてComponentを追加することが出来ます。最初から構成が決まっているのであれば、選択してからComponentを追加するとAttachする手間が省けます。
[PointLight]を[Arrow]の前方に移動します。
[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/9ff02/9ff02bb62b7c87331539d0016d67f7a1af5ba232" alt=""
LevelEditorのViewportで[Arrow]の前方が明るくなりました。
data:image/s3,"s3://crabby-images/f49cb/f49cba9535b29f9c34c88fe6353a353931de64ff" alt=""
[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/9affc/9affcaba0a27babcd268c3269aa73e4351c4547f" alt=""
[Play]してからでもArrowの矢印が向いている方が明るいので、前方がどちらかが分かります。
data:image/s3,"s3://crabby-images/b4fd7/b4fd773a00580c7d23fbe060c4fe91b0df5bca13" alt=""
全て保存して、Blueprint側は終了
Blueprint側の説明はここまでになります。
[Content Browser]から[Save All]ボタンをクリックし、[Save Selected]ボタンをクリックしてプロジェクトの変更のあったアセットをすべて保存します。
data:image/s3,"s3://crabby-images/f1d49/f1d493e5a69b8890f964c48cd3153aa3f16f8de5" alt=""
まとめ
これくらいの文字数が一番読みやすいですね。
基本的なことほど手順も丁寧に書かないといけないので、説明すると長くなってしまいます。
簡単なことほど簡単に説明するのが難しいです。
魂は細部に宿るので、手抜きは出来ない。
引き続きC++側でComponentを追加する方法についてまとめます。