data:image/s3,"s3://crabby-images/0d80e/0d80eae4b06d61c5601e8f3fd19175ef2ac77ea0" alt="見出し画像"
UE5から始める C++ & BP 13 【Blueprint版】Array(配列)
やっと配列までたどり着きました。
書いていると書かないことが沢山あります。
全部書いても勉強するには難しくなりすぎるので、かなり省略しています。
省略しても基本文法のすべてを説明できていないです。
プログラミン言語のごく一部でも膨大。
ようやく基本文法のゴールが見えてきました。
もう少し!
頑張ります。
前回は「Event Dispatcher」方法について調査しました。
今回は「Array(配列)」方法について調査していきます。
【Blueprint】Array(配列)
今回できること
変数をArray(配列)に変更します。
Array(配列)の設定方法や取得について解説します。
data:image/s3,"s3://crabby-images/94d48/94d4829e4ccc09a5ecefaeaccb76c4a2878d1d94" alt=""
Array(配列)の取得でよく使用する2つの方法について解説します。
Array(配列)をランダムに取得する。
Array(配列)を剰余(%)を使用して順番に取得する。
data:image/s3,"s3://crabby-images/990a3/990a3c68744b9f56ad81dbd701c416a7c8a9e64b" alt=""
data:image/s3,"s3://crabby-images/c8617/c8617154784fde4c076fa3d669c0545fd39436d6" alt=""
学習用の新規レベル「Chapter_2_Array」を作成する
学習用の新規レベルを作成します。
[File]メニューから[New Level…]を選択します。
data:image/s3,"s3://crabby-images/b9d60/b9d60c3449b5939659d2b2dd89b7604d6b3b6dd2" alt=""
[Default]を選択します。
data:image/s3,"s3://crabby-images/f7dc2/f7dc24ed1ba86ecb8c25ab0e6ef0906261374b16" alt=""
[File]メニューからCurrent Levelを保存します。
ショートカット「Ctrl + S」でも保存できます。
data:image/s3,"s3://crabby-images/bd9d5/bd9d5d64a36ba85310a838cc2485acd1f062c5c4" alt=""
「Maps」フォルダを選択し、Nameに「Chapter_2_Array」を入力し、[Save]ボタンをクリックします。
data:image/s3,"s3://crabby-images/217e2/217e232670b49cb907f1fa2b138020edc7e2b0d6" alt=""
Blueprintを複製する
「BP_EventDispatchcer」を複製(Ctrl + W)して、「BP_Array」を作成します。
data:image/s3,"s3://crabby-images/30179/30179b8050499fd396ca1caba3ba7cd2652f994e" alt=""
変数[Message]を配列の変数[Messages]に変更する
変数[Message]を配列の変数[Messages]に変更します。
変数[Message]を選択し、Variable Nameを[Messages]に変更します。配列の変数を宣言する時は複数形の名前にすると配列ということが分かりやすくなります。
Variable Typeの右端のアイコンをクリックし、[Array(配列)]を選択します。
data:image/s3,"s3://crabby-images/63e9b/63e9ba3fbb32fdf4b4b434973884ae36f307178e" alt=""
Variable TypeをArray(配列)に変更すると、変数をEvent Graphで使用しているので確認ダイアログが表示されます。[Change Variable Type]をクリックします。
data:image/s3,"s3://crabby-images/579ae/579ae21dd0e10613de5d693020d745ab8cd8f640" alt=""
[My Blueprint]パネルの変数[Messages]のVariable Typeのアイコンが変わっています。アイコンを確認することで変数が配列か判別できます。
data:image/s3,"s3://crabby-images/ef6c2/ef6c25aacf4e7becfe8da0b6d8b1d53942ca1ba9" alt=""
変数[Messages]にDefault Valueを設定する
変数[Messages]にDefault Valueを設定します。
Default Valueを設定するので、[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/03e0f/03e0f13061bbe8efbaac4ea757f22d592d839306" alt=""
Array(配列)はDefault Valueの設定方法が変わります。
data:image/s3,"s3://crabby-images/5d141/5d141944665f097da20e29ead3b64909436fdb8a" alt=""
Default Valueの[+]ボタンをクリックすると設定できる要素が増えます。
以下の表の国ごとの"Hello World!"を内容をDefault Valueに設定します。
配列の数え方は[0]が1番目になります。
data:image/s3,"s3://crabby-images/aaa9a/aaa9a737729aeba7c558e1a4428ac2dff114e92e" alt=""
data:image/s3,"s3://crabby-images/ebe4d/ebe4de109fceb9cfdc872af27ebff2a5772e3d8e" alt=""
変数[Messages]から値を取得する
変数[Messages]から値を取得します。
Variable Typeを変更したので、変数[Messages]のGetノードでエラーが発生しています。エラーとなっているピンの接続を切断します。
data:image/s3,"s3://crabby-images/fa1e6/fa1e67911a7fbbc23345227d9a1df1c88c13c6c3" alt=""
変数[Messages]のGetノードからDrag&Dropし、[Get(a ref)]を選択します。
data:image/s3,"s3://crabby-images/52325/52325a4e9cbe06cf86bb030f9576e461c98d0d20" alt=""
Array(配列)のGetノードには[Get(a ref)]と[Get(a copy)]の2種類があります。
Function(関数)で説明した「参照渡し」と「値渡し」でArray(配列)の値を取得するかの違いです。
Get(a ref):参照渡しで値を取得します。
Get(a copy):値渡しで値を取得します。
data:image/s3,"s3://crabby-images/697fd/697fdb6934e2a0b8afac3efafb485f8f2538b55b" alt=""
日本語の"こんにちは世界!"を取得するように、Getノードの数値には[4]を設定します。
Getノードを[Print String]ノードの[In String]に接続します。
data:image/s3,"s3://crabby-images/3f928/3f9284f8f77baa0a55d5ff53fc2dbe9d192c8461" alt=""
[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/391ba/391baaaf9bfa0defe178b60e32252c1fb788f765" alt=""
Level Editorに戻り、「BP_Array」をViewportにDrag&Dropします。
data:image/s3,"s3://crabby-images/8e40f/8e40f4100b8fdee2fe45fa7eaf8e207a6b90b6dd" alt=""
Level Editorの[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/cd0b9/cd0b9c60acf97e2a535b2d67954ffa0ac0b3f7bd" alt=""
[H]キーをPressすると、変数[Messages]のIndex[4]に設定した文字列が表示されます。
data:image/s3,"s3://crabby-images/9c587/9c58783d860af32494dbb47eb89471276c0c59d0" alt=""
変数[Messages]からランダムに値を取得する
変数の取得方法についてよく使う方法を2つ紹介します。
まずは、変数[Messages]からランダムに値を取得する方法です。
メニューから[Random Integer in Range]を選択します。
data:image/s3,"s3://crabby-images/1a6f3/1a6f333595fd104117b5b01f6a5941663e81195c" alt=""
[Random Integer in Range]の[Max]ピンに配列の最後のIndex Noである[4]を設定します。
[Random Integer in Range]の[Return Value]ピンとGetノードを接続します。
配列は[0]から始まるので、Index NoのMaxは「配列数 - 1」になります。
data:image/s3,"s3://crabby-images/c2be4/c2be4de3d0b4ae552e9acd9f12d3992803591b59" alt=""
[compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/b272e/b272ebb5e8b8b4eee2ba145036de9d911f4583bc" alt=""
Level Editorの[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/76bf7/76bf73789225d49f21aa79777d602780e63ba429" alt=""
[H]キーをPressすると、変数[Messages]の文字列がランダムに表示されます。
data:image/s3,"s3://crabby-images/b7ff6/b7ff6fd62e640937e4b1730c3e1fef97a380a027" alt=""
配列数が変わっても処理を変えずに済むように変更します。
data:image/s3,"s3://crabby-images/3684e/3684e40e91666eee7b82723d79acc018120e22ff" alt=""
変数[Messages]からDrag&Dropし、[Length]を選択します。
data:image/s3,"s3://crabby-images/cbab1/cbab1fd33752404541dfd97c73cd2ae93624d30b" alt=""
[Length]のアウトプットピンからDrag&Dropし、[Subtract(-)]を選択します。
[Subtract]のアウトプットピンを[Random Integaer in Range]の[Max]ピンに接続します。
配列は[0]から始まるので、Index NoのMaxは「配列数 - 1」になります。
配列の数を増やしても処理を変えずにMaxの値を取得できます。
data:image/s3,"s3://crabby-images/f518b/f518b3c4195110ee54c300f4367ec30373a371ad" alt=""
[compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/ea6b0/ea6b02e6bfb4327995325f5a69eaa3ddf239b39b" alt=""
Level Editorの[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/07bb2/07bb2e7635ab334d34298ea1d72329ab6fce1a36" alt=""
[H]キーをPressすると、先ほどと同じように配列の文字列をランダムに取得できます。配列数が変わってもMaxの値を変更せずに済むので[Length]ノードを使用した取得は便利です。
data:image/s3,"s3://crabby-images/99374/99374b1d6a939be701c9f79d30e3da6952ca2538" alt=""
配列からRandomのElementとIndexを取得できるRandom関数があります。
data:image/s3,"s3://crabby-images/3a913/3a91355f1397fa2d029cd75ba9d008c29619667c" alt=""
Random関数から取得できるElementは値渡しになるので、参照渡しにしたい場合はRandom関数のIndexをGet(a ref)に渡して取得します。
data:image/s3,"s3://crabby-images/5c634/5c6345d60b28622ba07abff457b539b8d893c66f" alt=""
変数[CalcType]を配列の変数[CalcTypes]に変更する
次に、剰余(%)を使用して、順番に配列を取得する方法について説明します。
Index番号を保持するための変数[TypeIndex]を宣言します。
data:image/s3,"s3://crabby-images/fb3ab/fb3abb5e6d1f92e9ad0ecb9529ad0c47a85eb0d0" alt=""
data:image/s3,"s3://crabby-images/01718/01718f827a5ce11156ce20cb0ab6271677aa5e6e" alt=""
変数[CalcType]を選択し、Variable Nameを[CalcTypes]に変更します。
Variable Typeの右端のアイコンをクリックし、[Array(配列)]を選択します。
data:image/s3,"s3://crabby-images/ea37c/ea37ca013039a656d0b5ce3c47d304b0e9e44227" alt=""
Default Valueを設定するので、[Compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/cd69b/cd69b54300c6f710a7d27a49902cab577cfd850b" alt=""
変数[CalcTypes]のDefault Valueを設定します。
data:image/s3,"s3://crabby-images/c791b/c791b3aa9cfc3197e404a4c1874dd4bac8296dca" alt=""
data:image/s3,"s3://crabby-images/3a707/3a707f554375779279d92885546877508169fd4c" alt=""
変数[CalcTypes]の値を順番に取得して出力する
変数[CalcTypes]の値を順番([0:Add]> [1:Subtract] > [2:Multiply] > [3:Divide] > [0:Add] > 繰り返し)に出力するように処理を編集します。
Variable Typeを変更したのでエラーになっているピンの接続を切断します。
data:image/s3,"s3://crabby-images/26ab6/26ab6faf844b8ac474584e22ab4116d57e3d8d54" alt=""
変数[CalcTypes]の値を変数[TypeIndex]で取得します。
先ほど追加した変数[TypeIndex]のGetを追加します。
変数[TypeIndex]のGetノードと変数[CalcTypes]のGetを接続します。
data:image/s3,"s3://crabby-images/f3114/f311431ebee942abda5e0030ee7f8d08dc41bb23" alt=""
Function[PrintCalcResult]実行後に、TypeIndexをIncrementします。
data:image/s3,"s3://crabby-images/7c5b7/7c5b7297a3eec155fd9ed60f0abbb9eadd756fd9" alt=""
Incrementは変数の値を[+1]してくれるノードです。
Increamentをして[+1]した変数[TypeIndex]の値をループする計算を追加します。
「%」は割り算の余り(剰余)を取得できるノードです。
「7 ÷ 3 = 2 余り1」の「余り1」を取得できます。
現在のIndex ÷ Length(配列数)の余りを求めると、配列のIndexをオーバーすることがなくなります。
「4 ÷ Length(4) = 1 余り0」になるので、配列数とIndexが同じになっても、配列のIndexをオーバーせずに最初の[0]に戻せます。
data:image/s3,"s3://crabby-images/f936c/f936c01b71fc6c51c2fb44a14288f2fd813db63f" alt=""
実行回数が配列数を越えるように実行した時の変数[TypeIndex]の値を表にしました。
[[3]:Divide]実行後、[[0]:Add]に戻って繰り返します。
data:image/s3,"s3://crabby-images/f3d0b/f3d0b22de2b6a17f117d5438d4c5c6bfd507d4ce" alt=""
data:image/s3,"s3://crabby-images/09768/09768ee7b0bbaf221b62d355f38e59c9a217dadb" alt=""
[compile]ボタンをクリックします。
data:image/s3,"s3://crabby-images/ddda8/ddda85b1073453ed6ad445413a05efd6dda32da1" alt=""
Level Editorの[Play]ボタンをクリックします。
data:image/s3,"s3://crabby-images/52616/52616319d7cc7a0e1c6e50be76021c42d7ada163" alt=""
[C]キーをPressすると、変数[CalcTypes]の値を順番([0:Add]> [1:Subtract] > [2:Multiply] > [3:Divide] > [0:Add] > 繰り返し)に出力します。
現在のIndex ÷ Length(配列数)の余りを現在のIndexに設定する処理はif文で最大数を比較しなくて済むのでスマートな書き方になります。
data:image/s3,"s3://crabby-images/ad660/ad6603535789e7e5c9351e2281b30d3699615ac8" alt=""
すべて保存
Blueprint側の説明はここまでになります。
[Content Browser]から[Save All]ボタンをクリックし、[Save Selected]ボタンをクリックしてプロジェクトの変更のあったアセットをすべて保存します。
data:image/s3,"s3://crabby-images/a8cec/a8cec39804b62f657ee0441cdd8498aef5c38ce8" alt=""
まとめ
寝たり起きたりでやっと書き終わりました。
ゴールが近づくほど一気に駆け抜けないとゴールできない。
今が一番苦しい時ですね。
抜けられないトンネルはない
もう少し!
参照URL
UE4から始めるC++&Blueprint 進捗とロードマップ
Zennで進捗報告を行い、GitHubでロードマップを公開中です。
よかったら覗いてみてください。