Unity3D 记录到日志

这篇具有很好参考价值的文章主要介绍了Unity3D 记录到日志。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

记录日志是一个好习惯,方便我们在日常开发中出现问题快速排查。

一、需要引入log4net.dll类库(注意版本)

把它放到Unity Project视图下,最好是建一个“Plugins”文件夹用来存放,在脚本中引用该类库。

下载链接:https://download.csdn.net/download/WenHuiJun_/87658498

二、设置log4net.config文件

原文:https://www.ngui.cc/el/1788499.html?action=onClick

注:对于“ <file type="log4net.Util.PatternString" value="%property{ApplicationLogPath}\\log.log" />“,当是Winform时,不写“type”属性时,“%property{ApplicationLogPath}”改为“Debug”目录下的文件夹名即可(与应用程序在一个目录下),Unity如果不这样设置的话,则会保存到Unity的安装文件路径下。

内容如下:文章来源地址https://www.toymoban.com/news/detail-811986.html

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <log4net>
    <logger name="log" additivity="false">    
      <level value="ALL" />
      <appender-ref ref="UnityLog" />
    </logger> 
    <appender name="UnityLog" type="log4net.Appender.RollingFileAppender">
      <!--保存到文件-->     
      <file type="log4net.Util.PatternString" value="%property{ApplicationLogPath}\\log.log" />
      <appendToFile value="true" />   
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="1024KB" />     
      <rollingStyle value="Size" />
      <datePattern value="yyyy-MM-dd&quot;.log&quot;" />
      <staticLogFileName value="false" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="【%d [%t] %p %r】-%m%n"/>
      </layout>
    </appender>
  </log4net>
</configuration>
 

三、把log4net.config文件放到工程中(此处放在StreamingAssets文件夹下),编写脚本

unity每一帧的执行流程都打印到日志,unity3D,C#,unity,c#,Powered by 金山文档
using log4net;
using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using UnityEngine;

public static class UnityMessageLog 
{
    static UnityMessageLog()
    {
        //log4net.config的路径
        string sPath = Application.streamingAssetsPath + "/log4net.config";
        //设置 Properties(log4net.config文件中用到的日志输出路径) 中 ApplicationLogPath 为 Application.streamingAssetsPath路径
        GlobalContext.Properties["ApplicationLogPath"] = Path.Combine(Application.streamingAssetsPath, "log");
        log4net.Config.XmlConfigurator.Configure(new FileInfo(sPath));
    }
    public static ILog GetLogger(string name = "log")
    {
        return LogManager.GetLogger(name);
    }
    /// <summary>
    /// 记录日志,info
    /// </summary>
    /// <param name="message"></param>
    /// <param name="ex"></param>
    public static void Info(string message, Exception ex = null)
    {
        GetLogger().Info(message, ex);
    }
    /// <summary>
    /// 记录日志,Debug
    /// </summary>
    /// <param name="message"></param>
    /// <param name="ex"></param>
    public static void Debug(string message, Exception ex = null)
    {
        ILog pLog = GetLogger();
        pLog.Debug(message, ex);
    }
    /// <summary>
    /// 记录日志,Debug
    /// </summary>
    /// <param name="ex"></param>
    public static void Debug(Exception ex)
    {
        GetLogger().Debug(ex.Message, ex);
    }
    /// <summary>
    /// 记录日志,Error
    /// </summary>
    /// <param name="message"></param>
    /// <param name="ex"></param>
    public static void Error(string message, Exception ex = null)
    {
        GetLogger().Error(message, ex);
    }
    /// <summary>
    /// 记录日志,Error
    /// </summary>
    /// <param name="ex"></param>
    public static void Error(Exception ex)
    {
        GetLogger().Error(ex.Message, ex);
    }
    /// <summary>
    /// 记录日志,Fatal
    /// </summary>
    /// <param name="ex"></param>
    public static void Fatal(Exception ex)
    {
        GetLogger().Fatal(ex.Message, ex);
    }
}

四、调用

    private void Start()
    {
        UnityMessageLog.Debug("this is Debug!");
        UnityMessageLog.Error("this is Error!");
        UnityMessageLog.Info("this is Info11");
    }

五、结果

unity每一帧的执行流程都打印到日志,unity3D,C#,unity,c#,Powered by 金山文档
unity每一帧的执行流程都打印到日志,unity3D,C#,unity,c#,Powered by 金山文档

到了这里,关于Unity3D 记录到日志的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Unity3D学习记录01:URP渲染管线以及3D游戏场景设置

    以下内容所使用的版本均为Unity2022.3 先在 Window-Package Manager-Unity Registry 里面搜索添加Universal RP   Unity中,创建渲染管线的方式为Asset文件夹下右键 Create-Readering-URP Asset(with Universal Asset) 会创建以下两个Pipeline:  接着在图中的设置里添加这两个渲染管线(Project Setting在Edit窗口下

    2024年02月08日
    浏览(63)
  • Unity3D学习记录04——利用射线实现角色类似LOL的移动

    首先新建一个空白的GameObject,挂在一个MouseManager的脚本 实现思路: 通过获取鼠标点击的位置,获得该位置的信息,然后使角色移动到该位置 MouseManager脚本的代码如下:   代码解释: 先创建了一个Action类型的事件OnMouseClicked 这个是C#中事件的内容,我们可以在满足条件的时

    2024年02月08日
    浏览(57)
  • [Unity3D] 记录一下ScrollView中粒子无法被Mask遮挡的问题解决过程

    项目解决问题1所使用的Shader链接:https://www.codenong.com/cs107033982/ 解决思路: 1、粒子特效使用的Mobile/Particles/Additive(Shader)材质球不包含模板测试,添加模板测试后可以与普通Image一样被Mask遮挡,所以我们给粒子的材质球加上模板测试。 2、普通Image使用默认的材质球,该材质球

    2024年02月07日
    浏览(51)
  • 【Unity3D日常开发】Unity3D中协程的使用

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 我的个人博客 大家好,我是佛系工程师 ☆恬静的小魔龙☆ ,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 最近有小伙伴问协程怎么用、怎么写,我也是会用会写,但是原理不是很明白。 学习了一下,总结出

    2024年02月12日
    浏览(59)
  • unity3D基础操作之01--unity3d窗口界面介绍

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 1、Scene场景编辑窗口; 2、Game游戏运行窗口; 3、Hierarchy场景物体列表窗口; 4、Project项目资源列表窗口; 5、Inspector属性编辑列表窗口; 6、其他常调节窗口 在屏幕左上方为场景编辑窗口Scene,在场景编

    2024年02月06日
    浏览(80)
  • 【Unity3D】Unity3D 软件安装 ( 注册账号并下载 Unity Hub | 安装 Unity Hub | 获取个人版授权 | 中文环境设置 | 安装 Unity3D 编辑器 )

    Unity 官方网站 : 英文 : https://unity.com 中文 : https://unity.cn 进入 中文网站 https://unity.cn , 点击右上角的 \\\" 下载 Unity \\\" 按钮 ; 推荐下载 Unity3D 的长期支持版本 ; 点击界面中的 \\\" 下载 Unity Hub \\\" 选项 ; 根据你的系统 , 选择对应的 Unity Hub , 我在 Windows 上开发 , 因此选择 \\\" Windows 下载 \\\"

    2024年01月25日
    浏览(101)
  • 【Unity3D小功能】Unity3D中实现Text显示版本功能

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 我的个人博客 大家好,我是佛系工程师 ☆恬静的小魔龙☆ ,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 在项目开发中,会遇到要控制版本的情况,比如说对比版本号,版本不对再更新版本的功能,这些就是

    2024年02月05日
    浏览(77)
  • 【Unity3D日常开发】Unity3D中实现单例模式详解

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 我的个人博客 大家好,我是佛系工程师 ☆恬静的小魔龙☆ ,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 首先,说一下,什么是 单例模式(Singleton) 。 单例模式是设计模式中常见的一种设计模式,目的是为了

    2024年02月02日
    浏览(65)
  • 【Unity3D小功能】Unity3D中实现点击‘文字’出现‘UI面板’

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 QQ群:398291828 大家好,我是佛系工程师 ☆恬静的小魔龙☆ ,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 宠粉博主又来了,今天有粉丝问我如何实现点击一段文字然后出现的面板在那段文字附近显示: 深入了

    2024年04月13日
    浏览(83)
  • 【Unity3D日常开发】Unity3D中实现不同脚本之间的执行顺序控制

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 我的个人博客 大家好,我是佛系工程师 ☆恬静的小魔龙☆ ,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 首先,来了解一下事件函数的执行顺序,下图是官方给的脚本中事件函数的执行顺序: 众所周知,U

    2024年02月02日
    浏览(58)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包