unity打印输出自动生成文本

在一次项目中需要打印出场景内物体相同的名字,并且生成txt
也是从别人处学习,同样勿怪
代码复制放在物体上直接使用 可生成 ,可以自定义生成位置,注意要在path前加上@
注:以下代码是遍历场景内所有名称相同的物体
using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using UnityEngine;

public abstract class MonoSingletonManager : MonoBehaviour where T : MonoSingletonManager
{
protected static T instance = null;

public static T GetInstance()
{
    if (instance == null)
    {
        instance = FindObjectOfType<T>();
    }

    return instance;
}

protected virtual void OnDestroy()
{
    instance = null;
}

}
public enum LogLevel
{
LOG = 0,
WARNING = 1,
ERROR = 2,
}
public class DebugHelper : MonoSingletonManager
{
public LogLevel SaveLogLevel;
public bool IsSameFile;
Queue m_vLogs;
FileInfo m_logFileInfo;
static bool m_isInited;
string logFolder;
string logFilename;
string path;

private Dictionary<string, int> namedic;
private int c = 0;

private Dictionary<LogType, LogLevel> logTypeLevelDict = null;
private void Awake()
{
    namedic = new Dictionary<string, int>();
    if (m_isInited)
    {
        Debug.Log("existed logfile object,break");
        Destroy(gameObject);
        return;
    }
    Init();
}
private void OnDestroy()
{
    //Application.logMessageReceived -= OnLogMessage;
    Application.logMessageReceivedThreaded -= OnLogMessageThread;
}
void FixedUpdate()
{
    if (m_isInited)
    {
        this.Refresh(Time.fixedDeltaTime);
    }
}

public void Init()
{
    if (m_isInited)
    {
        return;
    }
    DontDestroyOnLoad(gameObject);
    m_isInited = true;
    logTypeLevelDict = new Dictionary<LogType, LogLevel>() {
            { LogType.Log, LogLevel.LOG },
            { LogType.Warning, LogLevel.WARNING },
            { LogType.Assert, LogLevel.ERROR },
            { LogType.Error, LogLevel.ERROR },
            { LogType.Exception, LogLevel.ERROR }};
    // 创建文件
    DateTime timeNow = DateTime.Now;

#if UNITY_EDITOR
logFolder = @“H:”;
#else
logFolder = Application.persistentDataPath;
#endif
if (IsSameFile)
{
path = logFolder + “/Log.txt”;
}
else
{
path = logFolder + “/Log” + timeNow.ToString(“yyyyMMddHHmmss”) + “.txt”;
}

    m_logFileInfo = new FileInfo(path);
    var sw = m_logFileInfo.CreateText();
    sw.WriteLine("[{0}] - {1}", Application.productName, timeNow.ToString("yyyy/MM/dd HH:mm:ss"));
    sw.Close();
    Debug.Log("日志文件已创建:" + path);

    // 注册回调
    m_vLogs = new Queue<LogItem>();
    //Application.logMessageReceived += OnLogMessage;
    Application.logMessageReceivedThreaded += OnLogMessageThread;
    foreach (GameObject child in FindObjectsOfType(typeof(GameObject)))    //遍历所有gameobject
    {
        if (namedic.ContainsKey(child.gameObject.name))
        {
            string content = child.gameObject.name + ": " + "\n\r";

            Debug.Log(content);
        }
        else
        {
            namedic.Add(child.gameObject.name, c);
            c++;
        }
    }
}


public void Refresh(float dt)
{
    if (m_vLogs.Count > 0)
    {
        try
        {
            var sw = m_logFileInfo.AppendText();
            var item = m_vLogs.Peek(); // 取队首元素但先不移除
            var timeStr = item.time.ToString("HH:mm:ss.ff");
            var logStr = string.Format("{0}-[{1}]{2}", timeStr, item.logType, item.messageString);//显示时间/打印方式/打印内容
            //if (item.logType.Equals(LogType.Error))
            if (logTypeLevelDict[item.logType].Equals(LogLevel.ERROR))
            {
                logStr = string.Format("{0}-[{1}]{2}==>{3}", timeStr, item.logType, item.messageString, item.stackTrace);
            }
            sw.WriteLine(logStr);
            sw.Close();
            m_vLogs.Dequeue(); // 成功执行了再移除队首元素
        }
        catch (IOException ex)
        {
            Debug.Log(ex.Message);
        }
    }
}

private void OnLogMessage(string condition, string stackTrace, LogType type)
{
    if (logTypeLevelDict[type] >= SaveLogLevel)
    {
        m_vLogs.Enqueue(new LogItem()
        {
            messageString = condition,
            stackTrace = stackTrace,
            logType = type,
            time = DateTime.Now
        });
    }
}

void OnLogMessageThread(string condition, string stackTrace, LogType type)
{
    if (logTypeLevelDict[type] >= SaveLogLevel)
    {
        m_vLogs.Enqueue(new LogItem()
        {
            messageString = condition,
            stackTrace = stackTrace,
            logType = type,
            time = DateTime.Now
        });
    }
}

}

public struct LogItem
{
///
/// 日志内容
///
public string messageString;

/// <summary>
/// 调用堆栈
/// </summary>
public string stackTrace;

/// <summary>
/// 日志类型
/// </summary>
public LogType logType;

/// <summary>
/// 记录时间
/// </summary>
public DateTime time;

}`

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Unity是一款多平台游戏开发引擎,可通过其强大的AssetBundle功能根据文件夹自动生成AssetBundle资源包。 AssetBundle是Unity中用于打包和加载资源的一种形式,可以将游戏中的资源(包括模型、贴图、声音等)打包成独立的文件,方便在游戏运行时动态加载和卸载,实现资源的灵活管理和优化。 Unity提供了一个叫做AssetBundleBuild的类,可以用来定义AssetBundle的构建规则。在使用AssetBundleBuild时,可以指定一个文件夹,通过递归遍历该文件夹下的所有资源文件,自动将其打包生成AssetBundle。这样,在项目构建或发布时,不需要手动一个一个选择文件,只需指定文件夹路径,Unity自动构建并生成对应的AssetBundle。 通过这种方式,开发者可以按照逻辑或者功能将资源文件放置在不同的文件夹中,比如将“模型”资源放在"Models"文件夹下,将“贴图”资源放在"Textures"文件夹下。然后通过AssetBundleBuild定义规则,指定这两个文件夹路径,Unity会根据规则自动生成包含模型和贴图资源的AssetBundle。 通过自动生成AssetBundle,可以提高开发效率和资源管理的灵活性。开发者只需关注资源放置的文件夹和对应的规则,而无需手动一个一个处理资源文件。同时,由于AssetBundle的独立性,可以根据游戏中的不同场景或需求,灵活地加载和卸载对应的AssetBundle资源包,使游戏加载速度更快、内存占用更低。 总之,Unity可以根据文件夹自动生成AssetBundle,通过AssetBundleBuild中定义的规则,自动打包和生成资源包,提高开发效率和资源管理的灵活性。这为游戏开发带来了很多便利和优化的可能性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值