はじめに
InputSystem を使ってCinemachine の FreeLook Camera を操作できるようにする方法と、Camera が障害物を避けるようにする設定について説明します。
InputSystem はすでにインストールされているものとして説明します。InputSystem のインストールおよび設定方法は、以前の記事を参照してください。
【Unity】InputSystemを使ってキャラクターの移動を実装する【2023年版】
Cinemachine のインストール
メニューバーの Window から PackageManagerを選択して、PackageManager を起動します。Packages の選択肢から Unity Registry を選択します。
data:image/s3,"s3://crabby-images/53938/539385ece943f5fe3594a94fbfa08afaaca4ac66" alt=""
左の一覧からCinemachine を選択して、Install ボタンを押します。
data:image/s3,"s3://crabby-images/b08d8/b08d893106e3ba5cb633602c3bb73d151b05f767" alt=""
Player の下準備
Player の Prefab の名称変更と Free Look Camera の注視点の作成を行います。
プレイヤーキャラクタの名前の変更
プレイヤーが操作するキャラクターの名称がHumanMale_Character_Free だと分かりづらいので、Player に名前を変更します。
data:image/s3,"s3://crabby-images/9c4aa/9c4aa02eb7d7ffc9cab06c42c4e2d384b4fc77cb" alt=""
data:image/s3,"s3://crabby-images/ad8f3/ad8f3ced1d068869e7a66f016ac8bbcdd2b4c1a0" alt=""
HumanMale_Character_Free の初期状態からいくつかコンポーネントを追加しているので、Prefab に反映します。Hierarchy で Player を選択して、Inspector のPrefabのところで Overrides を押します。
data:image/s3,"s3://crabby-images/d837f/d837f4b965c9affa86e17b3455325806707b3e8e" alt=""
その状態で Apply All をボタンを押して、変更を Prefab に反映します。
data:image/s3,"s3://crabby-images/93ce8/93ce89ab0a8b3215af8684e3ab11b1f191da892c" alt=""
Player Prefab の作成
ここまで変更を加えた Player を改めて Prefab化します。
Hierarchy でPlayer を選択し、Project タブの Assets/PlayerController の中にドラッグアンドドロップします。
data:image/s3,"s3://crabby-images/38bbb/38bbb152230f7ccfc41392d6cfddab1eb0a9ea50" alt=""
どのような Prefab にするか聞かれるので、 Original Prefab を選択します。
data:image/s3,"s3://crabby-images/3e9e1/3e9e129609ef9afa1752dca17ede0b4184da0b6b" alt=""
FreeLook Camera の注視点の作成
Hierarchy の Player の > を押してPrefab の編集画面に入ります。
data:image/s3,"s3://crabby-images/623f5/623f56fbf6d102605061da2513a53a9a6832ab36" alt=""
data:image/s3,"s3://crabby-images/cfcd2/cfcd29787717c8bd96cff64f0a52760cc7778cec" alt=""
Playerを選択した状態で右クリックして、Create Empty で空のゲームオブジェクトを作成します。名前を LookTarget にします。
data:image/s3,"s3://crabby-images/c9f60/c9f60b22e967499ff7d9696f4bc8f7c6a160ed82" alt=""
data:image/s3,"s3://crabby-images/e55cb/e55cb771e45d2c5ef41af8239ac58d290a53812e" alt=""
LookTarget を選択した状態で、Inspector の Transform を見ると初期位置がずれていることがあるので、三点リーダーから Reset を行います。
data:image/s3,"s3://crabby-images/67a25/67a25979e1e9f3ae7e0a25794bb7bb414c2f042b" alt=""
その後、y座標だけ 1.6 を入れてキャラクターの首くらいの位置に合わせます。
data:image/s3,"s3://crabby-images/c27c0/c27c0d94b0a2cc4cf07f9b5cbadc735876801d38" alt=""
Hierarchy の < を選択して、Prefab の編集画面を抜けます。
data:image/s3,"s3://crabby-images/0c344/0c3443094db55415bae67174a844e700decdaaa1" alt=""
Cinemachine の設定
FreeLook Camera の追加
メニューバーで GameObject を選択し、Cinemachine –> FreeLook Camera を選択します。
data:image/s3,"s3://crabby-images/04871/0487120831b6998ec7dd21b75c73515e6a5eb003" alt=""
FreeLook Camera が追加されます。名前を変更しても構いません。
data:image/s3,"s3://crabby-images/c950a/c950af1c438292d8320484ba9922cea438a7f966" alt=""
FreeLook Camera が追加されたときに、Main Camera のコンポーネントにCinemachineBrainが追加されます。追加した覚えがないからと言って消さないようにしましょう。
data:image/s3,"s3://crabby-images/3240c/3240cecc6ff5800b92fe94d9406b1e9acfc73b03" alt=""
FreeLook Camera に 注視点を設定する
FreeLook Camera が追いかけるゲームオブジェクトを設定します。
Player と LookTarget を FreeLook Camera の Inspector の Follow と Look At に設定します。以下の画像のようにドラッグアンドドロップするか、⦿を押して一覧から選択します。
data:image/s3,"s3://crabby-images/ed8a9/ed8a910fb58db32c394a719498e4d79269ffaca8" alt=""
FreeLook Camera に Cinemachine Input Provider を追加する
Cinemachine の FreeLook Camera は、Input System の入力を直接受け取れないため、Cinemachine Input Provider スクリプトを追加します。
FreeLook Camera の Inspector で、Add Component ボタンを押して、検索窓に cinema くらいを入力すると Cinemachine Input Provider が見つかると思いますので、選択します。
data:image/s3,"s3://crabby-images/64bf9/64bf9e1b823498347e31bab8dfca764b2d34ff12" alt=""
data:image/s3,"s3://crabby-images/f7ec3/f7ec3a454ac892955a98d464e5b7dcd56428e31d" alt=""
Project タブのAssets 直下にある MyInputActions の中の Player/Look をCinemachine Input Provider の XY Axis にドラッグアンドドロップします。Z Axis は None のままで問題ありません。
data:image/s3,"s3://crabby-images/89e1e/89e1eb55eabbc7bdb7a47db37aedc00daf00bc7e" alt=""
data:image/s3,"s3://crabby-images/3352e/3352ee7f79069905779bb90b63804142032adcdf" alt=""
これで、Gamepad の右スティックでカメラが操作できるようになります。
Camera に Collider を付ける
カメラが壁を貫通しないようにするために、コライダーを付けます。
FreeLook Camera のコンポーネントの一番下、Extensions の Add Extensions の(select) から CinemachineCollider を選択します。
data:image/s3,"s3://crabby-images/7224f/7224f8847b76de1062d26913429a12ddfad565a5" alt=""
Ignore Tag で Player を選択し、 Player のタグが付いているオブジェクトを無視するように設定します。
data:image/s3,"s3://crabby-images/58449/584498f8255b64e215eced2d7da57039b7f212aa" alt=""
Player 側のTag も Player に設定します。
data:image/s3,"s3://crabby-images/9b500/9b5007b9e443d6770ca4d58df89a2267a3e85fb7" alt=""
FreeLook Camera の設定
今回は基本的にデフォルトの設定のまま使いました。
Orbits のところだけ以下のような値に変更しています。
data:image/s3,"s3://crabby-images/dda18/dda182dea974e474945d62059f80a4020f037db3" alt=""
スクリプトの変更
PlayerMove.cs の左スティックをカメラの方向を考慮した移動になるよう修正します。
スクリプトを新しいものに差し替えたら、Look Target を設定します。
data:image/s3,"s3://crabby-images/d7f2b/d7f2b729009981a72c411c12c1e2b659941389cd" alt=""
スクリプトの主な変更は、以下の場所になります。
void Update()
{
var velocity = Vector3.zero;
// 方向キーの入力があったら、その向きにキャラクターを回転させる
if (input.magnitude != 0)
{
Vector3 playerDirection = Vector3.Normalize(new Vector3(input.x, 0, input.y));
Vector3 cameraDirection = lookTarget.position - mainCamera.transform.position;
cameraDirection.y = 0;
cameraDirection.Normalize();
// カメラの向きに、スティックの向きを掛け合わせ、キャラクターをスティックの方向に向かせる
Quaternion characterTargetRotation = Quaternion.LookRotation(cameraDirection) * Quaternion.LookRotation(playerDirection);
transform.rotation = Quaternion.RotateTowards(transform.rotation, characterTargetRotation, rotationSpeed * Time.deltaTime);
}
カメラの向きを計算し、それを方向キーの入力と掛け合わせて、キャラクターがスティックの方向に向くようにしています。
変更箇所は、これ以外に、カメラの位置を取得するための変数の定義などもあります。