解説

コンポーネント操作(UnityならではのC#)【Unityの教科書#3】

コンポーネントとは?

Components (コンポーネント) はゲームオブジェクトに付いた「部品」です。ゲームオブジェクトにコンポーネントという部品を付けることで、そのゲームオブジェクトはコンポーネントに応じた機能を持ちます。位置・回転・大きさを管理するTransformや物理的な挙動を制御するRigidbodyなど、多岐にわたるコンポーネントが用意されています。後に出てきますがゲームオブジェクトにアタッチしたScriptもコンポーネントです。

このページでは特に使うコンポーネントについて解説します。

Transform

Transformposition(位置)、rotation(回転)、scale(大きさ)の情報を持った、どのゲームオブジェクトにも存在する最も基本的なコンポーネントです。

TransformをScriptから変更してみよう

#1ではTransformについて少し触れましたね。ここではさらにScriptを用いてTransformを変更する方法についてやっていきましょう。

では、もう一度長方形を作成してください。

作成できたら次に、プロジェクトウィンドウでCreate > C# Scriptと選び、「SquarePositioner」という名前のC# Scriptを作成してください。作成できたら開いてください。開けたら、コードを以下のように変更してください。

C#スクリプトのファイル名とクラス名は同じにしましょう。
(厳密にはMonoBehaviourを継承するクラスは名称を揃える必要がありますが今は気にしないでください)

using UnityEngine;

public class SquarePositioner : MonoBehaviour
{
    Transform tr;
    void Start()
    {
        //Transformコンポーネントを取得して変数trに格納する
        tr = GetComponent<Transform>();
        //開始時に位置を移動させる
        tr.position = new Vector2(0, 2);
    }
}

変更できたら、SquareにScriptをアタッチして実行してみましょう。

すると、位置が上に変わりましたね。

本来、Scriptからコンポーネントを取得して変更する場合には必ずGetComponent<取得したいコンポーネント>()のように書く必要がありますが、Transformには特殊なアクセス方法が用意されています。

では、先ほどのコードを以下のように書き換えてください。

using UnityEngine;

public class SquarePositioner : MonoBehaviour
{
    void Start()
    {
        //開始時に位置を以下のように場所に移動させる
        transform.position = new Vector2(0, 2);
    }
}

変更できたら、実行してみましょう。

すると、同様に位置が変わりましたね。

transformと書くだけで、GetComponent<Transform>()と同じ意味になります。GetComponentを使用するよりもtransformを使用するほうが内部処理が早いのでtransformコンポーネントにScriptから変更を加えたい場合にはこちらの方法を使いましょう。

Input.GetKeyでキー入力を取得しよう

ゲームの中で最も大事といっても過言ではないキーボード入力の実装についてここで扱いたいと思います。キーボードの入力ができなければ何も操作できませんしね。というわけでやっていきましょう!

では、C# Scriptを開いてください。開けたら以下のコードをUpdate関数の中に入力してください。

    void Update(){
    Debug.Log(Input.GetKey(KeyCode.Space));
    //Spaceキーが入力されていればtrueを、されていなければfalseを出力する
    }

Ctrl+Sで保存しましたか?それでは実行してみましょう。

するとコンソールがFalseで埋め尽くされます。

ではSpaceキーをしばらく押してみてください。

すると、今度はTrueでコンソールが埋め尽くされますね。

これで、Input.GetKey(KeyCode.Space)がどういう働きをするかが分かったかと思います。キーが入力されている間はTrueを、そうでないときはFalseを返します。つまりBool値が返ってくるというわけですね。

Bool値が返ってくるということはif文と相性がよさそうですね。ではif文を用いてさっきのコードを少し書き換えてみましょう。

    void Update()
    {
        if (Input.GetKey(KeyCode.Space)) {
             Debug.Log("Spaceキーが押されています");
         }
          //キーが入力されたら{}内の処理を実行する
     }

それでは実行してみましょう。

すると、今度はコンソールに何も出ませんね。

では、Spaceキーを入力してみましょう。すると…?

押している間だけDebug.Logで設定したメッセージが出力されましたね。

基本的に、Input.GetKeyはこのようにif文と組み合わせて使います。

また、Input.GetKeyはキーが押されている間ずっとTrueを返します。押された瞬間だけの判定が欲しいときにはInput.GetKeyDownを、離した瞬間だけの判定が欲しいときにはInput.GetKeyUpを使いましょう。

様々な入力

他にも様々な入力(キーボード、マウス、ゲームパッド)を受け付ける方法があります。代表的なものを紹介しておきます。

メソッド/プロパティ説明
Input.GetKeyDown(KeyCode key)指定したキーが押された瞬間かどうかを取得
Input.GetKey(KeyCode key)指定したキーが押されているかどうかを取得
Input.GetAxis("Horizontal")水平方向の入力値を取得(左が-1、右が1
Input.GetAxis("Vertical")垂直方向の入力値を取得(下が-1、上が1
Input.GetKeyUp(KeyCode key)指定したキーが離された瞬間かどうかを取得
Input.GetMouseButtonDown(int button)指定したマウスボタンが押された瞬間かどうかを取得
Input.GetMouseButton(int button)指定したマウスボタンが押されているかどうかを取得
Input.GetMouseButtonUp(int button)指定したマウスボタンが離された瞬間かどうか
Input.mousePositionマウスカーソルの現在位置をスクリーン座標で取得

Input Managerに代わる新しいInput System

最近では、今回紹介した従来の入力方法(Input Manager)に変わるものとしてInput Systemというものがあります。これは様々な入力システムを統一的に扱えたりします。例えば、キーコンフィグをより簡単に設定できます。現在Input Systemを使うにはパッケージマネージャーでプロジェクトにインストールする必要があり、インストールしていなければ従来のInput Managerをデフォルトとして使います。

これで、キー入力については終わりです。

Rigidbody 2D, Collider 2Dを使ってみよう

Rigidbody/Rigidbody 2Dとは、アクションゲームでは最も重要である物理演算を行うためのコンポーネントです。これを使えば重力に従って落下したり、キャラクターに動きを与えたりすることができます。

Collider/Collider 2Dとは、これもまたアクションゲームで最も重要である当たり判定を取るためのコンポーネントです。これを使えばモンスターに当たったときの処理や、床を作るなどのことができます。

3Dの物理演算の場合はRigidbody、Colliderを、2Dの物理演算の場合はRigidbody 2D、Collider 2Dを用います。

どちらも大事なので、必ずマスターしましょう!

では、まずはRigidbody 2Dから見ていきましょう。

Rigidbody 2Dについて

前述のとおり、Rigidbody 2Dとは物理演算を行うのに必要なコンポーネントです。

一度、どういう動きになるのか見てみましょう。

まずは、Squareを追加しましょう。追加できたらシーンビューの中央(カメラのマークがあるあたり)に持っていきましょう。

できたら、実行してみてください。

すると、こうなりますね。画面中央に動きは全くない状態であると思います。確認出来たら停止してください。

では、インスペクターからRigidbody 2Dを追加してください。追加できたら再度実行しましょう。

すると、このようにして落下していき、やがて画面外に出ていきます。

つまり、Rigidbody 2Dを追加したことによってSquareが重力の影響を受けて落下するようになりましたね。

では、インスペクターからRigidbody 2Dの中身を少し見ていきましょう。

ここから抜粋して説明します。

Body TypeStatic、Dynamic、Kinematicの3つがある。(下記説明)
Mass質量を設定できる。
Gravity Scale受ける重力の影響を設定できる。1.0が標準の重力、0.0で重力を無効化できる。
Collision Detection接触判定の方法。DiscreteとContinuousの2つがある。(下記説明)
Freeze RotationZ軸方向の回転を無効にできる。

Staticは重力や他の力の影響を全く受けない。物理演算をしない状態。
Dynamicは通常の物理演算を行う状態。

Discreteは離散的の意。接触判定を毎フレームごとに行うモード。通常はこちらで十分。
Continuousは連続的の意。接触判定を常時行うモード。主に高速の物体の演算のような離散的ではすり抜けてしまう可能性がある場合に用いる。

Kinematicは重力や他の力を全く受けないが、ScriptでRigidbodyの速度などをいじって移動は可能。(Staticは不可)

Collider 2Dについて

こちらは前述のとおりいわゆる当たり判定を取るのに使うコンポーネントです。

一度挙動を見ておきましょう。

では、もう1つSquareを追加してください。追加できたら、シーンビューのカメラの範囲にギリギリ入るように移動させて、横に伸ばしてください。

それでは実行してみましょう。

すると…?

はい、すり抜けましたね(笑)
当たり判定がないので、当然すり抜けます。

では、当たり判定を付与してみましょう。どちらのSqaureにもインスペクターからBox Collider 2Dを追加してください。追加できたら再び実行してみましょう。

すると、思った通りに上に乗って止まってくれましたね。

ここでは四角形の接触判定を使いたかったのでBox Collider 2Dを使用しましたが、必要な形状に応じて他のColliderを使用しましょう。Collider 2Dの種類を紹介しておきます。

Collider 2Dの種類説明
Box Collider 2D矩形形状のコライダー。四角いオブジェクトやタイルに適しています。
Circle Collider 2D円形のコライダー。球や円形のオブジェクトに適しています。
Polygon Collider 2D多角形のコライダー。任意の形状のオブジェクトに合わせて、頂点を自由に設定できます。(頂点数は多くなると重くなるのでできるだけ少ないほうが好ましい)
Edge Collider 2D線形のコライダー。地形の輪郭や障害物のエッジに適しています。
Capsule Collider 2Dカプセル形状のコライダー。キャラクターなど、上下に長いオブジェクトに適しています。
Composite Collider 2D複数のコライダーを組み合わせて一つの複合コライダーとして扱えます。複雑な形状のオブジェクトに適しています。

コライダーは不可視なので必ずしも見た目と同じ形にする必要はありません。例えば、攻撃の当たり判定が広すぎると遊ぶ人が理不尽と感じることもありますので気をつけましょう。

Collider 2Dの中のIs Triggerについて

このチェックボックスにチェックを入れると、接触判定は取るが、物体同士が接触しても通過するようになります。

ゲームオブジェクトをジャンプさせてみよう

では、いよいよゲームっぽいことをしてみましょう。ゲームオブジェクトをジャンプさせてみます。

新しくC# Scriptを作成してください。名前は「SquareJump」としておきましょう。

作成できたらSquareJumpの中身を次のコードに書き換えてください。

using UnityEngine;

public class SquareJump : MonoBehaviour
{
    Rigidbody2D rb2d; //Rigidbody2Dのコンポーネントをrb2dと省略
    void Start() {
        rb2d = GetComponent<Rigidbody2D>();
    }
    void Update() {
        //スペースが入力されたらジャンプする
        if (Input.GetKeyDown(KeyCode.Space)) {
            rb2d.velocity = new Vector2(0, 10f);
        }
    }
}
Unity 6の場合
using UnityEngine;

public class SquareJump : MonoBehaviour
{
    Rigidbody2D rb2d; //Rigidbody2Dのコンポーネントをrb2dと省略
    void Start() {
        rb2d = GetComponent<Rigidbody2D>();
    }
    void Update() {
        //スペースが入力されたらジャンプする
        if (Input.GetKeyDown(KeyCode.Space)) {
            rb2d.linearVelocity = new Vector2(0, 10f);
        }
    }
}

もしくは

using UnityEngine;

public class SquareJump : MonoBehaviour
{
    Rigidbody2D rb2d; //Rigidbody2Dのコンポーネントをrb2dと省略
    void Start() {
        rb2d = GetComponent<Rigidbody2D>();
    }
    void Update() {
        //スペースが入力されたらジャンプする
        if (Input.GetKeyDown(KeyCode.Space)) {
            rb2d.linearVelocityY = 10f;
        }
    }
}

では、実行してみましょう。

ジャンプさせることができましたね。

Collider 2Dでの衝突感知

まずは、Spaceキーを押している間にコンソールメッセージが出ると困るのでそれらの処理を以下のようにコメントアウトしましょう。(→コメント(#2))

        /*if (Input.GetKey(KeyCode.Space) == true) {
            Debug.Log("Spaceキーが押されています");
        }*/

これで『Spaceキーが押されています』は出なくなりました。

では、再度SquareJumpを開いて、Update関数の下に次の関数を書き足してください。

    void Update(){
         /*if (Input.GetKey(KeyCode.Space) == true) {
            Debug.Log("Spaceキーが押されています");
        }*/
    }
    void OnCollisionEnter2D(Collision2D collision) {
        Debug.Log("ぶつかった");
    }

OnCollisionEnter2D関数はStart関数と同じようにUnityに設定されたメソッドで、ゲームオブジェクトのcolliderが、他のcolliderと衝突したとき実行されます。(引数のCollision2D collisionは今回は関係ありません。後述。)

上記のコードを保存し、ゲームを実行してみましょう。

すると、Squareが床に衝突した瞬間に「ぶつかった」と出力されます。

ジャンプをしてから床に衝突しても「ぶつかった」と出力されますね。

Tagで衝突したオブジェクトを仕分ける

天井のゲームオブジェクトを追加しましょう。床を作ったときと同じ手順で追加してください。
追加できたら再度実行しましょう。

すると、床と天井どちらにぶつかっても「ぶつかった」と出ることがわかります。

しかし、ゲームを作る際、床と天井にぶつかったときに処理を分けたいときがあるかもしれませんね。このままではどちらにぶつかっても処理が同じになってしまいますね。そこでTagというものを使います。

床のゲームオブジェクトをクリックしてください。わかりずらいのでインスペクターから名前を変更しましょう。

ここをクリックして床に変更してください。また同様にして天井も変更しましょう。

次に、床のTagを設定しましょう。

ここをクリックしてください。

次に、Add Tagを選択してください。するとインスペクターの画面が切り替わります。次にここをクリックしてください。

すると、Tagの名前を設定する画面が出てくるので、Floorと入力しましょう。

入力できたらSaveをクリックして、床を選択してTagをFloorに変更しましょう。

同様にして天井にCeilingという名前のTagを付けてください。

また、ここでは床や天井かどうかを判定させるためにTagという機能を使いましたが、Tagはゲームオブジェクトの種類を区別するために用いるものです。アイテムなどにも使用することができます。

Tagをつけ終わったら、先ほど書いたコードを以下のように変更してください。

    void OnCollisionEnter2D(Collision2D collision) {
        if (collision.gameObject.tag == "Floor") {
            Debug.Log("床にぶつかった");
        }
        if (collision.gameObject.tag == "Ceiling") {
            Debug.Log("天井にぶつかった");
        }
    }

変更できたら実行してみましょう。

このように、床と天井で文章を分けることに成功しましたね。では、if文の条件式をよりきれいな形に書き換えてみましょう。CompareTagというメソッドを使って書き換えます。以下のコードに先ほどのコードを変更してください。

    void OnCollisionEnter2D(Collision2D collision) {
        //FloorというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Floor")) {
            Debug.Log("床にぶつかった");
        }
        //CeilingというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Ceiling")) {
            Debug.Log("天井にぶつかった");
        }
    }

変更できたら実行してみましょう。

先ほどと同じように動きましたね。

OnCollisionEnter2DがUnityによって実行されるとき、引数のcollisionにはぶつかった相手のゲームオブジェクトの情報が入力されます。

よって下記のように、ぶつかったゲームオブジェクトの名前を取得して出力することも可能です。

    void OnCollisionEnter2D(Collision2D collision) {
        //FloorというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Floor")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
        //CeilingというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Ceiling")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
    }

このコードに変更できたら実行してみましょう。

先ほどと同じ挙動になりましたね。

このようにして、ぶつかった相手の様々な情報を引き出して使用することができます。

BGMとSEを鳴らしてみよう!

音はゲームの体験をよりリアルにしてくれますよね。ここではBGMとSEの鳴らし方ついて解説していきます。

BGMを鳴らしてみよう

以下のBGMをダウンロードしてください。

このBGMは当サークルのサウンドクリエーター、セイさん作曲です。

ダウンロードが完了したら、Unity内にインポートして音源ファイルを取り込みます。

次に、SquareゲームオブジェクトにAudioSourceコンポーネントを追加します。
コンポーネントを追加したら、AudioSource>AudioClipに先程インポートした「gosikku1」をアタッチします。ついでに、AudioSource>Loopにチェックを入れておきましょう。

これでBGMの追加は完了です。さっそく実行してみましょう。

BGMを複数用意して切り替えたい場合には、Script上から変更しましょう。

音量調整

さて、実行した方はBGMの音量の大きさに驚いたことでしょう。これからびっくりしないためにも音量調節の方法を解説します。とはいっても、AudioSourceのVolumeを変更するだけです。

Volume右側「1」の数字を直接変更してもOK。0~1の間で調節可!

変更したら再度実行して音量を確かめてください。

SEを鳴らしてみよう

ネットからジャンプ音を拾ってきましょう。拾ってきたら、BGMと同じ要領でUnity内にインポートしてください。

フリー音源の規約にはしっかりと注意しましょう。

インポートができたら、「SquareJump」のScriptを以下のように書き換えてください。

using UnityEngine;

public class SquareJump : MonoBehaviour
{
    public AudioClip jumpAudio;
    Rigidbody2D rb2d;
    AudioSource audioSource;

    void Start() {
        rb2d = GetComponent<Rigidbody2D>();
        audioSource = GetComponent<AudioSource>();
    }

    //Rigidbody2Dのコンポーネントをrb2dと省略
    void Update()
    {
        if (Input.GetKeyDown(KeyCode.Space)) {
            //スペースが入力されたらジャンプ音を鳴らす
            audioSource.PlayOneShot(jumpAudio);
            //スペースが入力されたらジャンプする
            rb2d.velocity = new Vector2(0, 10f);
        }
    }

    void OnCollisionEnter2D(Collision2D collision) {
        //FloorというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Floor")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
        //CeilingというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Ceiling")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
    }
}
Unity 6の場合
using UnityEngine;

public class SquareJump : MonoBehaviour
{
    public AudioClip jumpAudio;
    Rigidbody2D rb2d;
    AudioSource audioSource;

    void Start() {
        rb2d = GetComponent<Rigidbody2D>();
        audioSource = GetComponent<AudioSource>();
    }

    //Rigidbody2Dのコンポーネントをrb2dと省略
    void Update()
    {
        if (Input.GetKeyDown(KeyCode.Space)) {
            //スペースが入力されたらジャンプ音を鳴らす
            audioSource.PlayOneShot(jumpAudio);
            //スペースが入力されたらジャンプする
            rb2d.linearVelocity = new Vector2(0, 10f);
        }
    }

    void OnCollisionEnter2D(Collision2D collision) {
        //FloorというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Floor")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
        //CeilingというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Ceiling")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
    }
}

または

using UnityEngine;

public class SquareJump : MonoBehaviour
{
    public AudioClip jumpAudio;
    Rigidbody2D rb2d;
    AudioSource audioSource;

    void Start() {
        rb2d = GetComponent<Rigidbody2D>();
        audioSource = GetComponent<AudioSource>();
    }

    //Rigidbody2Dのコンポーネントをrb2dと省略
    void Update()
    {
        if (Input.GetKeyDown(KeyCode.Space)) {
            //スペースが入力されたらジャンプ音を鳴らす
            audioSource.PlayOneShot(jumpAudio);
            //スペースが入力されたらジャンプする
            rb2d.linearVelocityY = 10f;
        }
    }

    void OnCollisionEnter2D(Collision2D collision) {
        //FloorというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Floor")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
        //CeilingというTagのゲームオブジェクトに衝突したときの処理
        if (collision.gameObject.CompareTag("Ceiling")) {
            Debug.Log(collision.gameObject.name + "にぶつかった");
        }
    }
}

AudioSourceは音を再生するコンポーネントで、AudioClipは音声ファイルのことです。

public AudioClip jumpAudio;

の部分を今回は、

[SerializeField] AudioClip jumpAudio;

としてもいいが、詳しくは#4の記事を参照

保存できたら、Unityの画面に戻ってください。

Squareを選択し、インスペクターを見ると、SqaureJumpのコンポーネントにAudioClipをアタッチできるようになっていると思うのでアタッチしてください。

アタッチできたら実行してみましょう。

PlayOneShotは複数のSEを重ねて鳴らすときに便利なメソッドです。

Playメソッドでは重複して音を鳴らすことはできません。1度前の音を止めてから再度実行する必要があります。

PlayOneShotメソッドは同時に複数の音を鳴らすことができます。前の音を止める必要はありません。

左右移動について

やはりゲームでは上下移動だけでなく左右移動も大切ですよね。ここでは左右移動について扱います。ですが、ジャンプとやることは本質的には変わりません。

左右移動

その前にまずは、壁を追加しましょう。マップ外に出てしまうのは困りますからね。

床、天井と同様にして壁を追加してください。追加したら名前をそれぞれ「左壁」、「右壁」として、「Wall」というTagを作ってつけておきましょう。

できたら、SquareJumpのUpdate関数に以下のコードを追加して下さい。

        if (Input.GetKey(KeyCode.A)) {
            //Aが入力されたら左に移動する
            rb2d.velocity = new Vector2(-10f, 0);
        }
        if (Input.GetKey(KeyCode.D)) {

            //Dが入力されたら右に移動する
            rb2d.velocity = new Vector2(10f, 0);
        }
Unity 6の場合
if (Input.GetKey(KeyCode.A)) {
            //Aが入力されたら左に移動する
            rb2d.linearVelocitty = new Vector2(-10f, 0);
        }
        if (Input.GetKey(KeyCode.D)) {

            //Dが入力されたら右に移動する
            rb2d.linearVelocity(new Vector2(10f, 0);
        }

または

if (Input.GetKey(KeyCode.A)) {
            //Aが入力されたら左に移動する
            rb2d.linearVelocityX = -10f;
        }
        if (Input.GetKey(KeyCode.D)) {

            //Dが入力されたら右に移動する
            rb2d.linearVelocityX = 10f;
        }

追加できたら実行してみましょう。

実行してみるとわかると思うのですが、何か挙動が変な感じがすると思います。左右移動しているときにはジャンプが効かずに音だけがし、逆にジャンプをすると左右方向の慣性が止まってしまいますね。これは、コードを見るとわかるんですが、ジャンプしたときにx軸方向の速度が0に、左右移動したときにはy軸方向の速度が0になるようになっていますね。ではここを修正しましょう。

Update関数の中身を以下のコードに変更してください。

        if (Input.GetKeyDown(KeyCode.Space)) {
            //スペースが入力されたらジャンプ音を鳴らす
            audioSource.PlayOneShot(jumpAudio);
            //スペースが入力されたらジャンプする
            rb2d.velocity = new Vector2(rb2d.velocity.x, 10f);
        }
        if (Input.GetKey(KeyCode.A)) {
            //Aが入力されたら左に移動する
            rb2d.velocity = new Vector2(-10f, rb2d.velocity.y);
        }
        if (Input.GetKey(KeyCode.D)) {
            //Dが入力されたら右に移動する
            rb2d.velocity = new Vector2(10f, rb2d.velocity.y);
        }
Unity 6
        if (Input.GetKeyDown(KeyCode.Space)) {
            //スペースが入力されたらジャンプ音を鳴らす
            audioSource.PlayOneShot(jumpAudio);
            //スペースが入力されたらジャンプする
            rb2d.linearVelocity = new Vector2(rb2d.linearVelocityX, 10f);
        }
        if (Input.GetKey(KeyCode.A)) {
            //Aが入力されたら左に移動する
            rb2d.linearVelocity = new Vector2(-10f, rb2d.velocity.y);
        }
        if (Input.GetKey(KeyCode.D)) {
            //Dが入力されたら右に移動する
            rb2d.linearVelocity = new Vector2(10f, rb2d.velocity.y);
        }

または

        if (Input.GetKeyDown(KeyCode.Space)) {
            //スペースが入力されたらジャンプ音を鳴らす
            audioSource.PlayOneShot(jumpAudio);
            //スペースが入力されたらジャンプする
            rb2d.linearVelocityY = 10f;
        }
        if (Input.GetKey(KeyCode.A)) {
            //Aが入力されたら左に移動する
            rb2d.linearVelocityX = -10f;
        }
        if (Input.GetKey(KeyCode.D)) {
            //Dが入力されたら右に移動する
            rb2d.linearVelocityX = 10f;
        }

こうすることで、Spaceキーが入力されたときにx方向の速度を現在の速度に置き換え、A、Dキーが入力されたときにy方向の速度を現在の速度に置き換えるようになりました。つまり、現在の速度のまま置き換えないということですね。

変更できたら実行してみましょう。すると、慣性が消えなくなりましたね。

rigidbody.velocity.x、rigidbody.velocity.yは読み取り専用です。これを直接変更することはできません。そのため以下のようなコードの書き方はできません。

rb2d.velocity.x = 10f;
rb2d.velocity.y = 10f;

この書き方ができないので先ほどのようなコードの書き方になります。

Unity 6の場合

新しく、rigidbody.linearVelocityX、rigidbody.linearVelocityYの書き方が追加され、読み取り書き込みともにできるようになりました。そのため、以下のようなコードの書き方ができます。

rb2d.linearVelocityX = 10f;
rb2d.linearVelocityY = 10f;

移動方法比較

Unityではrigidbody.velocity以外にもゲームオブジェクトを移動できる処理があります。ここではその説明をします。ですが、基本的にはrigidbody.velocityを使うことをお勧めします。

transform.positionフレームごとに瞬間移動する挙動。一定速度ならTime.deltaTimeを掛ける必要がある。
rigidbody.velocity速度を指定できる。キャラクターの移動によく使われる。一定速度ならTime.deltaTimeは要らない。
rigidbody.positiontransform.positionと比較して物理エンジンの更新サイクルに合わせて更新される。一定速度ならTime.deltaTimeを掛ける必要がある。
rigidbody.AddForce力を加える。簡単に物理的に自然な動作にできる。
Unity 6の場合
transform.positionフレームごとに瞬間移動する挙動。一定速度ならTime.deltaTimeを掛ける必要がある。
rigidbody.linearVelocityUnity 6で追加された書き方。速度を指定できる。キャラクターの移動によく使われる。一定速度ならTime.deltaTimeは要らない。
rigidbody.linearVelocityX
rigidbody.linearVelocityY
Unity 6で追加された書き方。X方向、Y方向のみの速度を変更できる。キャラクターの移動によく使われる。一定速度ならTime.deltaTimeは要らない。
rigidbody.positiontransform.positionと比較して物理エンジンの更新サイクルに合わせて更新される。一定速度ならTime.deltaTimeを掛ける必要がある。
rigidbody.AddForce力を加える。簡単に物理的に自然な動作にできる。

一定速度が必要でTime.deltaTimeが必要なものはFixedUpdate内で呼び出すことでも解決できる。

FixedUpdateやTime.deltaTimeについては詳しくは別途記事を作成予定です。

ゲームオブジェクトの管理

ゲームを制作する上で、ゲームオブジェクトの管理は非常に重要です。管理、というとイマイチわかりずらいかもしれません。具体的な意味としては、ゲームオブジェクトを消したり、生成したりすることです。

これらを用いることで、条件を満たしたゲームオブジェクトを消滅させることができたり。逆に、条件を満たしたときにゲームオブジェクトを生成できたりもします。

前者は敵を倒したときの消滅処理、後者はシューティングゲームの弾を生成するときの処理に応用できますね。

では、それぞれの項目ごとに見ていきましょう。

ゲームオブジェクトをInspectorからチェックボックスで消す

一番基本的なことから進めます。

Hierarchyのゲームオブジェクトをクリックしてみてください。
インスペクタービューの左上のチェックを外すことで、そのゲームオブジェクトが表示されなくなっているのがわかると思います。同じようにアタッチされているコンポーネントもチェックボックスでON/OFFができます。

いきなり走っている人の画像が出ましたが、気にせず進めてください。

これらの使い道は制作のときに様々な方法で活かすことができます。
エラーの原因だと思われるのを特定したり、邪魔なものを一旦消しておいたり。

ですがこの方法ではエディタ上でゲームを実行する前にしかON,OFFの設定をできません。

ゲームを実行しているときにON/OFFする方法については、「ゲームオブジェクトのON/OFF」の項目で説明したいと思います。

Prefab

プレハブ(Prefab)は、ゲームオブジェクトのテンプレートのようなものです。プレハブは、一度作成されたゲームオブジェクトを再利用可能な形で保存し、同じゲームオブジェクトを複数回使用する必要がある場合や、複数のシーンで同じゲームオブジェクトを使用する場合に非常に便利です。

実際に作ってみましょう。

  1. Unityのプロジェクト内で、プレハブにしたいゲームオブジェクトを選択します。
  2. 選択したゲームオブジェクトをHierarchyビューまたはProjectビューから、Assetsフォルダー内の任意の場所にドラッグアンドドロップします。これにより、プレハブが作成されます。

プレハブ化したゲームオブジェクトはAssetsフォルダーからHierarchyビューにドラッグアンドドロップすることで、もう一度生成することができます。

また、Assetsフォルダー内のプレハブ元の設定を変更してみてください。そうすると、Hierarchyビューにあるゲームオブジェクトも変更していることがわかると思います。

この機能を使うことで、ゲーム制作中の変更にとても強くなります。

ゲームオブジェクトの生成

作成したプレハブを用いて、ゲームを実行したときにゲームオブジェクトを生成してみましょう。

ゲームオブジェクトを生成する方法として代表的なのは、Instantiate関数というものがあります。これを使ってみましょう。

Unity上でスクリプトを生成して、以下のコードを書いてください。

public class Test : MonoBehaviour
{
    public GameObject prefab; // インスタンス化するプレハブ

    void Start()
    {
        // プレハブから新しいインスタンスを生成し、変数に代入する
        GameObject instance = Instantiate(prefab);

        // 生成したインスタンスの位置を設定する(例:座標を指定)
        instance.transform.position = new Vector3(2, 2, 0);

    }
}

コードが書けたら、スクリプトをゲームオブジェクトにアタッチしてください。
Inspecter上から、プレハブをドラッグアンドドロップしてください。

そうしたら実行してみましょう。

ゲームオブジェクトが大量に生成されたと思います。これは、ゲームオブジェクトが生成されるたびにそのゲームオブジェクトにアタッチされているスクリプトのStartメソッドが呼び出されているので、無限増殖が発生していますね。

ゲームオブジェクトの破壊

逆に、ゲームオブジェクトを破壊する際にはDestroy関数を使います。

Destroy関数は、GameObjectやComponentをシーンから削除します。この操作は、オブジェクトがもはや必要なくなった時(例えば、敵キャラクターが倒された後)に使います。Destroyを呼び出すと、指定されたオブジェクトは現在のフレームの終わりに削除されます。

実際に実行してみましょう
以下のコードはオブジェクトを破壊するコードです。
以前書いたコードを消して、書いてみてください。

public GameObject prefab;
    // Start is called before the first frame update
    void Start()
    {
        Destroy(prefab);
    }

実行して、ヒエラルキーを見てみてください。
オブジェクトがなくなっているのがわかると思います。
言葉通り、本当に破壊しているんですね。

オブジェクトのON/OFF

さて、ゲームオブジェクトを生成することができました。ではこのゲームオブジェクトをオフ、破壊してみましょう。
ゲームオブジェクト単位でオフにする方法は以下のものがメインとなります。

  1. Destroy
  2. SetActive

コンポーネント単位()のオンオフは主に以下の方法があります。

  1. コンポーネント.enabledを変更する
  2. コンポーネント.Destroy()

それぞれについて、見ていきましょう。

SetActive

GameObjectのSetActiveメソッドは、オブジェクトのアクティブ/非アクティブ状態を切り替えるために使用されます。しかし、非アクティブ状態であってもGameObjectはシーン内に残り、再度アクティブにすることができます。

では、こちらも実際に実行してみましょう。
以下のスクリプトを書いてください。もちろん、以前書いた内容は消してください。

public GameObject prefab;
    // Start is called before the first frame update
    void Start()
    {
        prefab.SetActive(false);
    }

実行すると、オブジェクトが破棄されずに、OFF(チェックが外れている)になっているのが確認できると思います。

Destroyとの違いは、完全に破棄されるかどうかといった点です。SetActiveの場合は、trueにすることで再度オブジェクトをONにすることができます。

場合によって、使い分けていきましょう。

DestroyはSetActiveより少しだけ重いです。最初のうちはあまり意識しなくても良いですが、大きなゲームを作るようになったときのために知っておきましょう。

コンポーネント単位でのOFF

これはまず、具体例を示してみたいと思います。
以下のスクリプトを書いて、実行してみてください。

public GameObject prefab;
    Collider2D collider2D;
    // Start is called before the first frame update
    void Start()
    {
        prefab.GetComponent<Collider2D>().enabled = false;
    }

では、Unity上で実行してみてください。その時に、そのオブジェクトをクリックしてインスペクタービューをみてみましょう。
Collider2Dがオフになっています。

このように、ゲームオブジェクト単位ではなく、コンポーネント単位でのオンオフができるのがこの.enableという機能です。

Sprite Renderer

Unityで2Dゲームを作るときには欠かせないのが、Sprite Rendererです。Unity上で画像を表示したい時に必要なコンポーネントです。


上の画像の黄色部分になります。ですが画像に追加する必要はありません。
プロジェクトビューから画像をシーン上にドラッグアンドドロップすれば追加されています。
では、このコンポーネント上でよく使う機能を以下にまとめます。

Order In Layer

画像の重なりを示す数字です。この数字が大きいほどより手前に表示されます。

FlipX

画像をX軸に反転させるチェックボックスです。プレイヤーなどを方向転換させる時につかいます。

UI関連のコンポーネント

スコア、時間制限の表示があるとゲームはより面白くより「ゲームっぽさ」が増します。
UnityでUIを作るにはまず、ヒエラルキー上で右クリック→Create→UIから必要なものを選んで表示させましょう。

今回はこの中から特に使うImage,Text-TextMeshProについて解説します。

作ったけどおかしな場所に表示される!という人はCanvasの項目を参照してください。

Image

画像を表示させます。

作成すると大きな四角形が表示されますが、ゲームビューをここで確認してください。

すると、四角形が小さくなっていることが分かります。これはUIがカメラに「へばりつく」ように表示されているためです。詳しくはCanvasの項目へ。

作成したImageオブジェクトにはImageコンポーネントがアタッチされており、ここから画像を変えたり色を変えることができます。SpriteRendererのUI版と捉えても差支えないです。ただしOrderInLayerなどの機能はこちらにはありません。

TextMeshPro (TMP)

テキストを表示させるUIです。操作説明、制限時間などに使えます。また、TextMeshProはTMPと略されることが多いです。この記事でも以降はTMPと呼称します。

Textオブジェクトを作成すると、TMPImporterという名前のウィンドウが出てきます。これはTMPを表示するために必要なパッケージをプロジェクト内にダウンロードするかを聞くウィンドウなので、とりあえずImportTMPEssentialsのボタンを押しておきましょう。

するとこのようにImport TMP Examples & Extrasというボタンも押せるようになります。TMPがすぐ使えるセットをダウンロードするボタンですが、日本語が使えずセット数も少ないため入れても入れなくても良いです。今回は練習のため入れておきましょう。
ではそのウィンドウは消して、テキストが表示されているか確認します。シーンビュー上でスクロールしてズームアウトしていくと…

ありました。案の定クソでかいですが、Imageと同じでゲームビューに変えてやると良い感じの大きさになっていることがわかります。

カメラから見切れていたら、RectTransformコンポーネントから位置を良い感じに調整してやりましょう。

文章を変えるにはTMPコンポーネント(青いアイコンのコンポーネント)からNewTextと書いてあるテキスト欄を変えてください。(この段階で日本語を入れると文字化けします!日本語を入れる方法は後ほど)

ここでたくさんの文字を入れてしまった人は文字が自動的に改行されてしまい、画面外まで見切れているかもしれません。適切なサイズのテキストを作るためにはまずシーンビューに戻りましょう。

すると黄色い枠がテキストの周りにあります。この枠についている四角形のうち右側の四角をドラッグしてやると…

このように、長い文章を改行せずに表示させることが出来ました。この枠はテキストのおおまかなサイズを決めるもので、特に横幅が足りないときは改行してしまうので要注意です。
逆にスコア表示など横に長すぎるとまずい場面では、黄色い枠の幅を適切に設定すると改行してくれます。

Alignmentのボタンをおすと文字が左詰め、中央詰め、右詰めかを選べます。また改行されているなら下のボタンから上詰め、中央詰め、下詰めかを選べます。

TMPで日本語を扱う

最初から用意されているTMPセットでは英語しか使えません。なので日本語を使うためには自分でTMPセットを作る必要があります。

左上Window → TextMeshPro → Font Asset Creatorを選択してください。

するとこのようなウィンドウが出てきます。

Source Font File

フォントデータを入れる場所です。フォント素材はインターネット上で配布されているものを使いましょう。フォントデータは画像などと同じように、パソコンのフォルダからProjectビューにドラッグアンドドロップすることでUnity上に追加できます。

フォントの選び方について、ゲームとして動かす以上利用規約は必ず確認しましょう!

フォントのライセンスであるSIL Open Font License 1.1, M+ライセンスがあるものを使えば大丈夫です、使った際はフォントの著作権表示とライセンスの明示を絶対にやってください。

Custom Character List

作成するTMPセットが表示する文字を登録する場所です。ここに日本語を登録することができます。(もちろんSource Font FIleには日本語対応のフォントを入れましょう。)

日本語一覧についてはGitHub上で公開されているものを使わせていただきます。

!"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890〜¡¢£¤¥¦§¨©ª«¬ ®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ‒–—―‖‗‘’‚‛“”„‟†‡•…‪‫‬‭‮ ‰′″‴‹›‼‾⁄⁞€™□ 、。,.・:;?!゛゜´`¨^ ̄_ヽヾゝゞ〃仝々〆〇ー―‐/◆□■△▲▽▼※〒→←↑↓〓∈∋⊆⊇⊂⊃アイウエオカキクケコサシスセソタチツテトナニヌネノハヒフヘホマミムメモヤユヨラリルレロワヲンァィゥェォッャュョーガギグゲゴザジズゼゾダヂヅデドバビブベボパピプペポヴぁあぃいぅうぇえぉおかがきぎくぐけげこごさざしじすずせぜそぞたァアィイゥウェエォオカガキギクグケゲコゴサザシジスズセゼソゾタΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩАБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭ─│┌┐┘└├┬┤┴┼━┃┏┓┛┗┣┳┫┻╋┠┯┨┷┿┝┰┥┸亜唖娃阿哀愛挨姶逢葵茜穐悪握渥旭葦芦鯵梓圧斡扱宛姐虻飴絢綾鮎或院陰隠韻吋右宇烏羽迂雨卯鵜窺丑碓臼渦嘘唄欝蔚鰻姥厩浦瓜閏噂云運押旺横欧殴王翁襖鴬鴎黄岡沖荻億屋憶臆桶牡乙俺卸恩温穏音下化仮何魁晦械海灰界皆絵芥蟹開階貝凱劾外咳害崖慨概涯碍蓋街該鎧骸浬馨蛙粥刈苅瓦乾侃冠寒刊勘勧巻喚堪姦完官寛干幹患感慣憾換敢柑桓棺款歓機帰毅気汽畿祈季稀紀徽規記貴起軌輝飢騎鬼亀偽儀妓宜戯技擬欺犠疑供侠僑兇競共凶協匡卿叫喬境峡強彊怯恐恭挟教橋況狂狭矯胸脅興蕎郷掘窟沓靴轡窪熊隈粂栗繰桑鍬勲君薫訓群軍郡卦袈祁係傾刑兄啓圭珪型検権牽犬献研硯絹県肩見謙賢軒遣鍵険顕験鹸元原厳幻弦減源玄現絃舷后喉坑垢好孔孝宏工巧巷幸広庚康弘恒慌抗拘控攻昂晃更杭校梗構江洪此頃今困坤墾婚恨懇昏昆根梱混痕紺艮魂些佐叉唆嵯左差査沙瑳砂詐鎖察拶撮擦札殺薩雑皐鯖捌錆鮫皿晒三傘参山惨撒散桟燦珊産算纂蚕讃賛次滋治爾璽痔磁示而耳自蒔辞汐鹿式識鴫竺軸宍雫七叱執失嫉室悉湿漆宗就州修愁拾洲秀秋終繍習臭舟蒐衆襲讐蹴輯週酋酬集醜什住充十従戎勝匠升召哨商唱嘗奨妾娼宵将小少尚庄床廠彰承抄招掌捷昇昌昭晶松梢拭植殖燭織職色触食蝕辱尻伸信侵唇娠寝審心慎振新晋森榛浸深申疹真澄摺寸世瀬畝是凄制勢姓征性成政整星晴棲栖正清牲生盛精聖声製西誠繊羨腺舛船薦詮賎践選遷銭銑閃鮮前善漸然全禅繕膳糎噌塑岨措曾曽楚臓蔵贈造促側則即息捉束測足速俗属賊族続卒袖其揃存孫尊損村遜他多叩但達辰奪脱巽竪辿棚谷狸鱈樽誰丹単嘆坦担探旦歎淡湛炭短端箪綻耽帖帳庁弔張彫徴懲挑暢朝潮牒町眺聴脹腸蝶調諜超跳銚長頂鳥勅捗直朕邸鄭釘鼎泥摘擢敵滴的笛適鏑溺哲徹撤轍迭鉄典填天展店添纏甜貼転顛董蕩藤討謄豆踏逃透鐙陶頭騰闘働動同堂導憧撞洞瞳童胴萄道銅峠鴇匿如尿韮任妊忍認濡禰祢寧葱猫熱年念捻撚燃粘乃廼之埜嚢悩濃納能脳膿函箱硲箸肇筈櫨幡肌畑畠八鉢溌発醗髪伐罰抜筏閥鳩噺塙蛤隼伴判半反鼻柊稗匹疋髭彦膝菱肘弼必畢筆逼桧姫媛紐百謬俵彪標氷漂瓢票表評豹福腹複覆淵弗払沸仏物鮒分吻噴墳憤扮焚奮粉糞紛雰文聞丙併兵塀幣平法泡烹砲縫胞芳萌蓬蜂褒訪豊邦鋒飽鳳鵬乏亡傍剖坊妨帽忘忙房暴望某漫蔓味未魅巳箕岬密蜜湊蓑稔脈妙粍民眠務夢無牟矛霧鵡椋婿娘冥名命諭輸唯佑優勇友宥幽悠憂揖有柚湧涌猶猷由祐裕誘遊邑郵雄融夕予余与痢裏裡里離陸律率立葎掠略劉流溜琉留硫粒隆竜龍侶慮旅虜了亮僚両凌蓮連錬呂魯櫓炉賂路露労婁廊弄朗楼榔浪漏牢狼篭老聾蝋郎六麓禄肋録\~∥|…‥‘’“”()〔〕[]{}〈〉《》「」『』【】+-±×∪∩∧∨¬⇒⇔∀∃∠⊥⌒∂ABCDEFGHIJKLMNOPQRSTUVWXYZだちぢっつづてでとどなにぬねのはばぱひびぴふぶぷへべぺほぼぽまみダチヂッツヅテデトドナニヌネノハバパヒビピフブプヘベペホボポマミαβγδεζηθικλμνξοπρστυφχψωЮЯабвгдеёжзийклмн╂粟袷安庵按暗案闇鞍杏以伊位依偉囲夷委威尉惟意慰易椅為畏異移維緯胃雲荏餌叡営嬰影映曳栄永泳洩瑛盈穎頴英衛詠鋭液疫益駅悦謁越閲榎厭円伽価佳加可嘉夏嫁家寡科暇果架歌河火珂禍禾稼箇花苛茄荷華菓蝦課嘩貨垣柿蛎鈎劃嚇各廓拡撹格核殻獲確穫覚角赫較郭閣隔革学岳楽額顎掛笠樫汗漢澗潅環甘監看竿管簡緩缶翰肝艦莞観諌貫還鑑間閑関陥韓館舘丸含岸祇義蟻誼議掬菊鞠吉吃喫桔橘詰砧杵黍却客脚虐逆丘久仇休及吸宮弓急救鏡響饗驚仰凝尭暁業局曲極玉桐粁僅勤均巾錦斤欣欽琴禁禽筋緊芹菌衿襟契形径恵慶慧憩掲携敬景桂渓畦稽系経継繋罫茎荊蛍計詣警軽頚鶏芸迎鯨言諺限乎個古呼固姑孤己庫弧戸故枯湖狐糊袴股胡菰虎誇跨鈷雇顧鼓五互浩港溝甲皇硬稿糠紅紘絞綱耕考肯肱腔膏航荒行衡講貢購郊酵鉱砿鋼閤降裟坐座挫債催再最哉塞妻宰彩才採栽歳済災采犀砕砦祭斎細菜裁載際剤在酸餐斬暫残仕仔伺使刺司史嗣四士始姉姿子屍市師志思指支孜斯施旨枝止疾質実蔀篠偲柴芝屡蕊縞舎写射捨赦斜煮社紗者謝車遮蛇邪借勺尺杓灼爵柔汁渋獣縦重銃叔夙宿淑祝縮粛塾熟出術述俊峻春瞬竣舜駿准循旬楯殉淳樟樵沼消渉湘焼焦照症省硝礁祥称章笑粧紹肖菖蒋蕉衝裳訟証詔詳象賞醤神秦紳臣芯薪親診身辛進針震人仁刃塵壬尋甚尽腎訊迅陣靭笥諏須酢図厨誓請逝醒青静斉税脆隻席惜戚斥昔析石積籍績脊責赤跡蹟碩切拙接摂折設狙疏疎礎祖租粗素組蘇訴阻遡鼠僧創双叢倉喪壮奏爽宋層匝惣想捜掃挿掻太汰詑唾堕妥惰打柁舵楕陀駄騨体堆対耐岱帯待怠態戴替泰滞胎腿苔袋貸胆蛋誕鍛団壇弾断暖檀段男談値知地弛恥智池痴稚置致蜘遅馳築畜竹筑蓄沈珍賃鎮陳津墜椎槌追鎚痛通塚栂掴槻佃漬柘辻蔦綴鍔椿潰坪壷嬬紬爪吊点伝殿澱田電兎吐堵塗妬屠徒斗杜渡登菟賭途都鍍砥砺努度土奴怒倒党冬得徳涜特督禿篤毒独読栃橡凸突椴届鳶苫寅酉瀞噸屯惇敦沌豚遁頓呑曇鈍農覗蚤巴把播覇杷波派琶破婆罵芭馬俳廃拝排敗杯盃牌背肺輩配倍培媒梅叛帆搬斑板氾汎版犯班畔繁般藩販範釆煩頒飯挽晩番盤磐蕃蛮匪卑否妃庇廟描病秒苗錨鋲蒜蛭鰭品彬斌浜瀕貧賓頻敏瓶不付埠夫婦富冨布府怖扶敷弊柄並蔽閉陛米頁僻壁癖碧別瞥蔑箆偏変片篇編辺返遍便勉娩弁鞭保舗鋪棒冒紡肪膨謀貌貿鉾防吠頬北僕卜墨撲朴牧睦穆釦勃没殆堀幌奔本翻凡盆明盟迷銘鳴姪牝滅免棉綿緬面麺摸模茂妄孟毛猛盲網耗蒙儲木黙目杢勿餅誉輿預傭幼妖容庸揚揺擁曜楊様洋溶熔用窯羊耀葉蓉要謡踊遥陽養慾抑欲寮料梁涼猟療瞭稜糧良諒遼量陵領力緑倫厘林淋燐琳臨輪隣鱗麟瑠塁涙累論倭和話歪賄脇惑枠鷲亙亘鰐詫藁蕨椀湾碗腕÷=≠<>≦≧∞∴♂♀°′″℃¥$¢£%#&*@§☆★○●◎◇∇≡≒≪≫√∽∝∵∫∬ʼn♯♭♪†‡¶abcdefghijklmnopqrstuvwxyzむめもゃやゅゆょよらりるれろゎわゐゑをんムメモャヤュユョヨラリルレロヮワヰヱヲンヴヵヶопрстуфхцчшщъыьэюя萎衣謂違遺医井亥域育郁磯一壱溢逸稲茨芋鰯允印咽員因姻引飲淫胤蔭園堰奄宴延怨掩援沿演炎焔煙燕猿縁艶苑薗遠鉛鴛塩於汚甥凹央奥往応迦過霞蚊俄峨我牙画臥芽蛾賀雅餓駕介会解回塊壊廻快怪悔恢懐戒拐改橿梶鰍潟割喝恰括活渇滑葛褐轄且鰹叶椛樺鞄株兜竃蒲釜鎌噛鴨栢茅萱巌玩癌眼岩翫贋雁頑顔願企伎危喜器基奇嬉寄岐希幾忌揮机旗既期棋棄朽求汲泣灸球究窮笈級糾給旧牛去居巨拒拠挙渠虚許距鋸漁禦魚亨享京謹近金吟銀九倶句区狗玖矩苦躯駆駈駒具愚虞喰空偶寓遇隅串櫛釧屑屈劇戟撃激隙桁傑欠決潔穴結血訣月件倹倦健兼券剣喧圏堅嫌建憲懸拳捲伍午呉吾娯後御悟梧檎瑚碁語誤護醐乞鯉交佼侯候倖光公功効勾厚口向項香高鴻剛劫号合壕拷濠豪轟麹克刻告国穀酷鵠黒獄漉腰甑忽惚骨狛込材罪財冴坂阪堺榊肴咲崎埼碕鷺作削咋搾昨朔柵窄策索錯桜鮭笹匙冊刷死氏獅祉私糸紙紫肢脂至視詞詩試誌諮資賜雌飼歯事似侍児字寺慈持時酌釈錫若寂弱惹主取守手朱殊狩珠種腫趣酒首儒受呪寿授樹綬需囚収周準潤盾純巡遵醇順処初所暑曙渚庶緒署書薯藷諸助叙女序徐恕鋤除傷償鉦鍾鐘障鞘上丈丞乗冗剰城場壌嬢常情擾条杖浄状畳穣蒸譲醸錠嘱埴飾逗吹垂帥推水炊睡粋翠衰遂酔錐錘随瑞髄崇嵩数枢趨雛据杉椙菅頗雀裾窃節説雪絶舌蝉仙先千占宣専尖川戦扇撰栓栴泉浅洗染潜煎煽旋穿箭線操早曹巣槍槽漕燥争痩相窓糟総綜聡草荘葬蒼藻装走送遭鎗霜騒像増憎退逮隊黛鯛代台大第醍題鷹滝瀧卓啄宅托択拓沢濯琢託鐸濁諾茸凧蛸只逐秩窒茶嫡着中仲宙忠抽昼柱注虫衷註酎鋳駐樗瀦猪苧著貯丁兆凋喋寵釣鶴亭低停偵剃貞呈堤定帝底庭廷弟悌抵挺提梯汀碇禎程締艇訂諦蹄逓凍刀唐塔塘套宕島嶋悼投搭東桃梼棟盗淘湯涛灯燈当痘祷等答筒糖統到奈那内乍凪薙謎灘捺鍋楢馴縄畷南楠軟難汝二尼弐迩匂賑肉虹廿日乳入楳煤狽買売賠陪這蝿秤矧萩伯剥博拍柏泊白箔粕舶薄迫曝漠爆縛莫駁麦彼悲扉批披斐比泌疲皮碑秘緋罷肥被誹費避非飛樋簸備尾微枇毘琵眉美斧普浮父符腐膚芙譜負賦赴阜附侮撫武舞葡蕪部封楓風葺蕗伏副復幅服圃捕歩甫補輔穂募墓慕戊暮母簿菩倣俸包呆報奉宝峰峯崩庖抱捧放方朋摩磨魔麻埋妹昧枚毎哩槙幕膜枕鮪柾鱒桝亦俣又抹末沫迄侭繭麿万慢満尤戻籾貰問悶紋門匁也冶夜爺耶野弥矢厄役約薬訳躍靖柳薮鑓愉愈油癒沃浴翌翼淀羅螺裸来莱頼雷洛絡落酪乱卵嵐欄濫藍蘭覧利吏履李梨理璃類令伶例冷励嶺怜玲礼苓鈴隷零霊麗齢暦歴列劣烈裂廉恋憐漣煉簾練聯弌丐丕个丱丶丼丿乂乖乘亂亅豫亊舒弍于亞亟亠亢亰亳亶从仍仄仆仂仗僉僊傳僂僖僞僥僭僣僮價僵儉儁儂儖儕儔儚儡儺儷儼儻儿兀兒兌兔兢竸辧劬劭劼劵勁勍勗勞勣勦飭勠勳勵勸勹匆匈甸匍匐匏匕匚匣匯匱匳匸區咫哂咤咾咼哘哥哦唏唔哽哮哭哺哢唹啀啣啌售啜啅啖啗唸唳啝喙喀咯喊圈國圍圓團圖嗇圜圦圷圸坎圻址坏坩埀垈坡坿垉垓垠垳垤垪垰埃埆埔埒奸妁妝佞侫妣妲姆姨姜妍姙姚娥娟娑娜娉娚婀婬婉娵娶婢婪媚媼媾嫋嫂屐屏孱屬屮乢屶屹岌岑岔妛岫岻岶岼岷峅岾峇峙峩峽峺峭嶌峪崋崕崗嵜廖廣廝廚廛廢廡廨廩廬廱廳廰廴廸廾弃弉彝彜弋弑弖弩弭弸彁彈彌彎弯悄悛悖悗悒悧悋惡悸惠惓悴忰悽惆悵惘慍愕愆惶惷愀惴惺愃愡惻惱愍愎戞戡截戮戰戲戳扁扎扞扣扛扠扨扼抂抉找抒抓抖拔抃抔拗拑抻拏拿拆擔據擒擅擇撻擘擂擱擧舉擠擡抬擣擯攬擶擴擲擺攀擽攘攜攅攤攣攫攴攵攷曄暸曖曚曠昿曦曩曰曵曷朏朖朞朦朧霸朮朿朶杁朸朷杆杞杠杙杣杤枉杰棔棧棕椶椒椄棗棣椥棹棠棯椨椪椚椣椡棆楹楷楜楸楫楔楾楮椹楴椽楙椰檗蘗檻櫃櫂檸檳檬櫞櫑櫟檪櫚櫪櫻欅蘖櫺欒欖鬱欟欸欷盜欹飮歇歃歉歐沺泛泯泙泪洟衍洶洫洽洸洙洵洳洒洌浣涓浤浚浹浙涎涕濤涅淹渕渊涵淇漾漓滷澆潺潸澁澀潯潛濳潭澂潼潘澎澑濂潦澳澣澡澤澹濆澪濟濕濬濔濘燹燿爍爐爛爨爭爬爰爲爻爼爿牀牆牋牘牴牾犂犁犇犒犖犢犧犹犲狃狆狄瓠瓣瓧瓩瓮瓲瓰瓱瓸瓷甄甃甅甌甎甍甕甓甞甦甬甼畄畍畊畉畛畆畚畩畤癲癶癸發皀皃皈皋皎皖皓皙皚皰皴皸皹皺盂盍盖盒盞盡盥盧盪蘯盻眈眇磧磚磽磴礇礒礑礙礬礫祀祠祗祟祚祕祓祺祿禊禝禧齋禪禮禳禹禺秉秕秧筺笄筍笋筌筅筵筥筴筧筰筱筬筮箝箘箟箍箜箚箋箒箏筝箙篋篁篌篏箴篆紂紜紕紊絅絋紮紲紿紵絆絳絖絎絲絨絮絏絣經綉絛綏絽綛綺綮綣綵緇綽罅罌罍罎罐网罕罔罘罟罠罨罩罧罸羂羆羃羈羇羌羔羞羝羚羣羯羲羹羮羶隋腆脾腓腑胼腱腮腥腦腴膃膈膊膀膂膠膕膤膣腟膓膩膰膵膾膸膽臀臂膺茵茴茖茲茱荀茹荐荅茯茫茗茘莅莚莪莟莢莖茣莎莇莊荼莵荳荵莠莉莨菴蕁蘂蕋蕕薀薤薈薑薊薨蕭薔薛藪薇薜蕷蕾薐藉薺藏薹藐藕藝藥藜藹蘊蘓蝓蝣蝪蠅螢螟螂螯蟋螽蟀蟐雖螫蟄螳蟇蟆螻蟯蟲蟠蠏蠍蟾蟶蟷蠎蟒蠑蠖襦襤襭襪襯襴襷襾覃覈覊覓覘覡覩覦覬覯覲覺覽覿觀觚觜觝觧觴觸訃訖譟譬譯譴譽讀讌讎讒讓讖讙讚谺豁谿豈豌豎豐豕豢豬豸豺貂貉貅貊貍貎蹇蹉蹌蹐蹈蹙蹤蹠踪蹣蹕蹶蹲蹼躁躇躅躄躋躊躓躑躔躙躪躡躬躰軆躱躾遏遐遑遒逎遉逾遖遘遞遨遯遶隨遲邂遽邁邀邊邉邏邨邯邱邵郢郤扈郛鄂錙錢錚錣錺錵錻鍜鍠鍼鍮鍖鎰鎬鎭鎔鎹鏖鏗鏨鏥鏘鏃鏝鏐鏈鏤鐚鐔鐓鐃陝陟陦陲陬隍隘隕隗險隧隱隲隰隴隶隸隹雎雋雉雍襍雜霍雕雹霄霆霈霓顱顴顳颪颯颱颶飄飃飆飩飫餃餉餒餔餘餡餝餞餤餠餬餮餽餾饂饉饅饐饋髻鬆鬘鬚鬟鬢鬣鬥鬧鬨鬩鬪鬮鬯鬲魄魃魏魍魎魑魘魴鮓鮃鮑鮖鮗鮟鮠鮨鵝鵞鵤鵑鵐鵙鵲鶉鶇鶫鵯鵺鶚鶤鶩鶲鷄鷁鶻鶸鶺鷆鷏鷂鷙鷓鷸鷦鷭鷯鷽堯槇遙瑤凜熙仞仭仟价伉佚估佛佝佗佇佶侈侏侘佻佩佰侑佯來侖儘俔俟俎俘俛俑俚俐俤兩兪兮冀冂囘册冉冏冑冓冕冖冤冦冢冩冪冫决冱冲冰况冽凅凉凛几處凩凭卆卅丗卉卍凖卞卩卮夘卻卷厂厖厠厦厥厮厰厶參簒雙叟曼燮叮叨叭叺吁吽喟啻啾喘喞單啼喃喩喇喨嗚嗅嗟嗄嗜嗤嗔嘔嗷嘖嗾嗽嘛嗹噎噐營嘴嘶嘲嘸埓堊埖埣堋堙堝塲堡塢塋塰毀塒堽塹墅墹墟墫墺壞墻墸墮壅壓壑壗壙壘壥媽嫣嫗嫦嫩嫖嫺嫻嬌嬋嬖嬲嫐嬪嬶嬾孃孅孀孑孕孚孛孥孩孰孳孵學斈孺宀崟崛崑崔崢崚崙崘嵌嵒嵎嵋嵬嵳嵶嶇嶄嶂嶢嶝嶬嶮嶽嶐嶷嶼巉巍巓巒巖巛彑彖彗彙彡彭彳彷徃徂彿徊很徑徇從徙徘徠徨徭徼忖忻忤忸忱忝悳忿怡恠慇愾愨愧慊愿愼愬愴愽慂慄慳慷慘慙慚慫慴慯慥慱慟慝慓慵憙憖憇憬憔憚拈拜拌拊拂拇抛拉挌拮拱挧挂挈拯拵捐挾捍搜捏掖掎掀掫捶掣掏掉掟掵捫收攸畋效敖敕敍敘敞敝敲數斂斃變斛斟斫斷旃旆旁旄旌旒旛旙无旡旱杲昊枩杼杪枌枋枦枡枅枷柯枴柬枳柩枸柤柞柝柢柮枹柎柆柧檜栞框栩桀桍栲桎楡楞楝榁楪榲榮槐榿槁槓榾槎寨槊槝榻槃榧樮榑榠榜榕榴槞槨樂樛槿權槹歙歔歛歟歡歸歹歿殀殄殃殍殘殕殞殤殪殫殯殲殱殳殷殼毆毋毓毟毬毫毳毯淦涸淆淬淞淌淨淒淅淺淙淤淕淪淮渭湮渮渙湲湟渾渣湫渫湶湍渟湃渺湎渤濱濮濛瀉瀋濺瀑瀁瀏濾瀛瀚潴瀝瀘瀟瀰瀾瀲灑灣炙炒炯烱炬炸炳炮烟烋烝狎狒狢狠狡狹狷倏猗猊猜猖猝猴猯猩猥猾獎獏默獗獪獨獰獸獵獻獺珈玳珎畧畫畭畸當疆疇畴疊疉疂疔疚疝疥疣痂疳痃疵疽疸疼疱痍痊痒痙痣痞痾痿眄眩眤眞眥眦眛眷眸睇睚睨睫睛睥睿睾睹瞎瞋瞑瞠瞞瞰瞶瞹瞿瞼瞽瞻矇矍秬秡秣稈稍稘稙稠稟禀稱稻稾稷穃穗穉穡穢穩龝穰穹穽窈窗窕窘窖窩竈窰篝篩簑簔篦篥籠簀簇簓篳篷簗簍篶簣簧簪簟簷簫簽籌籃籔籏籀籐籘籟籤籖綫總綢綯緜綸綟綰緘緝緤緞緻緲緡縅縊縣縡縒縱縟縉縋縢繆繦縻縵縹繃縷羸譱翅翆翊翕翔翡翦翩翳翹飜耆耄耋耒耘耙耜耡耨耿耻聊聆聒聘聚聟聢聨臉臍臑臙臘臈臚臟臠臧臺臻臾舁舂舅與舊舍舐舖舩舫舸舳艀艙艘艝艚艟艤萓菫菎菽萃菘萋菁菷萇菠菲萍萢萠莽萸蔆菻葭萪萼蕚蒄葷葫蒭葮蒂葩葆萬蘋藾藺蘆蘢蘚蘰蘿虍乕虔號虧虱蚓蚣蚩蚪蚋蚌蚶蚯蛄蛆蚰蛉蠣蚫蛔蛞蛩蛬蠕蠢蠡蠱蠶蠹蠧蠻衄衂衒衙衞衢衫袁衾袞衵衽袵衲袂袗袒袮袙袢袍袤袰袿訐訌訛訝訥訶詁詛詒詆詈詼詭詬詢誅誂誄誨誡誑誥誦誚誣諄諍諂諚諫諳諧貔豼貘戝貭貪貽貲貳貮貶賈賁賤賣賚賽賺賻贄贅贊贇贏贍贐齎贓賍贔贖赧軅軈軋軛軣軼軻軫軾輊輅輕輒輙輓輜輟輛輌輦輳輻輹轅轂輾轌轉轆轎轗轜鄒鄙鄲鄰酊酖酘酣酥酩酳酲醋醉醂醢醫醯醪醵醴醺釀釁釉釋釐釖釟釡釛釼鐇鐐鐶鐫鐵鐡鐺鑁鑒鑄鑛鑠鑢鑞鑪鈩鑰鑵鑷鑽鑚鑼鑾钁鑿閂閇閊閔閖閘閙霎霑霏霖霙霤霪霰霹霽霾靄靆靈靂靉靜靠靤靦靨勒靫靱靹鞅靼鞁靺鞆鞋鞏饑饒饌饕馗馘馥馭馮馼駟駛駝駘駑駭駮駱駲駻駸騁騏騅駢騙騫騷驅驂驀驃鮴鯀鯊鮹鯆鯏鯑鯒鯣鯢鯤鯔鯡鰺鯲鯱鯰鰕鰔鰉鰓鰌鰆鰈鰒鰊鰄鰮鰛鰥鰤鰡鸚鸛鸞鹵鹹鹽麁麈麋麌麒麕麑麝麥麩麸麪麭靡黌黎黏黐黔黜點黝黠黥黨黯俥倚倨倔倪倥倅伜俶倡倩倬俾俯們倆偃假會偕偐偈做偖偬偸傀傚傅傴傲凰凵凾刄刋刔刎刧刪刮刳刹剏剄剋剌剞剔剪剴剩剳剿剽劍劔劒剱劈劑辨呀听吭吼吮吶吩吝呎咏呵咎呟呱呷呰咒呻咀呶咄咐咆哇咢咸咥咬哄哈咨噫噤嘯噬噪嚆嚀嚊嚠嚔嚏嚥嚮嚶嚴囂嚼囁囃囀囈囎囑囓囗囮囹圀囿圄圉壜壤壟壯壺壹壻壼壽夂夊夐夛梦夥夬夭夲夸夾竒奕奐奎奚奘奢奠奧奬奩它宦宸寃寇寉寔寐寤實寢寞寥寫寰寶寳尅將專對尓尠尢尨尸尹屁屆屎屓巫已巵帋帚帙帑帛帶帷幄幃幀幎幗幔幟幢幤幇幵并幺麼广庠廁廂廈廐廏怙怐怩怎怱怛怕怫怦怏怺恚恁恪恷恟恊恆恍恣恃恤恂恬恫恙悁悍惧悃悚憊憑憫憮懌懊應懷懈懃懆憺懋罹懍懦懣懶懺懴懿懽懼懾戀戈戉戍戌戔戛捩掾揩揀揆揣揉插揶揄搖搴搆搓搦搶攝搗搨搏摧摯摶摎攪撕撓撥撩撈撼昃旻杳昵昶昴昜晏晄晉晁晞晝晤晧晨晟晢晰暃暈暎暉暄暘暝曁暹曉暾暼梳栫桙档桷桿梟梏梭梔條梛梃檮梹桴梵梠梺椏梍桾椁棊椈棘椢椦棡椌棍槲槧樅榱樞槭樔槫樊樒櫁樣樓橄樌橲樶橸橇橢橙橦橈樸樢檐檍檠檄檢檣麾氈氓气氛氤氣汞汕汢汪沂沍沚沁沛汾汨汳沒沐泄泱泓沽泗泅泝沮沱沾滿渝游溂溪溘滉溷滓溽溯滄溲滔滕溏溥滂溟潁漑灌滬滸滾漿滲漱滯漲滌烙焉烽焜焙煥煕熈煦煢煌煖煬熏燻熄熕熨熬燗熹熾燒燉燔燎燠燬燧燵燼玻珀珥珮珞璢琅瑯琥珸琲琺瑕琿瑟瑙瑁瑜瑩瑰瑣瑪瑶瑾璋璞璧瓊瓏瓔珱痼瘁痰痺痲痳瘋瘍瘉瘟瘧瘠瘡瘢瘤瘴瘰瘻癇癈癆癜癘癡癢癨癩癪癧癬癰矗矚矜矣矮矼砌砒礦砠礪硅碎硴碆硼碚碌碣碵碪碯磑磆磋磔碾碼磅磊磬窶竅竄窿邃竇竊竍竏竕竓站竚竝竡竢竦竭竰笂笏笊笆笳笘笙笞笵笨笶筐籥籬籵粃粐粤粭粢粫粡粨粳粲粱粮粹粽糀糅糂糘糒糜糢鬻糯糲糴糶糺紆縲縺繧繝繖繞繙繚繹繪繩繼繻纃緕繽辮繿纈纉續纒纐纓纔纖纎纛纜缸缺聳聲聰聶聹聽聿肄肆肅肛肓肚肭冐肬胛胥胙胝胄胚胖脉胯胱脛脩脣脯腋艢艨艪艫舮艱艷艸艾芍芒芫芟芻芬苡苣苟苒苴苳苺莓范苻苹苞茆苜茉苙葯葹萵蓊葢蒹蒿蒟蓙蓍蒻蓚蓐蓁蓆蓖蒡蔡蓿蓴蔗蔘蔬蔟蔕蔔蓼蕀蕣蕘蕈蛟蛛蛯蜒蜆蜈蜀蜃蛻蜑蜉蜍蛹蜊蜴蜿蜷蜻蜥蜩蜚蝠蝟蝸蝌蝎蝴蝗蝨蝮蝙袱裃裄裔裘裙裝裹褂裼裴裨裲褄褌褊褓襃褞褥褪褫襁襄褻褶褸襌褝襠襞諤諱謔諠諢諷諞諛謌謇謚諡謖謐謗謠謳鞫謦謫謾謨譁譌譏譎證譖譛譚譫赭赱赳趁趙跂趾趺跏跚跖跌跛跋跪跫跟跣跼踈踉跿踝踞踐踟蹂踵踰踴蹊轢轣轤辜辟辣辭辯辷迚迥迢迪迯邇迴逅迹迺逑逕逡逍逞逖逋逧逶逵逹迸釵釶鈞釿鈔鈬鈕鈑鉞鉗鉅鉉鉤鉈銕鈿鉋鉐銜銖銓銛鉚鋏銹銷鋩錏鋺鍄錮閠閨閧閭閼閻閹閾闊濶闃闍闌闕闔闖關闡闥闢阡阨阮阯陂陌陏陋陷陜陞鞐鞜鞨鞦鞣鞳鞴韃韆韈韋韜韭齏韲竟韶韵頏頌頸頤頡頷頽顆顏顋顫顯顰騾驕驍驛驗驟驢驥驤驩驫驪骭骰骼髀髏髑髓體髞髟髢髣髦髯髫髮髴髱髷鰰鱇鰲鱆鰾鱚鱠鱧鱶鱸鳧鳬鳰鴉鴈鳫鴃鴆鴪鴦鶯鴣鴟鵄鴕鴒鵁鴿鴾鵆鵈黴黶黷黹黻黼黽鼇鼈皷鼕鼡鼬鼾齊齒齔齣齟齠齡齦齧齬齪齷齲齶龕龜龠
掲載元:kgsi/japanese_full.txt
フォントを作成する

Generate Font Atlasボタンを押すと作成が始まります。ほぼすべての日本語を出力するため、かなり時間はかかります。素材を探すなりYoutubeを見るなりして時間をつぶしましょう。

また常用漢字まででも十分であれば、そこまでの文字が入ったテキストを探して貼り付ければかなりの時間短縮になります。

終了するとこのような画面になります。ここでこのウィンドウを閉じてはいけません!すべての作業がやり直しになります。閉じる前にSaveボタンからUnity上にデータを保存してください。それができればもう完了です。

あなたのプロジェクトに日本語がやってきました。やったね!

スクリプトから文字をいじる

スクリプト上でTMPの文字を変更する際、まず最初にusing TMPro と書く必要があります。こうすると持ってきたコンポーネントからtextにアクセスすることで文字が変更できます。

TMPの文字を変更するスクリプト
using UnityEngine;
using TMPro; //ここが必要

public class TextChange : MonoBehaviour 
{
    //変更したいTMPを格納する変数を宣言
    TextMeshProUGUI textMeshPro;

    void Start()
    {
        // まずはTextMeshProUGUIコンポーネントを取得します
        textMeshPro = GetComponent<TextMeshProUGUI>();

        // その後、textプロパティに文字列を代入することで文字列を変更できます
        textMeshPro.text = "変更したい文字列";
    }
}

TextMeshProUGUI型の変数からtextにアクセスすることで書き込み、また右式に書くことで読み込みもできます。これを応用してタイマーを作ったのが以下のスクリプトです。ざっと見でいいです。

タイマーを実装するスクリプト
using UnityEngine;
using TMPro;

public class Timer : MonoBehaviour 
{
    TextMeshProUGUI textMeshPro;
    // タイマーの時間を保持する変数
    float time = 0;
    // 制限時間
    public float limitTime = 60;
 
    void Start()
    {

        // TextMeshProUGUIコンポーネントを取得します
        textMeshPro = GetComponent<TextMeshProUGUI>();
        // 初期値を設定します
        time = limitTime;
    }

    // Update is called once per frame
    void Update()
    {
        // タイマーを更新します
        time -= Time.deltaTime;
        // タイマーが0以下になったら
        if (time <= 0)
        {
            // タイマーを0にします
            time = 0;
        }
        // タイマーを表示します
        textMeshPro.text = "Time: " + time.ToString("f1");
        //ToStringはfloat型をString型に変更、引数の"f1"は小数点第2位を四捨五入と指定
    }
}
Time.deltaTime

一つ前のフレームから今回のフレームまでにかかった秒数の値がfloat型で取得できます。そのため、Updateメソッド内でtimeから引くことで経過時間分だけタイマーの数値を減らすカウントダウンタイマーの挙動を実装できます。(→フレームとは?(#2))

タイマーを表示するスクリプトです。もちろん他にも実装方法はあります!

Canvas

今までUIとなるゲームオブジェクトを作成してきましたが、必ずCanvasというゲームオブジェクトが親オブジェクトとなっていたことにお気づきでしょうか。CanvasはUIを作るための基礎となる部分です。その名の通りCanvas上でないとUIオブジェクトは表示できないのです。

ここではCanvasに関するコンポーネントについて解説します。

Canvas

Canvasを構成する基礎となるコンポーネントです。ゲーム上での表示形式をどのようにするかを設定します。

Render Mode

Screen Space – Overlayはスクリーンに張り付くように表示します。

Screen Space – Cameraはカメラに張り付くように表示します。

World Spaceは他オブジェクトと同様に座標をもち、その部分のUIを描画します。

OverlayとCameraはかなり似ているため、最初のうちはほとんど同じ物だと考えて良いでしょう。詳しくは公式リファレンスを参照してください。

CameraかWorld Spaceにしたとき、下画像のような警告が出ます。

これは「描画するためにシーン上のカメラが欲しいけど設定されてないよ」という内容です。実は再生時に自動で設定してくれるため放置してもエラーは出ないのですが、その時に処理が重くなるため設定しておいてください。MainCameraにしておけば問題ないでしょう。

Canvas Scaler

UI Scale Mode

UI表示のとき、ゲームの解像度に依存するかどうかを選べます。

Constant Pixel Sizeは解像度に応じてUIの大きさが変わります。

Scale With Screen Sizeは解像度に関わらずUIの大きさは固定です。

このような挙動となります。ビルドした時によくトラブルになる部分なので、とりあえずScale With Screen Sizeで問題ないでしょう。解像度を最初に決めてからConstant Pixel Sizeにしても構いません。

終わりに

これでコンポーネント操作は終了です。お疲れ様でした!
次回は「スクリプトの全体像」について学んでいきます。

タイトルとURLをコピーしました