今回は、Unityでボタンや画像などのオブジェクトを等間隔に自動で並べるメモです。「LayoutGroup」を利用していきます。
はじめに
Unityのバージョンは2021.3.14f1です。自動レイアウトを利用してボタンの整列を簡単に実装してみます。
実装開始
Unityではボタンや画像などを簡単に並べることが出来るので実装していきます。
ボタンを配置(縦並び)
まずは「UI」→「Button」でボタンを追加、ボタンじゃなくてImageでもOK。
data:image/s3,"s3://crabby-images/80db2/80db2384fb4b2eec87768d3f8e7a7ddee31d373b" alt=""
とりあえず適当に3つほど作ります。位置はあえて適当な場所にしています。これを整列してみます。
data:image/s3,"s3://crabby-images/1e22c/1e22cf5178dd27f4d2f4f557a26e6b1e3b834bde" alt=""
まずはCanvasの配下に「CreateEmpty」で空のオブジェクトを追加。名前を「BtnGroup」にします。
data:image/s3,"s3://crabby-images/c57f2/c57f28ec1cb7495a38106699507300e8a06ac702" alt=""
下図のようにボタンを全て配下に移動します。
data:image/s3,"s3://crabby-images/cdc20/cdc20841df400e82ed31caae978a306972b7ab2b" alt=""
ボタンを縦並びにするので、BtnGroupに「AddComponent」から「Vertical Layout Group」を追加。
data:image/s3,"s3://crabby-images/80d7e/80d7e3008714247d220c7e09ec24e57304c751da" alt=""
下記のように自動で均等に並びます。サイズやプロパティを変更することでボタンの大きさも変わります。
data:image/s3,"s3://crabby-images/3b57b/3b57b7cd01a6d200ff73e63bbccebc20f9706f00" alt=""
さらにボタンを追加すると等間隔に自動で整列していきます。
スクリプトでボタンを有効にしてみる
次に、スクリプトでボタンを有効にしてみます。まずは、下記のようにボタンを並べます。
data:image/s3,"s3://crabby-images/e1e33/e1e33a895db44018bda29b3d999f4bd9e9cb50f4" alt=""
スクリプトを作成し、中身を下記のようにします。
using UnityEngine; public class BtnGroup : MonoBehaviour { [SerializeField] private GameObject _btn; public void BtnClick() { _btn.SetActive(true); } }
BtnGroupにスクリプトをアタッチしてパラメータをセット。
data:image/s3,"s3://crabby-images/9b863/9b8633e6048b12d508ecf697e8ca848bad9cf89b" alt=""
下記のようにすると、クリックでボタンが有効になり自動で整列してくれます。
data:image/s3,"s3://crabby-images/373da/373da02b64c95386b37dfe02284e80904b7fca41" alt=""
ボタン配置(横並び)
次は横並びを実装してみます。「AddComponent」から「HorizontalLayoutGroup」を追加。
data:image/s3,"s3://crabby-images/d2548/d254871f4b47e8ff33e2893ac489dd0deb63a7ca" alt=""
プレハブ化してスクリプトでボタンを生成
ボタンをプレハブ化して一つだけ残します。
data:image/s3,"s3://crabby-images/4f081/4f0815ef62d2308c077519c71948b59e878e83e7" alt=""
スクリプトの中身を下記に変更。
using UnityEngine; public class BtnGroup : MonoBehaviour { [SerializeField] private GameObject _btnPrefab; [SerializeField] private Transform _Parent; public void BtnClick() { Instantiate(_btnPrefab, _Parent); } }
下記のようにパラメータをセット。
data:image/s3,"s3://crabby-images/5378f/5378f3a6cd7aec807616f7e2d76da1fce8693f31" alt=""
data:image/s3,"s3://crabby-images/2729d/2729d5fefcb689ce9a6685dd8ac53a819166a5ad" alt=""
実行すると、下記のようにクリックでボタンを増やすたびに自動で整列します。
data:image/s3,"s3://crabby-images/a53de/a53def91ac067aae2c46120f1465050d592f9a1e" alt=""
ボタン配置(縦横並び)
縦横で並べたい場合は「GridLayoutGroup」。CellSizeやSpacing調整すると、下記のように配置するのも簡単。
data:image/s3,"s3://crabby-images/e83e3/e83e34c390f4f858c35153e64a8481c0723ed896" alt=""
今回は例としてボタンだけど、画像とかでも同じように可能。