- Unityで新しいプロジェクトを開始します。
"Mecanim" という "3D" 形式のプロジェクトを NEW しています。
data:image/s3,"s3://crabby-images/0bb6b/0bb6b8a5c23c291e1b1a20c6790fc61d64d175d0" alt=""
- 人型モデル(fbx)をUnityに取り込みます
- Assets -> Create -> Folder として "Models" という名前のフォルダをアセットに作成します。
- Explorer で
「MakeHuman で Unity5 で使用する人型モデルを作成する」
で作成した AsianBoy.fbx と textures/ があるフォルダを開きます。
そこから、UnityのProjectウィンドウの Assets/Models/ に
AsianBoy.fbx と textures/ フォルダをドラッグしてインポートします。
data:image/s3,"s3://crabby-images/6eff6/6eff679f01e06ae0246e09510276f2da8f4d0ae7" alt=""
[注意]上の操作は
Assets -> Import New Asset... -> AsianBody.fbx
から行なってもよいのですが、これだとAsianBoy.fbx に必要なtextureが
自動ではimportされず、モデルが真っ白になってしまいます。
この場合は Assets/Models/Materials/に生成された白いMaterialに対応する
Textureを手動でimportしなくてはいけません。
data:image/s3,"s3://crabby-images/a1ae8/a1ae894948aa71f280bd1c81808b092ac9c8f268" alt=""
- ProjectウィンドウでAsianBoyを選択をして、
Inspectorウィンドウで "Rig" で Animation Type を "Humanoid" に変更し、
Avatar Definition を "Create From This Model" のままとして、
"Apply"ボタンをクリックします。
data:image/s3,"s3://crabby-images/dd3f5/dd3f50ad6e6238d336744e254f754687cbd953c3" alt=""
- Inspectorウィンドウで "configure" をクリックして、ボーンが正しく設定されたか確かめておいた方が安全です。
data:image/s3,"s3://crabby-images/40bae/40baee9cc688e9a75d95088b2733ab42908b33b9" alt=""
- Inspectorウィンドウで "Mapping" をクリックして、ボーンの対応を見ます。表示はSceneウィンドウの方がGameウィンドウよりも見やすいかもしれません。
data:image/s3,"s3://crabby-images/f3b14/f3b140f89d8132f0ccd5fd8be9f1c34733b0e78f" alt=""
- Inspectorウィンドウで "Muscles & Settings" をクリックして、スライダを動かして各ボーンが正しく動作するかを確認します。確認できたら "Done" をクリックします。
data:image/s3,"s3://crabby-images/7574d/7574de0308541ba4781186e6cf1d814b143d7581" alt=""
- Hierarchyに地面となる Planeを配置します。InspectorのTransformの
からResetを選んで、Position (x,y,z)=(0,0,0)にします。
GameObject -> 3D Object -> Plane
data:image/s3,"s3://crabby-images/9754c/9754ce8ac468554da2732f29b10a0d9a05193600" alt=""
- Hierarchy に Assets/Models/AsianBoy を配置します。
- Assets/Models から AsianBoy を Hierarchy にドラッグします。
data:image/s3,"s3://crabby-images/29dee/29deea956a394f4dd7042b31234206862bcbb3e2" alt=""
- InspectorのTransformの
から Resetを選択して、Position (x,y,z)=(0,0,0)とします。
- InspectorでAdd Componenct をクリックして、Physics/CharacterController コンポーネントを追加します。
data:image/s3,"s3://crabby-images/dd748/dd74888271d9c59f55b40aa177d3f0eefce51ed6" 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/337cc/337ccadc5ba7fe960132d0e28480fac39ac49382" alt=""
- 人型キャラクタを移動させるスクリプトを作成します。
- Projectウィンドウの Assets で右クリック -> Create -> Folder -> Scripts として
フォルダを生成し、Scriptsにrenameします。
data:image/s3,"s3://crabby-images/0f87a/0f87a44bb985c66acc99ac8453d1d2c3de6798fe" alt=""
data:image/s3,"s3://crabby-images/9544b/9544bc8bc927a42b654564f411a81ed5187d1279" alt=""
- ProjectウィンドウのAssets/Scriptsで右クリック -> Create -> C# Script として
C#のファイルを生成し、PlayerMoveにrenameします。
data:image/s3,"s3://crabby-images/09044/09044434800af93055bb4e5b5e66a766c3433acc" alt=""
data:image/s3,"s3://crabby-images/8bf48/8bf48f1e383a3f306810a0bad83af42cab610de1" alt=""
- ProjectウィンドウのAssets/Scripts/PlayerMoveを Hierarchy の AsianBoyの上へドラッグし、
HierarchyのAsianBoyが青い楕円で囲まれている状態でドロップします。
data:image/s3,"s3://crabby-images/86683/86683a437d2a866a570a3f6d23699f44b0a3cd4e" alt=""
- Hierarchy のAsianBoyを選択すると、Inspectorウィンドウに
"Player Move (Script)" コンポーネントが表示されるようになったので、
追加されたことがわかります。
data:image/s3,"s3://crabby-images/95b03/95b0354f066f96471d80524cfac97ff7bec4af63" 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/14a53/14a53ad2940b89cb65d2068ecc763afda388adcf" alt=""
をクリックして実行してみます。
キーボードの矢印キー(↑, ↓, ←, →)または 'w, 'a', 's', 'd'
キーで AsianBoy が移動します。でも空中に浮いてしまっています。
data:image/s3,"s3://crabby-images/9c920/9c92078906259e16118d43cba2163d8add6bd5ef" alt=""
- Projectウィンドウの Assets/Scripts/PlayerMove を次のように変更します。
Playerを動かす時に、重力による加速度を考慮するようにします。
赤い文字の部分が追加された1行です。
これで AsianBoy が Plane の端を越えて移動すると、落下するようになりました。
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);
moveDirection.y += Physics.gravity.y;
charController.Move(velocity * Time.deltaTime * moveDirection);
}
}
|
- Projectウィンドウの Assets/Scripts/PlayerMove をさらに次のように変更します。
足が地面に接地しているときだけ、キーボード操作で移動できるようにします。
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(0, 0, 0);;
if (charController.isGrounded) {
moveDirection = new Vector3(h, 0, v);
}
moveDirection.y += Physics.gravity.y;
charController.Move(velocity * Time.deltaTime * moveDirection);
}
}
|
- Sceneを保存します。
- ProjectウィンドウのAssetsで右クリックして、Sceneを保存するフォルダを作成します。
data:image/s3,"s3://crabby-images/ac3e0/ac3e0f752e587656dd636d35937007f57fd4cd08" alt=""
data:image/s3,"s3://crabby-images/88633/88633ea2b4b0c1f1461997c7ffee24c6196b31c7" alt=""
- ProjectウィンドウのAssets/Scenes にSceneを PlayerMove.unity として保存します。
File -> Save Scene as ... -> PlayerMove
data:image/s3,"s3://crabby-images/40136/401365e65efbd4db006bbc964b05be8f19d6b6c2" alt=""
- ここで説明した Unity のプロジェクトファイルはこちら Mecanim.zip。