237 lines
11 KiB
C#
237 lines
11 KiB
C#
|
using System.Text;
|
||
|
using Unity.Profiling;
|
||
|
using UnityEngine;
|
||
|
using UnityEngine.Profiling;
|
||
|
using System.Runtime.InteropServices;
|
||
|
|
||
|
public class WXProfileStatsScript : MonoBehaviour
|
||
|
{
|
||
|
string statsText;
|
||
|
#if UNITY_2021_2_OR_NEWER
|
||
|
//private ProfilerRecorder m_totalUsedMemoryRecorder;
|
||
|
//private ProfilerRecorder m_totalReservedMemoryRecorder;
|
||
|
//private ProfilerRecorder m_gcUsedMemoryRecorder;
|
||
|
//private ProfilerRecorder m_gcReservedMemoryRecorder;
|
||
|
//private ProfilerRecorder m_gfxUsedMemoryRecorder;
|
||
|
//private ProfilerRecorder m_gfxReservedMemoryRecorder;
|
||
|
|
||
|
//private ProfilerRecorder m_systemUsedMemoryRecorder;
|
||
|
//private ProfilerRecorder m_textureCountRecorder;
|
||
|
//private ProfilerRecorder m_textureMemoryRecorder;
|
||
|
//private ProfilerRecorder m_meshCountRecorder;
|
||
|
//private ProfilerRecorder m_meshMemoryRecorder;
|
||
|
//private ProfilerRecorder m_materialCountRecorder;
|
||
|
//private ProfilerRecorder m_materialMemoryRecorder;
|
||
|
//private ProfilerRecorder m_animationClipCountRecorder;
|
||
|
//private ProfilerRecorder m_animationClipMemoryRecorder;
|
||
|
|
||
|
//private ProfilerRecorder m_assetCountRecorder;
|
||
|
//private ProfilerRecorder m_gameObjectsInScenesRecorder;
|
||
|
//private ProfilerRecorder m_totalObjectsInScenesRecorder;
|
||
|
//private ProfilerRecorder m_totalUnityObjectCountRecorder;
|
||
|
//private ProfilerRecorder m_gcAllocationInFrameCountRecorder;
|
||
|
//private ProfilerRecorder m_gcAllocatedInFrameRecorder;
|
||
|
|
||
|
|
||
|
ProfilerRecorder m_setPassCallsRecorder;
|
||
|
ProfilerRecorder m_drawCallsRecorder;
|
||
|
ProfilerRecorder m_verticesRecorder;
|
||
|
#endif
|
||
|
private int m_fpsCount;
|
||
|
private float m_fpsDeltaTime;
|
||
|
private int fps;
|
||
|
private GUIStyle m_bgStyle;
|
||
|
private bool m_isShow = false;
|
||
|
System.Collections.Generic.Dictionary<string, ProfValue> profValues = new System.Collections.Generic.Dictionary<string, ProfValue>();
|
||
|
|
||
|
|
||
|
private void Awake()
|
||
|
{
|
||
|
m_bgStyle = new GUIStyle();
|
||
|
m_bgStyle.normal.background = Texture2D.whiteTexture;
|
||
|
}
|
||
|
|
||
|
void OnEnable()
|
||
|
{
|
||
|
|
||
|
#if UNITY_2021_2_OR_NEWER
|
||
|
//m_totalUsedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Total Used Memory");
|
||
|
//m_totalReservedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Total Reserved Memory");
|
||
|
//m_gcUsedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "GC Used Memory");
|
||
|
//m_gcReservedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "GC Reserved Memory");
|
||
|
//m_gfxUsedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Gfx Used Memory");
|
||
|
//m_gfxReservedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Gfx Reserved Memory");
|
||
|
//m_systemUsedMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "System Used Memory");
|
||
|
//m_textureCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Texture Count");
|
||
|
//m_textureMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Texture Memory");
|
||
|
//m_meshCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Mesh Count");
|
||
|
//m_meshMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Mesh Memory");
|
||
|
//m_materialCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Material Count");
|
||
|
//m_materialMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Material Memory");
|
||
|
//m_animationClipCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "AnimationClip Count");
|
||
|
//m_animationClipMemoryRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "AnimationClip Memory");
|
||
|
//m_assetCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Asset Count");
|
||
|
//m_gameObjectsInScenesRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "GameObject Count");
|
||
|
//m_totalObjectsInScenesRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Scene Object Count");
|
||
|
//m_totalUnityObjectCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "Object Count");
|
||
|
//m_gcAllocationInFrameCountRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "GC Allocation In Frame Count");
|
||
|
//m_gcAllocatedInFrameRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Memory, "GC Allocated In Frame");
|
||
|
m_setPassCallsRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Render, "SetPass Calls Count");
|
||
|
m_drawCallsRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Render, "Draw Calls Count");
|
||
|
m_verticesRecorder = ProfilerRecorder.StartNew(ProfilerCategory.Render, "Vertices Count");
|
||
|
#endif
|
||
|
|
||
|
}
|
||
|
|
||
|
void OnDisable()
|
||
|
{
|
||
|
#if UNITY_2021_2_OR_NEWER
|
||
|
//m_totalUsedMemoryRecorder.Dispose();
|
||
|
//m_totalReservedMemoryRecorder.Dispose();
|
||
|
//m_gcUsedMemoryRecorder.Dispose();
|
||
|
//m_gcReservedMemoryRecorder.Dispose();
|
||
|
//m_gfxUsedMemoryRecorder.Dispose();
|
||
|
//m_gfxReservedMemoryRecorder.Dispose();
|
||
|
//m_systemUsedMemoryRecorder.Dispose();
|
||
|
//m_textureCountRecorder.Dispose();
|
||
|
//m_textureMemoryRecorder.Dispose();
|
||
|
//m_meshCountRecorder.Dispose();
|
||
|
//m_meshMemoryRecorder.Dispose();
|
||
|
//m_materialCountRecorder.Dispose();
|
||
|
//m_materialMemoryRecorder.Dispose();
|
||
|
//m_animationClipCountRecorder.Dispose();
|
||
|
//m_animationClipMemoryRecorder.Dispose();
|
||
|
//m_assetCountRecorder.Dispose();
|
||
|
//m_gameObjectsInScenesRecorder.Dispose();
|
||
|
//m_totalObjectsInScenesRecorder.Dispose();
|
||
|
//m_totalUnityObjectCountRecorder.Dispose();
|
||
|
//m_gcAllocationInFrameCountRecorder.Dispose();
|
||
|
//m_gcAllocatedInFrameRecorder.Dispose();
|
||
|
m_setPassCallsRecorder.Dispose();
|
||
|
m_drawCallsRecorder.Dispose();
|
||
|
m_verticesRecorder.Dispose();
|
||
|
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
class ProfValue
|
||
|
{
|
||
|
public long current;
|
||
|
public long max = 0;
|
||
|
public long min = 9999;
|
||
|
// public int avrage;
|
||
|
};
|
||
|
private ProfValue UpdateValue(string key, long value, StringBuilder sb)
|
||
|
{
|
||
|
ProfValue profValue = null;
|
||
|
if (!profValues.TryGetValue(key, out profValue))
|
||
|
{
|
||
|
profValue = new ProfValue();
|
||
|
profValues.Add(key, profValue);
|
||
|
}
|
||
|
profValue.current = value;
|
||
|
profValue.max = value > profValue.max ? value : profValue.max;
|
||
|
profValue.min = value < profValue.min ? value : profValue.min;
|
||
|
sb.AppendLine($"{key}:[{profValue.current}, {profValue.min}, {profValue.max}]");
|
||
|
return profValue;
|
||
|
}
|
||
|
|
||
|
void Update()
|
||
|
{
|
||
|
UpdateFps();
|
||
|
const uint toMB = 1024 * 1024;
|
||
|
var sb = new StringBuilder(500);
|
||
|
sb.AppendLine($"-------------FPS---------------");
|
||
|
//var key = "targetFrameRate";
|
||
|
UpdateValue("targetFrameRate", Application.targetFrameRate, sb);
|
||
|
UpdateValue("FPS", fps, sb);
|
||
|
|
||
|
sb.AppendLine($"-------------Profiler------------");
|
||
|
|
||
|
UpdateValue("MonoHeapReserved", Profiler.GetMonoHeapSizeLong() / toMB, sb);
|
||
|
UpdateValue("MonoHeapUsed", Profiler.GetMonoUsedSizeLong() / toMB, sb);
|
||
|
// UpdateValue("Graphics", Profiler.GetAllocatedMemoryForGraphicsDriver() / toMB, sb);
|
||
|
|
||
|
// UpdateValue("TempAllocator", Profiler.GetTempAllocatorSize() / toMB, sb);
|
||
|
UpdateValue("NativeReserved", Profiler.GetTotalReservedMemoryLong() / toMB, sb);
|
||
|
UpdateValue("NativeUnused", Profiler.GetTotalUnusedReservedMemoryLong() / toMB, sb);
|
||
|
UpdateValue("NativeAllocated", Profiler.GetTotalAllocatedMemoryLong() / toMB, sb);
|
||
|
|
||
|
|
||
|
#if UNITY_2021_2_OR_NEWER
|
||
|
sb.AppendLine("-------------Render------------");
|
||
|
UpdateValue("SetPass Calls", m_setPassCallsRecorder.LastValue, sb);
|
||
|
UpdateValue("Draw Calls", m_drawCallsRecorder.LastValue, sb);
|
||
|
UpdateValue("Vertices", m_verticesRecorder.LastValue, sb);
|
||
|
#endif
|
||
|
sb.AppendLine("-------------WebAssembly----------");
|
||
|
UpdateValue("TotalHeapMemory", WeChatWASM.WX.GetTotalMemorySize() / toMB, sb);
|
||
|
UpdateValue("DynamicMemory", WeChatWASM.WX.GetDynamicMemorySize() / toMB, sb);
|
||
|
UpdateValue("UsedHeapMemory", WeChatWASM.WX.GetUsedMemorySize() / toMB, sb);
|
||
|
UpdateValue("UnAllocatedMemory", WeChatWASM.WX.GetUnAllocatedMemorySize() / toMB, sb);
|
||
|
|
||
|
|
||
|
|
||
|
#if UNITY_2021_2_OR_NEWER
|
||
|
//sb.AppendLine("-------------MemoryRecorder-----");
|
||
|
//UpdateValue("Total Used Memory", m_totalUsedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Total Reserved Memory", m_totalReservedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("GC Used Memory", m_gcUsedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("GC Reserved Memory", m_gcReservedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Gfx Used Memory", m_gfxUsedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Gfx Reserved Memory", m_gfxReservedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("System Used Memory", m_systemUsedMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Texture Count", m_textureCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("Texture Memory", m_textureMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Mesh Count", m_meshCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("Mesh Memory", m_meshMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Material Count", m_materialCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("Material Memory", m_materialMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("AnimationClip Count", m_animationClipCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("AnimationClip Memory", m_animationClipMemoryRecorder.LastValue / toMB, sb);
|
||
|
//UpdateValue("Asset Count", m_assetCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("GameObject Count", m_gameObjectsInScenesRecorder.LastValue, sb);
|
||
|
//UpdateValue("Scene Object Count", m_totalObjectsInScenesRecorder.LastValue, sb);
|
||
|
//UpdateValue("Object Count", m_totalUnityObjectCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("GC Allocation In Frame Count", m_gcAllocationInFrameCountRecorder.LastValue, sb);
|
||
|
//UpdateValue("GC Allocated In Frame", m_gcAllocatedInFrameRecorder.LastValue / toMB, sb);
|
||
|
#endif
|
||
|
statsText = sb.ToString();
|
||
|
|
||
|
}
|
||
|
|
||
|
void UpdateFps()
|
||
|
{
|
||
|
m_fpsCount++;
|
||
|
m_fpsDeltaTime += Time.deltaTime;
|
||
|
|
||
|
if (m_fpsCount % 60 == 0)
|
||
|
{
|
||
|
m_fpsCount = 1;
|
||
|
fps = (int)Mathf.Ceil(60.0f / m_fpsDeltaTime);
|
||
|
m_fpsDeltaTime = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void OnGUI()
|
||
|
{
|
||
|
|
||
|
GUI.backgroundColor = new Color(0, 0, 0, 0.5f);
|
||
|
#if UNITY_EDITOR
|
||
|
GUI.skin.button.fontSize = 10;
|
||
|
GUI.skin.label.fontSize = 10;
|
||
|
#else
|
||
|
GUI.skin.button.fontSize = 30;
|
||
|
GUI.skin.label.fontSize = 30;
|
||
|
#endif
|
||
|
if (GUILayout.Button("Performence Stats", GUILayout.ExpandWidth(false))){
|
||
|
m_isShow = !m_isShow;
|
||
|
}
|
||
|
GUILayout.BeginVertical(m_bgStyle);
|
||
|
if (m_isShow){
|
||
|
GUILayout.Label(statsText);
|
||
|
}
|
||
|
GUILayout.EndVertical();
|
||
|
}
|
||
|
}
|