2023/09/02 Updated by data:image/s3,"s3://crabby-images/c3200/c320081f0bbd1fe67ee2193cd6a2812a62366393" alt=""
Unity
Humanoid を動かす (1) 移動
[Up]
data:image/s3,"s3://crabby-images/be693/be6931c4df369eb18a21c5fce89b7b8da66d3e5d" alt="English"
MacBookAir (M1, 2020)
Tip: Apple M1
Memory: 16GB
macOS: Ventura 13.5.1
新しいプロジェクトを開始する
"Third Person (Core)" を選択すると、初回は "Download" ボタンが表示される。
"Download" が終了するとプロジェクトの "Create" が可能になる。
Unity Hub: 3.5.1
Unity version: 2021.3.16f1 APPLE SILICON LTS
Project Type: Third Person (Core)
Project Name: Humanoid
data:image/s3,"s3://crabby-images/9c660/9c660ca575ffc83efb3b50009256baed5f741103" alt=""
data:image/s3,"s3://crabby-images/dddff/dddff5fe471d6b47e17b5dc0b63647b7493ba24d" alt=""
Unity が起動する。"Run" すると、物体の Material は正しく Render されているし、キー入力に対しても正しく動作しているように見える。
data:image/s3,"s3://crabby-images/0282d/0282d77f54fde378abf323161d573a408bd9fa28" alt=""
data:image/s3,"s3://crabby-images/89ac4/89ac4474e67bde69563a09f5d47805d62389388f" alt=""
このプロジェクトで使われている Render Pipeline を確認しておく。→ UniversalRenderPipelineAsset であることがわかる。
Top Menu Bar → Edit → Project Settings → Graphics → Scriptable Render Pipeline Settings
data:image/s3,"s3://crabby-images/3a455/3a4550aef0b01c0d1ba1cd1bf90a11e4e1fbfef0" alt=""
Assets の下に TSP というフォルダを作成し、Assets の直下にあったファイルをすべて TSP の下に移動しておく。
新しいシーンを Basic (URP) で作成する。
Top Menu Bar → File → New Scene → Standard → Basic (URP)
Finder (macOS の場合、Windows では Explorer を使う) で
「MakeHuman で Unity5 で使用する人型モデルを作成する」
で作成した AsianBoy.fbx と textures/ があるフォルダを開く。
そこから、UnityのProjectウィンドウの Assets/Models/ に AsianBoy.fbx と textures/ フォルダをドラッグしてインポートする。
警告が表示された場合は、"Fix now" をクリックする。
makehuman2.zip
data:image/s3,"s3://crabby-images/bbb93/bbb93a3ec09e7cfc3cd360ca6c4f0b05ca7f9504" alt=""
data:image/s3,"s3://crabby-images/0b134/0b1346a31b8063f0b6309b307ec562afd3308241" alt=""
ProjectウィンドウでAsianBoyを選択をして、 Inspectorウィンドウで "Rig" で Animation Type を "Humanoid" に変更し、 Avatar Definition を "Create From This Model" のままとして、 "Apply"ボタンをクリックします。
data:image/s3,"s3://crabby-images/533de/533de4493e43609f76b43c689dbfe847d1ac6c3f" alt=""
Inspectorウィンドウで "configure" をクリックして、ボーンが正しく設定されたか確かめておいた方が安全です
data:image/s3,"s3://crabby-images/1abb2/1abb29c209ebe8cec23afd7dc9ffbf824dd744e9" alt=""
Inspectorウィンドウで "Mapping" をクリックして、ボーンの対応を見ます。表示はSceneウィンドウの方がGameウィンドウよりも見やすいかもしれません。
data:image/s3,"s3://crabby-images/b4eaa/b4eaa45800e3e4186f1ad5f1bb7ffd8accdb6079" alt=""
Inspectorウィンドウで "Muscles & Settings" をクリックして、スライダを動かして各ボーンが正しく動作するかを確認します。確認できたら "Done" をクリックします。
data:image/s3,"s3://crabby-images/7f056/7f056c6a086ed515cdd076930a1ed708ed28e5aa" alt=""
Hierarchyに地面となる Planeを配置します。InspectorのTransformの からResetを選んで、Position (x,y,z)=(0,0,0)にします。
GameObject → 3D Object → Plane
data:image/s3,"s3://crabby-images/6b923/6b923e8b6722b8ce37eafa30081b371240f91b89" alt=""
Hierarchy に Assets/Models/AsianBoy を配置する。
- Assets/Models から AsianBoy を Hierarchy にドラッグする。
data:image/s3,"s3://crabby-images/287a0/287a039226102c98ecc65334dc812bc2d1191bd9" alt=""
- InspectorのTransformのから Resetを選択して、Position (x,y,z)=(0,0,0)とする。
- InspectorでAdd Componenct をクリックして、Physics/CharacterController コンポーネントを追加する。
data:image/s3,"s3://crabby-images/13a27/13a2767f50304def6ac43775acded6383c0c3352" alt=""
- AsiznBoy の Inspectorに追加された CharacterController コンポーネントの Center と Height の値を変更する。
Sceneウィンドウを表示している状態で、Hierarchy 内で AsianBoy を選択すると、
CharacterController の Capsel Collider が緑色の実線で表示される。
人型キャラクタと合致するように Center と Height の値を変更する。
ここでは Center (x,y,z)=(0,0.87,0), Height = 1.7 とした。
data:image/s3,"s3://crabby-images/23346/233466e3f70d085682eb9da38166990284fb42e5" alt=""
ユーザからの入力を扱う
Unity では「従来からの Input System」と「2020 以降に導入された新しい Input System」の2種類の
入力方式が利用可能であり、これらはプロジェクトの設定で切り替えることができる。
どちらの System にも長所と短所があるが、以下では簡単のため「従来のInput System」を使う例を説明する。
- Package Manager で、"Cinematic" と "Input System" という2つのパッケージがインストールされていることを確認する。
data:image/s3,"s3://crabby-images/24f6d/24f6d5b8a8f154f7895d0d0db6834ace4c7e7835" alt=""
- プロジェクトの設定で、2種類の Input System をどちらも利用可能 (
Both
) に設定する。設定を変更後は、Unity Editor の再起動が必要になる。
Top Menu Bar → Edit → Project Settings ... → Player → Other Settings → Configuration → Active Input Handling → Both
data:image/s3,"s3://crabby-images/d4e39/d4e39fb1d5d1c6fd9b13170ff7b37d66cb7cb83d" alt=""
人型キャラクタを移動させるスクリプトを作成する。
- Projectウィンドウの Assets で右クリック → Create → Folder → Scripts として フォルダを生成し、Scriptsにrenameする。
data:image/s3,"s3://crabby-images/917c0/917c05dd84a31aa625c8a98e8aa994b0119a6f00" alt=""
- ProjectウィンドウのAssets/Scriptsで右クリック -> Create -> C# Script として C#のファイルを生成し、PlayerMoveにrenameする。
data:image/s3,"s3://crabby-images/719fc/719fcc9d13df3d880de854ae5b98a18c19ae6e86" alt=""
- ProjectウィンドウのAssets/Scripts/PlayerMoveを Hierarchy の AsianBoyの上へドラッグする。Hierarchy のAsianBoyを選択すると、Inspectorウィンドウに "Player Move (Script)" コンポーネントが追加されたことがわかる。
data:image/s3,"s3://crabby-images/ebb3e/ebb3e0198b13dab659e7b1af0fc4b4974d92c3d5" alt=""
ProjectウィンドウのAssets/Scriptsの中の PlayerMove.cs を次のように変更する。
PlayerMove.cs |
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class PlayerMove : MonoBehaviour
{
public float velocity = 1.3f;
private CharacterController charController;
void Start()
{
charController = gameObject.GetComponent<CharacterController>();
}
void Update()
{
float h = Input.GetAxis("Horizontal");
float v = Input.GetAxis("Vertical");
Vector3 moveDirection = new Vector3(h, 0, v);
charController.Move(velocity * Time.deltaTime * moveDirection);
}
}
|
Hierarchy の中の Main Camera の位置を変更する。
Plane はxz平面上の平面で、原点を中心として 10x10 の大きさである。
また、AsianBoyは原点にいる。
Main Camera が少し離れ過ぎているので Plane の端である Transform Position (x,y,z)=(0,1,-5)に設定する。
data:image/s3,"s3://crabby-images/891b8/891b8660f41f63349c395c206dbaf404c50d1bb3" alt=""
"Run"ボタンをクリックして、実行してみる。
「矢印キー (↑↓←→)」または「w/s/a/d キー」で AsianBoy が前後左右に動作する。地面からはみ出しても落下せずに、そのまま平行移動することがわかる。
data:image/s3,"s3://crabby-images/a4610/a46109d896f410ac18a4c8daef353a43983c2d82" alt=""
シーンを Assets/Scenes/Scene01.unity として保存する。
Top Menu Bar → File → Save as ... → Scene01
ProjectウィンドウのAssets/Scripts に PlayerMove2.cs を生成して、内容は PlayerMove.cs から以下の変更を加えたものとする。
PlayerMove2.cs |
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class PlayerMove2 : MonoBehaviour
{
public float velocity = 1.3f;
private CharacterController charController;
void Start () {
charController = gameObject.GetComponent<CharacterController>();
}
void Update () {
float h = Input.GetAxis("Horizontal");
float v = Input.GetAxis("Vertical");
Vector3 moveDirection = new Vector3(h, 0, v);
moveDirection.y += Physics.gravity.y;
charController.Move(velocity * Time.deltaTime * moveDirection);
}
}
|
Hierarchy ウィンドウの AsianBoy に Add Component する。PlayerMove.cs は Disable しておく。
data:image/s3,"s3://crabby-images/21e1f/21e1fae5bd7b459f8362285815d4864047f1c5f7" alt=""
実行すると、AsianBody地面からはみ出すと落下するようになる。
Assets/Scens/ にシーンを Scene02 として保存しておく。
作成したプロジェクトのzipファイル。
Unity プロジェクトの作成環境:
PC: MacBookAir (M1, 2020)
macOS: Ventura 13.5.1
Unity Hub: 3.5.1
Unity: 2021.3.16f1 (Intel)