Unity2DゲームでSpringJoint2Dを利用して、バネのような動きを実装してみます。
はじめに
Unityのバージョンは2021.3.14f1です。下記、公式リファレンスでは、SpringJoint2Dは「バネでつながったような物理挙動に制御される」とあります。
実装開始
動きを確認しながら実装してみます。
オブジェクトの作成
「2DObject」→「Sprites」→「Circle」を追加します。
data:image/s3,"s3://crabby-images/5f79e/5f79eb8c0a78fca532c1648fad564231ee3a5b21" alt=""
「AddComponent」から「Rigidbody2D」をアタッチして重力を0に。BallMoveと言う名前でスクリプトを作成してアタッチします。
data:image/s3,"s3://crabby-images/48d91/48d910419e3dac67ebdcfbcba787db4b5c6b7568" alt=""
スクリプトの中身を下記にします。左右の入力でオブジェクトに力を加えます。
using UnityEngine; public class ballMove : MonoBehaviour { private float _force = 10.0f; private Rigidbody2D _rb; private void Start() { _rb = GetComponent<Rigidbody2D>(); } void Update() { float InputX = Input.GetAxisRaw("Horizontal"); if (InputX != 0) _rb.AddForce(Vector2.right * InputX * _force); } }
実行して、キーボードの「D」を押すと下記のような動きになります。
data:image/s3,"s3://crabby-images/da840/da84034810348db07e7b879f79f81d8e45783fc7" alt=""
バネを追加(SpringJoint2D)
「2DObject」→「Sprites」→「Square」を追加します。
data:image/s3,"s3://crabby-images/009fd/009fd8ac8c1918951b7667302a4f7e5e6772c191" alt=""
「Add Component」から「Rigidbody 2D」をアタッチします。BodyTypeを「Kinematic」にします。
data:image/s3,"s3://crabby-images/3642c/3642c35967277ec8e7db5c64f3cb2d53e86d3e0c" alt=""
Circleオブジェクトに「SpringJoint2D」をアタッチして、ConnectedRigidBodyにSquareを指定します。
data:image/s3,"s3://crabby-images/24e5d/24e5d37c0ec9bb867c3ec84fbfe6e18768cc7a0f" alt=""
シーンで確認すると、下記のような感じでつながります。緑色がバネの部分になります。
data:image/s3,"s3://crabby-images/e5346/e5346a1c7130a7360cb31e0a3a816d01b3d30c47" alt=""
実行してキーボードの「A」や「D」を押してみると、下記のようにバネではじかれるような動きになります。(分かりにくいですが・・・)
data:image/s3,"s3://crabby-images/b1fba/b1fba60e9ebaf0ec8fd37d566d2d564cf82631f4" alt=""
バネをlineRendererで表示
Circleのままでは分かりにくいので名前をplayerに変更、Squareはblockに変更しておきます。
playerにLineRendererをアタッチして、Positionsのサイズを0に、幅や色は好きなのに変更しておきます。
data:image/s3,"s3://crabby-images/e8f53/e8f53f4d3a410eb79fa50bf9ae07284403e50104" alt=""
下記スクリプトを作成します。LineRendererのポジションをセットしているだけです。
using UnityEngine; public class grap : MonoBehaviour { [SerializeField] private GameObject block; private LineRenderer line; void Start() { line = GetComponent<LineRenderer>(); line.positionCount = 2; } void Update() { line.SetPosition(0, transform.position); line.SetPosition(1, block.transform.position); } }
playerにスクリプトをアタッチして、blockをセットします。
data:image/s3,"s3://crabby-images/fc863/fc863d38193fac313fc061f4ceaed44fcf052a53" alt=""
実行すると下記のようにバネが可視化されます。
data:image/s3,"s3://crabby-images/7181a/7181a91da266c8f9021ef6bf5dfb034617ebe057" alt=""
ブロックを増やして、ブロックをクリックしたらバネを付け替える感じにすると下記のようになります。
data:image/s3,"s3://crabby-images/ce625/ce6251cb2371a4aa3d0f8d85a5b5d188eb7e4c6a" alt=""