原地址:http://www.cnblogs.com/koalaylj/archive/2012/09/04/2670629.html

最近在用unity3d开发Android上的游戏,一直Debug.Log感觉很悲剧,后来研究了下把log4net加了进去,能通过udp发送远程日志,电脑手机上都能发送日志,顿时神清气爽。可是后来才发现,把eclipse打开,连接到android设备后,Debug.Log 能直接在LogCat中显示出来,囧!

但是还是分享下我加入Log4net的过程吧,如果确实有需要的话可以借鉴下,少走点儿弯路,之前查各种资料各种费劲,其实一切没那么麻烦。。。

还是分步骤来说吧。

开发及测试环境:win7旗舰版 + .net2.0 + java6 + android + unity3.5;

1. 下载log4net,下来后把里面mono文件夹下的log4net.dll拿出来用。

2. 在unity3d中创建Asset\Log文件夹,日志相关的都放到这里,log4net的dll也拷贝到这里。注意要把unity的playerSetting中的api等级设置为.net2.0,不要用默认的.net2.0 subset,不然会各种报错(其实你引入其他dll的时候,什么没干就一堆错的话,很可能也是这个问题),然后创建log4net.xml,这个配置就不多说了,配置的是udpappender,直接粘代码。

<log4net>
  <appender name="UdpAppender" type="log4net.Appender.UdpAppender">
 <localPort value="9090" />
 <remoteAddress value="192.168.199.80" />
 <remotePort value="8081" />
 <layout type="log4net.Layout.PatternLayout, log4net">
      <conversionPattern value="%d{yyyy-MM-dd HH:mm:ss,fff} %-5level [%c:%line] - %message%newline" />
    </layout>
 <filter type="log4net.Filter.LevelRangeFilter">
   <param name="LevelMin" value="DEBUG" />
   <param name="LevelMax" value="FATAL" />
 </filter>
  </appender>
  <root>
    <level value="ALL" />
    <appender-ref ref="UdpAppender" />
  </root>
</log4net>

说明:remoteAddress和remotePort是接受udp日志的服务器地址和端口(后面说udp服务器配置),localPort是本地发送端口,要保证在手机上和电脑上这个端口都能使用。

3.配置udp日志接受服务器:好像udp日志能直接发送到cmd窗口中,无需什么配置,可是在windows下就是没搞成功,没办法,自己用.net写了个LogServer,就起一个端口监听下,简单的接受udp信息显示出来,具体不多说了,如果有兴趣看看的话可以稍后下载源代码(文章末尾部分提供所有代码下载)研究下。

4.使用,unity3d搞pc的游戏还好说,从加载文件比较方便,但是如果在手机上的话,从sd卡上加载就稍微有点儿别扭,所以如果需要在手机上用的,就把log4net.xml 拷贝到Resources目录下,改后缀为txt,这个目录unity能通过resources.load加载文件,不用自己找路径了。手机上用的话就加载这个配置文件。其实当初弄的时候就这个地方卡了我比较久,因为好多教程配置文件都在assembly.cs(.net原生项目才有)配置,unity3d中没法搞,后来才发现能直接加载文件进行配置,真是囧了。。

//4-1,log4net配置文件的路径

private static string _fileName =
#if UNITY_ANDROID
        "Config/log4net";
#elif UNITY_STANDALONE_WIN
 Application.dataPath + "/Log/log4net.xml";
#endif

//4-2,加载配置文件

#if UNITY_ANDROID
        byte[] xml = (Resources.Load(_fileName, typeof(TextAsset)) as TextAsset).bytes;
        XmlConfigurator.Configure(new MemoryStream(xml));
#elif UNITY_STANDALONE_WIN
        XmlConfigurator.ConfigureAndWatch(new System.IO.FileInfo(_fileName));
#endif

剩下的使用就和在.net下原生开发一样了,就不多说了。

源代码下载地址:

sina http://iask.sina.com.cn/u/1634280977/ish?folderid=967939

csdn http://download.csdn.net/detail/koalaylj/4547902

Unity3d中使用log4net的更多相关文章

  1. 在C#代码中应用Log4Net系列教程(附源代码)

    Log4Net应该可以说是DotNet中最流行的开源日志组件了.以前需要苦逼写的日志类,在Log4Net中简单地配置一下就搞定了.没用过Log4Net,真心不知道原来日志组件也可以做得这么灵活,当然这 ...

  2. 在C#代码中应用Log4Net(二)典型的使用方式

    不管用什么框架,学什么东西,最初的想法还不是尽快地用上这个框架,所以我们在这个章节还是不打算介绍具体配置节的应用,而是直接给出一个经典的使用样例,让你尽快上手.即使你对Log4Net的配置不熟悉也完全 ...

  3. 在C#代码中应用Log4Net(三)Log4Net中配置文件的解释

    一个完整的配置文件的例子如下所示,这个是”在C#代码中应用Log4Net(二)”中使用的配置文件. <log4net> <!-- 错误日志类--> <logger nam ...

  4. 在C#代码中应用Log4Net(五)将Log4Net正确地封装在自己的类库中并进行调用

    前面的几篇文章已经比较完整地解释了怎么使用Log4Net,但是我们可能需要将Log4Net的日志类封装在自己的类库中,以便C/S或B/S程序进行调用.下面的示例程序简单地分为两层,一个是应用程序层We ...

  5. 【Unity3d游戏开发】Unity3D中的3D数学基础---向量

    向量是2D.3D数学研究的标准工具,在3D游戏中向量是基础.因此掌握好向量的一些基本概念以及属性和常用运算方法就显得尤为重要.在本篇博客中,马三就来和大家一起回顾和学习一下Unity3D中那些常用的3 ...

  6. Unity3D中可中途释放的单例

    Unity3D中可中途释放的单例 使用静态类,静态变量的坏处是从程序加载后就一直占用内存,想要释放比较麻烦,可是之前使用的单例,没有提供释放的方法,那是不是也同静态的一样直到程序结束菜释放?那单例的好 ...

  7. 图文详解Unity3D中Material的Tiling和Offset是怎么回事

    图文详解Unity3D中Material的Tiling和Offset是怎么回事 Tiling和Offset概述 Tiling表示UV坐标的缩放倍数,Offset表示UV坐标的起始位置. 这样说当然是隔 ...

  8. unity3d中 刚体(Rigidbody) 碰撞体(Collider) 触发器(Is Trigger)

      刚体(Rigidbody)的官方(摘自Unity3d的官方指导书<Unity4.x从入门到精通>)解释如下: Rigidbody(刚体)组件可使游戏对象在物理系统的控制下来运动,刚体可 ...

  9. Unity3D中Update()与FixedUpdate()的区别

    Unity3D中Update()与FixedUpdate()的区别是什么呢?从字面上理解,它们都是在更新时会被调用,并且会循环的调用.但是Update会在每次渲染新的一帧时,被调用.而FixedUpd ...

随机推荐

  1. android studio 汉化 美化 个性化 修改 安卓工作室 2.3.3 最新版

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 先看一下效果. 建议全屏看图,或者新标签看图.

  2. 活动a 使用 启动为结果 方法 启动 活动 b, b什么都不做 并返回给a,a中的 在活动结果时候 回调 是否被执行?

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 活动a 使用 启动为结果 方法 启动 活动 b, b什么都不做 并返回给a,a中的 在活 ...

  3. 记一次ms16-032成功提权win7/win12

    E:\Tools\提权大结合\ms16-032>whoami pc-20140503jfge\administrator 首先查看权限是administrator 随后溢出 可以看到是syste ...

  4. 求矩阵主对角线元素的和 Exercise08_02

    import java.util.Scanner; /** * @author 冰樱梦 * 时间:2018年12月 * 题目:求矩阵主对角线元素的和 * */ public class Exercis ...

  5. bzoj 2002 LinkCutTree

    我的第一道LCT题(居然1A,O(∩_∩)O哈哈~) 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2002 大概题意: 给一颗有根树,维护每个 ...

  6. [转]Eclipse 项目转移到Android Studio遇到的问题

    1.Android Studio直接导入项目是copy原项目的,无法纳入代码管控 解决方案: 英文地址:http://developer.android.com/sdk/installing/migr ...

  7. C# 时间戳与当前时间互相转换

    时间戳: Unix时间戳(Unix timestamp),或称Unix时间(Unix time).POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01日 ...

  8. Python3的变化

    http://www.cnblogs.com/tips4python/archive/2011/05/31/2064290.html print 由一个语句(statement)变为一个函数 Pyth ...

  9. Ext如何动态添加一行组件

    用的column布局,点击一个按钮能添加一行组件,如文本框,有下拉框等. 如: 效果: 实现方法如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ...

  10. Spring Bean init-method 和 destroy-method实例

    在Spring中,可以使用 init-method 和 destroy-method 在bean 配置文件属性用于在bean初始化和销毁某些动作时.这是用来替代 InitializingBean和Di ...