今回はUnity2Dゲームで壁を作成していきます。固定で作成、スクリプトで作成、画面サイズに合わせて自動で作成。の3つを見ていきます。
はじめに
Unityのバージョンは2022.3.14f1です。(あまりバージョンは関係ないですが)
下記の続きとして作成していきますが、ゼロから作成でも問題ないです。あくまでも壁として機能しているのを確認するため、下記の続きとして作成しています。
作成開始
まずは「空オブジェクト」を追加、名前をWallとします。
data:image/s3,"s3://crabby-images/c6ed1/c6ed138f3a78b4c55d2c4999efb22abd5596b272" alt=""
「Line Renderer」を追加して、サイズや幅、マテリアルなどを変更して枠を作成します。
data:image/s3,"s3://crabby-images/d9f31/d9f31cbad6c0d8163bddb6061efa57b3a2de062a" alt=""
下記のように白い枠が出来ればOKです。
data:image/s3,"s3://crabby-images/137d6/137d65456ba52dbec5ed055be38a97b9c77543b5" alt=""
Projectフォルダ内に「2D」→「PhysicsMaterial 2D」を追加します。
data:image/s3,"s3://crabby-images/59397/593979047560d4d5b9170255b3c6c65db98d17d1" alt=""
名前をBounceに変更して、Bouncinessを1にします。
data:image/s3,"s3://crabby-images/b5d10/b5d103a5ff7c73ad80d144a4eba2086a86de6ef7" alt=""
Wallに「EdgeCollider2D」を追加して、マテリアル、ポイントを変更します。
data:image/s3,"s3://crabby-images/9f678/9f6786ce123fc9d2c0b99873b3bad251996a2d97" alt=""
試しに動かしてみると下記の様な感じに。
data:image/s3,"s3://crabby-images/60d34/60d34e80a92decc3c11de76db506e92bd3ed283f" alt=""
スクリプトで作成
次にスクリプトで同じ壁を作成してみます。先ほどセットしたサイズをリセットしておきます。
data:image/s3,"s3://crabby-images/3a3d1/3a3d15cff3ff47abdfeaca4dc674b6ebd8bad7a8" alt=""
下記のスクリプトを作成します。
using UnityEngine; public class WallCreate : MonoBehaviour { [SerializeField] private LineRenderer _lineRender; [SerializeField] private EdgeCollider2D _edgeCollider; [SerializeField] private Vector3 _leftTop, _leftBottom, _rightTop, _rightBottom; private void Awake() { Vector3[] linePositions = new Vector3[] { _leftTop, _leftBottom, _rightBottom, _rightTop, _leftTop }; _lineRender.positionCount = linePositions.Length; _lineRender.SetPositions(linePositions); Vector2[] colliderPoints = new Vector2[5]; colliderPoints[0] = new Vector2(_leftTop.x,_leftTop.y); colliderPoints[1] = new Vector2(_leftBottom.x,_leftBottom.y); colliderPoints[2] = new Vector2(_rightBottom.x,_rightBottom.y); colliderPoints[3] = new Vector2(_rightTop.x,_rightTop.y); colliderPoints[4] = new Vector2(_leftTop.x, _leftTop.y); _edgeCollider.points = colliderPoints; } }
Wallオブジェクトにスクリプトをアタッチして、パラメータをセットします。
data:image/s3,"s3://crabby-images/2d964/2d9648145ba3947a8b9b352b2da2c705de866347" alt=""
実行すると、同じような壁が作成されます。パラメータの値を変更すると壁の位置を簡単に変更することができます。
画面サイズに合わせて壁を作成
次に画面枠のサイズに合わせて、自動でサイズが変わる壁を作成してみます。
スクリプトを下記に変更します。
using UnityEngine; public class WallCreate : MonoBehaviour { [SerializeField] private LineRenderer _lineRender; [SerializeField] private EdgeCollider2D _edgeCollider; private void Awake() { Vector3 LeftTop = Camera.main.ScreenToWorldPoint(new Vector3(0, Screen.height, 0)); Vector3 LeftBottom = Camera.main.ScreenToWorldPoint(new Vector3(0, 0, 0)); Vector3 RightBottom = Camera.main.ScreenToWorldPoint(new Vector3(Screen.width, 0, 0)); Vector3 RightTop = Camera.main.ScreenToWorldPoint(new Vector3(Screen.width, Screen.height, 0)); LeftTop.z = LeftBottom.z = RightBottom.z = RightTop.z = 0; Vector3[] linePositions = new Vector3[] { LeftTop, LeftBottom, RightBottom, RightTop, LeftTop }; _lineRender.positionCount = linePositions.Length; _lineRender.SetPositions(linePositions); Vector2[] colliderPoints = new Vector2[5]; colliderPoints[0] = new Vector2(LeftTop.x, LeftTop.y); colliderPoints[1] = new Vector2(LeftBottom.x, LeftBottom.y); colliderPoints[2] = new Vector2(RightBottom.x, RightBottom.y); colliderPoints[3] = new Vector2(RightTop.x, RightTop.y); colliderPoints[4] = new Vector2(LeftTop.x, LeftTop.y); _edgeCollider.points = colliderPoints; } }
画面サイズに沿って壁が作成されます。
data:image/s3,"s3://crabby-images/70639/70639c4e41dc23ca093e6d8c48ce415fb606e4b9" alt=""