Version: 2021.1
言語: 日本語
重要なクラス - Random
重要なクラス - Gizmos と Handles

重要なクラス - Debug

Debug クラスは、エディター上の情報を視覚化し、実行中のプロジェクトで何が起こっているのかを理解したり調査したりするのに役立ちます。例えば、Console (コンソール) ウィンドウにメッセージを出力したり、シーンビューやゲームビューに視覚化のためのラインを描いたり、スクリプトからエディターの再生モードを一時停止したりすることができます。

このページでは、Debug クラスの概要と、Debug クラスを使ってスクリプトを作成する際の一般的な使用方法について説明します。Debug クラスのすべてのメンバーの詳細なリファレンスについては、Debug スクリプトリファレンス を参照してください。

エラー、警告、メッセージのロギング

Unity 自体も、エラー、警告、メッセージを Console ウィンドウに出力することがあります。Debug クラスは、以下のように、独自のコードを使って全く同じことを行う機能を提供します。

Debug.Log("This is a log message.");
Debug.LogWarning("This is a warning message!");
Debug.LogError("This is an error message!");

3 つのタイプ (エラー、警告、メッセージ) のそれぞれのアイコンが、Console ウィンドウに表示されます。

Unity や独自のコードによって Console ウィンドウに書き込まれたものはすべて、ログファイル にも書き込まれます。

Console で Error Pause が有効になっていると、Debug クラスを使って Console に書き込まれたエラーは、Unity の再生モードを一時停止させます。

また、任意でこれらのログメソッドに第 2 パラメーターを指定して、メッセージが特定のゲームオブジェクトに関連していることを示すことができます。

using UnityEngine;

public class DebugExample : MonoBehaviour
{    void Start()
    {
        Debug.LogWarning("I come in peace!", this.gameObject);
    }
}

これにより、Console 上でメッセージをクリックすると、そのメッセージに関連するゲームオブジェクトが Hierarchy 上で強調表示され、メッセージがどのゲームオブジェクトに関連しているかを確認することができるというメリットがあります。下の画像では、“I come in peace!” という警告メッセージをクリックすると、“Alien (8) ” というゲームオブジェクトがハイライトされることを示しています。

また、Debug クラスはシーンビューやゲームビューで線を描くための 2 つのメソッドを提供しています。これらは DrawLineDrawRay です。

この例では、シーンのすべてのスフィアゲームオブジェクトに Debug.DrawLine を使ったスクリプトを加え、Y が 0 である平面からの垂直距離を示します。なお、この例の最後のパラメーターは、ラインがエディターに表示されている時間を秒で表しています。

using UnityEngine;

public class DebugLineExample : MonoBehaviour
{
    // Start is called before the first frame update
    void Start()
    {
        float height = transform.position.y;
        Debug.DrawLine(transform.position, transform.position - Vector3.up * height, Color.magenta, 4);
    }
}

そして、シーンビューでの結果は次のようになります。

重要なクラス - Random
重要なクラス - Gizmos と Handles