关于Android真机调测Profiler
我们在使用Unity开发安卓游戏的时候,虽然可以很方便的在编辑器里直接启动查看运行效果,但是编辑器的环境始终比不上真机显示来的直接,而且有些操作,类似多点触控等等操作,必须要在手机端才能触发,如果我们不想一遍遍的编译apk安装到手机上的话,Unity Remote会是一个很好的选择。
注意:Remote在手机上的运行结果并不能取代打包安装之后运行的结果,他只是将编辑器的显示图像同步到了手机上,并通过手机接收输入而已。所以开发完成之后,还是要按照完整的流程进行测试。
1)使用Unity Remote的第一步是自己的机器上安装Android SDK和你使用手机的驱动。SDK下载地址请自行baidu,手机驱动一般可以在对应品牌的官网找到。这里要注意,如果你的手机系统版本是4.1以上的,请将SDK中的adb升级至最新版本,目前最新版本为1.0.31,否则在adb连接手机的时候会出现设备始终offline的情况。
上面这些东西全部安装完成之后,检测是否安装正确的方法是通过SDK中adb程序来检测(在SDK目录platform-tools文件夹下),在控制台中进入到adb程序所在的目录后输入 adb devices 命令,如果看到设备正常连接,即所有准备工作安装就绪。
注意:如果你的电脑上装有类似豌豆荚之类的PC端手机管理软件,请在任务管理器中将他们全部关闭,因为类似软件会劫持adb进程导致其无法正常工作。
2)关闭手机wifi(重要),打开手机的USB调试功能,在手机端安装Unity Remote 并运行。
3)启动Unity并在编辑器中直接点击Play,不出以外的话你将会看到手机屏幕上也出现了相同的画面。
———————————— 华丽丽的分割线————————————————————————————
上面我们介绍了不打包的情况下怎么在手机上看到运行结果,这毕竟不能代替真正的运行环境。有可能打包发布运行之后还会在手机上出现各种各样的问题,下面我们就将介绍如何在手机程序运行时查看Unity的日志文件。
其实,Unity在Android手机中运行时的所有日志可以通过Logcat捕获到,我们还是可以通过adb工具很方便的在pc上看到游戏运行时打出的Log信息。
1)首先第一步是在保证各种安装环境都正常的情况下链接手机并运行游戏。
2)输入adb logcat -s Unity 即可看到游戏运行过程中通过Debug.log打出的所有日志信息。
目前貌似不支持断点调试,但可以通过日志打印(logcat)来跟踪。
在android SDK中有个adb工具,使用此工具来跟踪运行的android应用:
- adb logcat
启动logcat,并将设备上运行的android应用的运行时信息全部打印出来。
- adb logcat -s Unity
如果只想打印Unity的输出信息,使用此命令。
- adb logcat -d > logcat.txt
将打印信息输出为文件。
清除adb logcat缓存
- adb logcat -c
当然,更直接的做法是在应用中集成自己的调试信息窗口,将如下代码关联到一个gameobject:
- <p>using UnityEngine;
- using System.Collections;</p><p>public class GuiTextDebug : MonoBehaviour
- {
- private float windowPosition = -440.0f;
- private int positionCheck = 2;
- private static string windowText = "";
- private Vector2 scrollViewVector = Vector2.zero;
- private GUIStyle debugBoxStyle;
- private float leftSide = 0.0f;
- private float debugWidth = 420.0f;
- public bool debugIsOn = false;
- public static void debug(string newString)
- {
- windowText = newString + "\n" + windowText;
- UnityEngine.Debug.Log(newString);
- }
- void Start()
- {
- debugBoxStyle = new GUIStyle();
- debugBoxStyle.alignment = TextAnchor.UpperLeft;
- leftSide = 120;
- }
- void OnGUI()
- {
- if (debugIsOn)
- {
- GUI.depth = 0;
- GUI.BeginGroup(new Rect(windowPosition, 40.0f, leftSide, 200.0f));
- scrollViewVector = GUI.BeginScrollView(new Rect (0, 0.0f, debugWidth, 200.0f),
- scrollViewVector,
- new Rect (0.0f, 0.0f, 400.0f, 2000.0f));
- GUI.Box(new Rect(0, 0.0f, debugWidth - 20.0f, 2000.0f), windowText, debugBoxStyle);
- GUI.EndScrollView();
- GUI.EndGroup ();
- if (GUI.Button(new Rect(leftSide, 0.0f,75.0f,40.0f), "调试"))
- {
- if (positionCheck == 1)
- {
- windowPosition = -440.0f;
- positionCheck = 2;
- }
- else
- {
- windowPosition = leftSide;
- positionCheck = 1;
- }
- }
- if (GUI.Button(new Rect(leftSide + 80f,0.0f,75.0f,40.0f),"清除"))
- {
- windowText = "";
- }
- }
- }
- }
- </p>