【Unity入門】プレイヤーをカメラで追従する方法
data:image/s3,"s3://crabby-images/18b42/18b4262f33041777576be3ea955de72f1e29bf48" alt=""
ゲームを作っているとプレイヤーをカメラで追従したくなることってありますよね。
この記事では、2Dと3Dに分けてそれぞれの追従方法を解説していきます!
この記事の目次
【2D】プレイヤーをカメラで追従する
data:image/s3,"s3://crabby-images/9e097/9e097ef2ec8217289bf92a20dc525719c1ff969d" alt=""
動画で見たい場合は、こちらをどうぞ。
流れ
1.背景を作る
2.プレイヤーを作る
3.スクリプトでカメラを追従させる
背景を作る
わかりやすくするためにまずは背景を作っていきます。
背景を作成するために背景の画像を取り込みましょう。
Assets > Import New Assetsを押し、
data:image/s3,"s3://crabby-images/83035/83035010b3d7b32c7935630259ff0c097969d150" alt=""
背景にしたい画像を選択してImportを押してください。
data:image/s3,"s3://crabby-images/0da5f/0da5f13f84ff856ca8c41b5dedf923076e23cb36" alt=""
画像を取り込んだらSceneビューにドラッグ&ドロップしてください。
data:image/s3,"s3://crabby-images/fa6fb/fa6fbf4fd9264327e135c7b790f29dc66cc00897" alt=""
data:image/s3,"s3://crabby-images/a14cf/a14cfdd9fb5bfb17323910ab511b2dedc44cfcd4" alt=""
ドラッグ&ドロップをした段階では背景のサイズが小さいと思うので、引き伸ばしましょう。
data:image/s3,"s3://crabby-images/b5147/b514746bb8a2fa3f10aaaf7b3fe7c4f1c68ff957" alt=""
これで背景ができました。
プレイヤーを作る
背景ができたので次はプレイヤーを作っていきましょう。
背景と同じようにプレイヤーも画像を取り込んで、ドラッグ&ドロップします。
なので、まずはプレイヤーにしたい画像を取り込みましょう。
Assets > Import New Assetsと押していきます。
data:image/s3,"s3://crabby-images/83035/83035010b3d7b32c7935630259ff0c097969d150" alt=""
プレイヤーにしたい画像を選択してImpotを押しましょう。
data:image/s3,"s3://crabby-images/52d24/52d24327881883be3aae3de0f3c8d52055ff7aff" alt=""
画像を取り込んだらSceneビューにドラッグ&ドロップしてください。
data:image/s3,"s3://crabby-images/92d71/92d712d3079c13b709059296a16de1711ae0eff9" alt=""
後ほどカメラを追従させた時にわかりやすくするためにプレイヤーを常に動くようにしていきます。
プレイヤーを制御するにはスクリプトを追加する必要があるので、プレイヤーのオブジェクトを選択した状態でインスペクターからAddComponent > New Scriptを押してください。
data:image/s3,"s3://crabby-images/33f61/33f61e4cfc78ad3788f4810d592eaa291e38532d" alt=""
名前を『SushiManager』とでもしておきましょう。
data:image/s3,"s3://crabby-images/b1201/b1201f9f42acb3ac4c509d2393aa0e157314f38c" alt=""
追加したスクリプトにコードを記述していきます。
記述内容は、
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class SushiManager : MonoBehaviour {
int positionX;
// Use this for initialization
void Start () {
}
// Update is called once per frame
void Update () {
positionX++;
//プレイヤーを移動させる
transform.position = new Vector3(positionX, 0, 0);
}
}
簡単に説明すると、int型の変数『PositionX』を作り、常に加算し続けます。
そして、プレイヤーのx軸を加算され続けている変数『PositionX』の値と同じにすることで、プレイヤーが常に動き続けます。
実行結果は、
data:image/s3,"s3://crabby-images/477b1/477b1c2c114342b776c41535db5fe23abb5d7bd1" alt=""
プレイヤーが移動するようになりましたね!
スクリプトでカメラを追従させる
次はスクリプトを使ってプレイヤーをカメラが追従するようにしましょう。
『Main Camera』を選択した状態でインスペクターから、Add Component > NewScriptを押してください。
data:image/s3,"s3://crabby-images/c7dda/c7dda410d29e0b06ce6e9b621e162c46dca90324" alt=""
名前を『CameraManager』としましょう。
data:image/s3,"s3://crabby-images/8e827/8e827c0522df86ddcd14a77b5459f3a2315d6a1c" alt=""
スクリプト『CameraManager』にカメラの位置をプレイヤーの位置と同じにするコードを書いていきましょう。
記述内容は、
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class CameraManager : MonoBehaviour {
//寿司を格納する変数
public GameObject sushi;
// Use this for initialization
void Start () {
}
// Update is called once per frame
void Update () {
Vector3 sushiPos = sushi.transform.position;
//カメラとプレイヤーの位置を同じにする
transform.position = new Vector3(sushiPos.x, 0, -10);
}
}
スクリプト『CameraManager』に記述された変数『Sushi』にプレイヤーオブジェクトをセットしましょう。
プレイヤーオブジェクトを変数『Sushi』にドラッグ&ドロップです。
data:image/s3,"s3://crabby-images/dd654/dd654ee0d82647a8e74b1d64676187733997de89" alt=""
data:image/s3,"s3://crabby-images/d56bd/d56bd090c5158d965ad319ae075bba35a0aee763" alt=""
実行してみましょう。
実行結果は、
data:image/s3,"s3://crabby-images/9e097/9e097ef2ec8217289bf92a20dc525719c1ff969d" alt=""
プレイヤーをカメラが追従していますね!
【3D】一定の距離を保ってカメラで追従する
data:image/s3,"s3://crabby-images/ccdb7/ccdb78d902f8750a8dc2bd2c76408a538064c705" alt=""
動画で見たい場合は、こちらをどうぞ。
次は3Dでプレイヤーを一定の距離を保ってカメラで追従する処理を解説していきましょう!
流れ
1.プレイヤーを動くようにする
2.カメラで追従するスクリプトを作成
プレイヤーを動くようにする
まずはプレイヤーを作りましょう。
今回はプレイヤーをSphereで作ります。
作り方は、HierarchyビューでCreate > 3D Object > Sphereです。
data:image/s3,"s3://crabby-images/5920e/5920e5c59257a30f29566dac91a7f3fffd1a65b3" alt=""
data:image/s3,"s3://crabby-images/af22a/af22aaee94811bf798e275cbec2e8874b4bf139f" alt=""
次にプレイヤーが乗っかる地面を作りましょう。
作り方は、HierarchyビューでCreate > 3D Object > Cubeです。
data:image/s3,"s3://crabby-images/ac2d6/ac2d69a6e9ced30ab87778104226114663c76ff3" alt=""
data:image/s3,"s3://crabby-images/90540/905401818ea06afb1feae87a33092eeaa31fdc65" alt=""
Cubeは地面になるのでSphereよりも下に位置を下げておきましょう。
data:image/s3,"s3://crabby-images/3d08e/3d08edd498ea87cd9d00564e2d2b71b93e03aeec" alt=""
Cubeのサイズを大きくしていきます。
Cubeを選択した状態でScaleのxとyを共に100にしましょう。
data:image/s3,"s3://crabby-images/3d790/3d790e01534e96828fdb331f3e072105075dc33f" alt=""
プレイヤーを動かせるようにしていきましょう。
スクリプトに記述して制御するのでまずはスクリプトをプレイヤーにつけましょう。
付け方は、Sphereを選択した状態でAddComponent > New Script
data:image/s3,"s3://crabby-images/99632/996323b96fc07b5cf5ef859a91b50afbdf4964b8" alt=""
名前を『PlayerManager』に変更してCreate And Addで追加できます。
data:image/s3,"s3://crabby-images/b92f4/b92f4b4112497050e2b38a97068e93de58d5bc58" alt=""
data:image/s3,"s3://crabby-images/79eb3/79eb3f229b72c28d8301938fcb932b34d2a62f1c" alt=""
次にプレイヤーにRigidbodyコンポーネントを追加しましょう。
Sphereを選択した状態で、Add Component > Physics
data:image/s3,"s3://crabby-images/613b1/613b1a0b494be6b4f45247625a17451708e27c39" alt=""
Rigidbodyを押してください。
data:image/s3,"s3://crabby-images/9dd04/9dd04e8ef89716d7c36f25a6af97153e796c11cd" alt=""
data:image/s3,"s3://crabby-images/07960/079605700ef65d13cf0c50cf72adec845d1699b3" alt=""
次は『PlayerManager』にコードを記述して、プレイヤーを十字キーで動かせるようにしましょう。
記述内容は、
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class PlayerManager : MonoBehaviour {
Rigidbody rb;
// Use this for initialization
void Start () {
//プレイヤーのrigidbodyコンポーネントを格納
rb = GetComponent<Rigidbody>();
}
// Update is called once per frame
void Update () {
//十字キー入力
float x = Input.GetAxis("Horizontal");
float z = Input.GetAxis("Vertical");
//プレイヤーに力を加えて移動させる
rb.AddForce(x * 30, 0, z * 30);
}
}
実行結果は、
data:image/s3,"s3://crabby-images/e7441/e74411ee96edc42a1742e118063ffdb1e1567fb0" alt=""
カメラで追従するスクリプトを作成
カメラをスクリプトで制御して、プレイヤーに追従するようにしていきましょう。
まずはカメラにスクリプトを追加します。
Cameraオブジェクトを選択した状態で、Add Component > New Script
data:image/s3,"s3://crabby-images/17995/1799594c604eb0bcea02e15111355e20d485b058" alt=""
名前を『CameraManager』としてCreate and Add
data:image/s3,"s3://crabby-images/f0a51/f0a51b38bfeae53e1b6956e769fb49a8b4fbb68a" alt=""
data:image/s3,"s3://crabby-images/42555/42555ea102f9fc6b5585f3bf6620f171f80b8d19" alt=""
『CameraManager』スクリプトにコードを記述して、カメラがプレイヤーに追従するようにしましょう。
記述内容は、
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class CameraManager : MonoBehaviour {
//プレイヤーを格納する変数
public GameObject player;
//プレイヤーとの距離を調整する変数
public float offsetx;
public float offsety;
public float offsetz;
// Use this for initialization
void Start () {
}
// Update is called once per frame
void Update () {
//プレイヤーのポジション
Vector3 pos = player.transform.position;
//カメラのポジション
transform.position = new Vector3(pos.x + offsetx, pos.y + offsety, pos.z + offsetz);
}
}
簡単に説明すると、カメラの位置をプレイヤーの位置と同じにし、offset変数を加算することで位置を微調整します。
コードを書いたら、Unityエディターからプレイヤーと、offsetの値をセットしましょう。
プレイヤーはCameraを選択した状態でCameraManagerのPlayerにSphereをドラッグ&ドロップしてセットします。
data:image/s3,"s3://crabby-images/d0250/d0250c90ac3e1d0cab4cb12ca58f7c4e84e07421" alt=""
offsetはyを0に、zを-3に変更してください。
data:image/s3,"s3://crabby-images/e2fbd/e2fbd797ea2fd03c7ebe981b308e010dc9049897" alt=""
これで実行した時に、カメラがプレイヤーを追従する位置がプレイヤーの位置よりもy軸に『+1』、z軸に『-3』されるようになりました。
offsetの値を変えることで、追従する位置が変えられます。
実行結果は、
data:image/s3,"s3://crabby-images/ccdb7/ccdb78d902f8750a8dc2bd2c76408a538064c705" alt=""
カメラが追従するようになっていますね!
まとめ
今回はプレイヤーをカメラが追従する方法について2Dと3Dでそれぞれまとめました。
この記事を読んで、カメラを追従させる方法が身についたのなら幸いです!