文档章节

Unity中Debug打印信息的颜色设置

o
 osc_t0zmqrod
发布于 2018/08/07 13:09
字数 307
阅读 11
收藏 0

精选30+云产品,助力企业轻松上云!>>>

为了更好的识别打印信息,这里封装了一下打印信息的工具类,虽然Unity中已经很好的识别..但是自己还是想实现新的工具类

DebugBase脚本:

 

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class DebugBase<T> where T :new()
{
	/// <summary>
	/// 泛型单例
	/// </summary>
	static T instance;

	public static T Instance {
		get {
			if (instance == null) {
				instance = new T ();
			}
			return instance;
		}
	}

	/// <summary>
	/// 普通打印信息
	/// </summary>
	/// <param name="msg">Message.</param>
	public virtual void Log (string msg)
	{
		if (!string.IsNullOrEmpty (msg)) {
			Debug.Log (msg);
		}
	}

	/// <summary>
	/// 警告打印
	/// </summary>
	/// <param name="msg">Message.</param>
	public virtual void LogWarning (string msg)
	{
		if (!string.IsNullOrEmpty (msg)) {
			Debug.LogWarning (msg);
		}
	}

	/// <summary>
	/// 错误打印
	/// </summary>
	/// <param name="msg">Message.</param>
	public virtual void LogError (string msg)
	{
		if (!string.IsNullOrEmpty (msg)) {
			Debug.LogError (msg);
		}
	}
}

public class GameLog :DebugBase<GameLog>
{
	/// <summary>
	/// 重写父类Log
	/// </summary>
	/// <param name="msg">Message.</param>
	public override void Log (string msg)
	{
		if (!string.IsNullOrEmpty (msg)) {
			base.Log ("*LOG*<color=white>" + msg + "</color>");
		}
	}

	/// <summary>
	/// 重写父类LogWarning
	/// </summary>
	/// <param name="msg">Message.</param>
	public override void LogWarning (string msg)
	{
		if (!string.IsNullOrEmpty (msg)) {
			base.LogWarning ("*Warning*<color=yellow>" + msg + "</color>");
		}
	}

	/// <summary>
	/// 重写父类LogError
	/// </summary>
	/// <param name="msg">Message.</param>
	public override void LogError (string msg)
	{
		if (!string.IsNullOrEmpty (msg)) {
			base.LogError ("*Error*<color=red>" + msg + "</color>");
		}
	}
}

 

  Test脚本:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class Test : MonoBehaviour
{
	Button btn;

	// Use this for initialization
	void Start ()
	{
		btn = transform.Find ("Button").GetComponent <Button> ();
		btn.onClick.AddListener (delegate() {
			GameLog.Instance.Log ("这是一个LOG");
			GameLog.Instance.LogWarning ("这是一个LogWarning");
			GameLog.Instance.LogError ("这是一个LogError");
		});
	}
}

  效果如下:

 

o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

JIT的Profile神器JITWatch

点击上方的蓝字关注我吧 程序那些事 简介 老是使用命令行工具在现代化社会好像已经跟不上节奏了,尤其是在做JIT分析时,使用LogCompilation输出的日志实在是太大了,让人望而生畏。有没有什么...

flydean
07/04
0
0
运维基础--虚拟机的使用(一)

虚拟机的使用 开始使用Linux操作系统时,首先可能会接触到两个主要的界面:GUI和CLI,即图形界面个命令界面,而运维一般极少使用到图形界面。 一、命令提示符的格式:[root@mylab11~] # roo...

osc_9os5791s
1分钟前
0
0
以程序员的方式,尽绵薄之力

作为程序员,我们不能冲在第一线,参与病毒防疫工作,我们希望通过我们的方式,让更多的人获取到关于疫情的有用的消息,正确的消息 虽然github可能是个相对小众的平台,对于非程序员来说,可...

Jipson
01/26
0
0
Oracle 等待事件之 db file scattered read

db file scattered read 官网解释: This event signifies that the user process is reading buffers into the SGA buffer cache and is waiting for a physical I/O call to return. A db......

osc_qlj7m2h9
2分钟前
0
0
互联网+时代的畅想

封面的台风卫星照片,我认为很形象地可以看作互联网的那一波浪潮。在智能手机普及的初始阶段,还记得我们对于互联网的狂热,有人说要用互联网颠覆一切,亦有人要用互联网干一切事情,当然,这...

zd200572
2015/09/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部