温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Unity中怎么实现日志输出功能

发布时间:2021-08-09 16:36:56 来源:亿速云 阅读:178 作者:Leah 栏目:编程语言

这期内容当中小编将会给大家带来有关Unity中怎么实现日志输出功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

1.日志记录器接口

public interface ILogger{  void Log(string condition, string stackTrace, UnityEngine.LogType type);}

2.日志文件记录器

using System;using UnityEngine;using System.IO; public class FileLogger : ILogger{  private readonly string path;   /// <summary>  /// 构造方法  /// </summary>  /// <param name="isClear">是否清空原有的日志</param>  public FileLogger(bool isClear = false)  {    switch (Application.platform)    {      case RuntimePlatform.Android:        path = Path.Combine( Application.persistentDataPath,"log.txt");        break;      case RuntimePlatform.WindowsPlayer:        path = Path.Combine(Application.dataPath, "log.txt");        break;      case RuntimePlatform.WindowsEditor:        path = Path.Combine(Application.dataPath, "log.txt");        break;      case RuntimePlatform.IPhonePlayer:        path = Path.Combine(Application.persistentDataPath, "log.txt");        break;      case RuntimePlatform.OSXEditor:        break;      default:        break;    }     if (isClear)    {      if (File.Exists(path))      {        File.Delete(path);      }    }  }   public void Log(string condition, string stackTrace, LogType type)  {    using (StreamWriter sw = new StreamWriter(path, true, System.Text.Encoding.UTF8))    {      string msg = string.Format("[{0}] {1}: {2}\n{3}", GetNowTime(), type, condition, stackTrace);      sw.WriteLine(msg);    }  }    #region Tool Method  private string GetNowTime()  {    return DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");  }  #endregion}

3.日志系统管理类

using System;using UnityEngine; public class LogSys{  private static ILogger logger;  public static ILogger Logger  {    get { return logger; }  }   public bool IsOpen  {    get { return Debug.unityLogger.logEnabled; }  }   private LogSys() { }   /// <summary>  /// 初始化  /// </summary>  /// <param name="_logger">日志输出器</param>  /// <param name="isOpen">是否开启日志输出</param>  public static void Init(ILogger _logger, bool isOpen = true)  {    Init(isOpen);    logger = _logger;    Enable();  }   public static void Init(bool isOpen = true)  {    Debug.unityLogger.logEnabled = isOpen;  }   /// <summary>  /// 过滤器  /// </summary>  /// <param name="logType">需要显示的日志类型</param>  public static void Filter(LogType logType = LogType.Log)  {    Debug.unityLogger.filterLogType = logType;  }    public static void Enable()  {    if (logger != null)    {      Application.logMessageReceived += logger.Log;    }  }    public static void Disable()  {    if (logger != null)    {      Application.logMessageReceived -= logger.Log;    }   }}

4.测试

using System;using System.Collections;using System.Collections.Generic;using System.IO;using UnityEngine;using UnityEngine.UI; public class Test : MonoBehaviour{  public Text logText;   void Awake()  {    LogSys.Init(new FileLogger());  }   void Update()  {    if (Input.GetKeyDown(KeyCode.Q))    {      Debug.Log("My name is Blinkedu.");    }     if (Input.GetKeyDown(KeyCode.W))    {      Debug.LogWarning("My name is Blinkedu.");    }     if (Input.GetKeyDown(KeyCode.E))    {      Debug.LogError("My name is Blinkedu.");    }  }   private void OnDestroy()  {    LogSys.Disable();  }}

上述就是小编为大家分享的Unity中怎么实现日志输出功能了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI