Unity Android Logcat插件 输出日志中文乱码解决

  • 背景

之前安卓真机调试看日志,一直用的是Android Studio自带的adb命令进行看日志,不太方便,改用Unity自带的安卓日志插件时,存在中文日志乱码问题。

  • 插件安装

基于Unity6000.1.11版本:Window -> Package Management -> Package Manager,即可打开包管理工具,选择Unity Registry分类,找到Android Logcat插件,导入即可。

  • 插件使用

打开插件:Window -> Analysis -> Android Logcat,手机开启调试模式后,使用数据线连接电脑,在该插件面板默认会自动选择手机并输出日志(需手机先运行程序,每次运行后,每次选择)。可在顶部选择要调试程序的包名,输出的日志更整洁。

  • 乱码解决

找到插件源码:Editor/AndroidLogcatMessageProvider.cs

cs 复制代码
        public override void Start()
        {
            var arguments = LogcatArguments();
            AndroidLogcatInternalLog.Log("\n\nStarting logcat\n\n");
            AndroidLogcatInternalLog.Log("{0} {1}", m_ADB.GetADBPath(), arguments);
            m_LogcatProcess = new Process();
            m_LogcatProcess.StartInfo.FileName = m_ADB.GetADBPath();
            m_LogcatProcess.StartInfo.Arguments = arguments;
            m_LogcatProcess.StartInfo.RedirectStandardError = true;
            m_LogcatProcess.StartInfo.RedirectStandardOutput = true;
            m_LogcatProcess.StartInfo.UseShellExecute = false;
            m_LogcatProcess.StartInfo.CreateNoWindow = true;

            //中文乱码修复,增加两行代码
            m_LogcatProcess.StartInfo.StandardOutputEncoding = System.Text.Encoding.UTF8;
            m_LogcatProcess.StartInfo.StandardErrorEncoding = System.Text.Encoding.UTF8;

            m_LogcatProcess.OutputDataReceived += OutputDataReceived;
            m_LogcatProcess.ErrorDataReceived += OutputDataReceived;
            m_LogcatProcess.Start();

            m_LogcatProcess.BeginOutputReadLine();
            m_LogcatProcess.BeginErrorReadLine();
        }

找到插件源码:Editor/AndroidTools/Shell.cscishi

cs 复制代码
        internal static ShellReturnInfo RunProcess(ShellStartInfo startInfo)
        {
            Process process = new Process();
            process.StartInfo.FileName = startInfo.FileName;
            process.StartInfo.Arguments = startInfo.Arguments;
            process.StartInfo.WorkingDirectory = startInfo.WorkingDirectory;
            process.StartInfo.UseShellExecute = false;
            process.StartInfo.RedirectStandardOutput = true;
            process.StartInfo.RedirectStandardError = true;
            process.StartInfo.CreateNoWindow = true;

            //中文乱码修复,增加两行代码
            process.StartInfo.StandardOutputEncoding = Encoding.UTF8;
            process.StartInfo.StandardErrorEncoding = Encoding.UTF8;

            ...

        }

此时,日志就能够正常显示中了。

相关推荐
非凡ghost20 分钟前
Control Center 安卓版:个性化手机控制中心
android·智能手机·生活·软件需求
撩得Android一次心动1 小时前
Android 项目:画图白板APP开发(一)——曲线优化、颜色、粗细、透明度
android
月夜风雨磊9 小时前
Android NDK从r10c版本到r29版本的下载链接
android·gitee·android ndk
louisgeek10 小时前
Android MIUI 开启 Google Play 服务
android
独行soc11 小时前
2025年大模型安全岗的面试汇总(题目+回答)
android·人工智能·安全·面试·职场和发展·渗透测试
SmalBox11 小时前
【渲染流水线】[几何阶段]-[图元装配]以UnityURP为例
unity·渲染
前行的小黑炭12 小时前
Android App:每次想写新项目锻炼一下,但苦于没有UI,那么这篇文章适合你~(适合基础小白锻炼)
android·kotlin
雨白14 小时前
压缩、序列化与哈希
android
安卓开发者14 小时前
RxJava 核心概念解析:构建响应式Android应用的基石
android·echarts·rxjava
叽哥15 小时前
flutter学习第 18 节:设备功能调用
android·flutter·ios