- Unityで新しいプロジェクトを開始します。
"Mecanim" という "3D" 形式のプロジェクトを NEW しています。
data:image/s3,"s3://crabby-images/65a79/65a7915885492583499a3bbb8451adc2905cfbfe" 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/cc7ba/cc7ba01618955e212b115095e04dd20be1bd7f37" alt=""
[注意]上の操作は
Assets -> Import New Asset... -> AsianBody.fbx
から行なってもよいのですが、これだとAsianBoy.fbx に必要なtextureが
自動ではimportされず、モデルが真っ白になってしまいます。
この場合は Assets/Models/Materials/に生成された白いMaterialに対応する
Textureを手動でimportしなくてはいけません。
data:image/s3,"s3://crabby-images/bc8d5/bc8d5fb3fd403f41f19f6798ee03480f6837fb3b" alt=""
- ProjectウィンドウでAsianBoyを選択をして、
Inspectorウィンドウで "Rig" で Animation Type を "Humanoid" に変更し、
Avatar Definition を "Create From This Model" のままとして、
"Apply"ボタンをクリックします。
data:image/s3,"s3://crabby-images/cd30b/cd30bf51e35f332ba1a6ff4cf38e4798285dbf86" alt=""
- Inspectorウィンドウで "configure" をクリックして、ボーンが正しく設定されたか確かめておいた方が安全です。
data:image/s3,"s3://crabby-images/db56a/db56aa524f3a782c2fd522f7ff129855a38d5155" alt=""
- Inspectorウィンドウで "Mapping" をクリックして、ボーンの対応を見ます。表示はSceneウィンドウの方がGameウィンドウよりも見やすいかもしれません。
data:image/s3,"s3://crabby-images/14a7d/14a7d5658ced3dad4dfe663ba6d64f4f00fa378f" alt=""
- Inspectorウィンドウで "Muscles & Settings" をクリックして、スライダを動かして各ボーンが正しく動作するかを確認します。確認できたら "Done" をクリックします。
data:image/s3,"s3://crabby-images/c6c6a/c6c6a744e448ca9306938074df09e3d1410048ec" alt=""
- Hierarchyに地面となる Planeを配置します。InspectorのTransformの
からResetを選んで、Position (x,y,z)=(0,0,0)にします。
GameObject -> 3D Object -> Plane
data:image/s3,"s3://crabby-images/21478/214782996f4259cf97b67c7deb1f654ae515df78" alt=""
- Hierarchy に Assets/Models/AsianBoy を配置します。
- Assets/Models から AsianBoy を Hierarchy にドラッグします。
data:image/s3,"s3://crabby-images/58841/58841f7d04787976199b27f7e0d0be7af48caf3d" alt=""
- InspectorのTransformの
から Resetを選択して、Position (x,y,z)=(0,0,0)とします。
- InspectorでAdd Componenct をクリックして、Physics/CharacterController コンポーネントを追加します。
data:image/s3,"s3://crabby-images/4f825/4f825c0a1ca923d50720819a60e5ae2277842611" 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/cd84a/cd84ae82fbdbb182b2bcf4a8e86be8d2516a9457" alt=""
- 人型キャラクタを移動させるスクリプトを作成します。
- Projectウィンドウの Assets で右クリック -> Create -> Folder -> Scripts として
フォルダを生成し、Scriptsにrenameします。
data:image/s3,"s3://crabby-images/867b2/867b29f8fbc7e5caa49ec4b8dfe1c5c7496edd6c" alt=""
data:image/s3,"s3://crabby-images/1cfb9/1cfb9ef9e26328f25e66a18840d0f50f4b70efb3" alt=""
- ProjectウィンドウのAssets/Scriptsで右クリック -> Create -> C# Script として
C#のファイルを生成し、PlayerMoveにrenameします。
data:image/s3,"s3://crabby-images/ced5d/ced5da4633b98fb22e05fa63a7fc7a47ce74a338" alt=""
data:image/s3,"s3://crabby-images/96fd8/96fd8973db741872e3481e845150365be888cce8" alt=""
- ProjectウィンドウのAssets/Scripts/PlayerMoveを Hierarchy の AsianBoyの上へドラッグし、
HierarchyのAsianBoyが青い楕円で囲まれている状態でドロップします。
data:image/s3,"s3://crabby-images/e34ea/e34eac523a9dc5e454dccee37352722104e56dbc" alt=""
- Hierarchy のAsianBoyを選択すると、Inspectorウィンドウに
"Player Move (Script)" コンポーネントが表示されるようになったので、
追加されたことがわかります。
data:image/s3,"s3://crabby-images/8e7ba/8e7bac4150738308035481d44833d378f3dfbc92" 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/73f64/73f6438bba4e5d4768d593c7e5da233de6cae471" alt=""
をクリックして実行してみます。
キーボードの矢印キー(↑, ↓, ←, →)または 'w, 'a', 's', 'd'
キーで AsianBoy が移動します。でも空中に浮いてしまっています。
data:image/s3,"s3://crabby-images/30c3b/30c3bcde688d85d6715335e41d8825a869266ea8" 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/d5ab8/d5ab82dfe3df4223136a92daccc8a68c5d923c66" alt=""
data:image/s3,"s3://crabby-images/633b9/633b9616e36e24701c003a59f895845a8553e361" alt=""
- ProjectウィンドウのAssets/Scenes にSceneを PlayerMove.unity として保存します。
File -> Save Scene as ... -> PlayerMove
data:image/s3,"s3://crabby-images/cfb26/cfb260f8cc8df7d7abd6e42278cca3213dda71c2" alt=""
- ここで説明した Unity のプロジェクトファイルはこちら Mecanim.zip。