240 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			C#
		
	
	
	
			
		
		
	
	
			240 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			C#
		
	
	
	
| 
 | ||
| using System;
 | ||
| using System.Diagnostics;
 | ||
| using System.Reflection;
 | ||
| using System.Runtime.InteropServices;
 | ||
| using System.Xml;
 | ||
| using UnityEngine;
 | ||
| using UnityEngine.Scripting;
 | ||
| using System.IO;
 | ||
| 
 | ||
| using Unity.Profiling;
 | ||
| using UnityEngine.Profiling;
 | ||
| using Debug = UnityEngine.Debug;
 | ||
| 
 | ||
| 
 | ||
| #if PLATFORM_WEIXINMINIGAME || PLATFORM_WEBGL || UNITY_EDITOR
 | ||
| 
 | ||
| 
 | ||
| #if ENABLE_WX_PERF_FEATURE
 | ||
| namespace WXSDKPerf
 | ||
| {
 | ||
| 	[Preserve]
 | ||
| 	[ComVisible(false)]
 | ||
| 	public class WXPerfEngine
 | ||
| 	{
 | ||
| #if !UNITY_EDITOR
 | ||
| 		static WXPerfEngine_Implementation m_PerfEngineImplementation = null;
 | ||
| #endif
 | ||
| 
 | ||
|         [RuntimeInitializeOnLoadMethod]
 | ||
| 		public static void StartWXPerfEngine()
 | ||
| 		{
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             m_PerfEngineImplementation = new WXPerfEngine_Implementation();
 | ||
|             m_PerfEngineImplementation.StartPerfEngine();
 | ||
| #endif
 | ||
| 		}
 | ||
| 
 | ||
|         /// <summary>
 | ||
|         /// This method is used to add an annotation to the performance data.
 | ||
|         /// The annotation string is uploaded to the server along with the current frame ID.
 | ||
|         /// </summary>
 | ||
|         /// <param name="InAnnotationString">The annotation string to be added. It should not be null or empty.</param>
 | ||
|         /// <remarks>
 | ||
|         /// If the provided annotation string is null or empty, an error message will be logged.
 | ||
|         /// </remarks>
 | ||
|         public static void Annotation(string InAnnotationString)
 | ||
|         {
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             // Don't record annotation if we are not recording.
 | ||
|             if (!IsRecording())
 | ||
|             {
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("Annotation: Invalid m_PerfEngineImplementation! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             if (InAnnotationString.Contains("CaptureUnityMemorySnapshot"))
 | ||
| 			{
 | ||
| 				TakeAndUploadUnityMemorySnapshot();
 | ||
| 			}
 | ||
| 
 | ||
|             m_PerfEngineImplementation.Annotation(InAnnotationString);
 | ||
| #endif
 | ||
|         }
 | ||
| 
 | ||
| 
 | ||
|         /// <summary>
 | ||
|         /// 检查是否正在录制性能数据
 | ||
|         /// </summary>
 | ||
|         /// <returns>如果正在录制返回true,否则返回false</returns>
 | ||
|         public static bool IsRecording()
 | ||
|         {
 | ||
| #if UNITY_EDITOR
 | ||
|             return false;
 | ||
| #else
 | ||
|             return m_PerfEngineImplementation != null && m_PerfEngineImplementation.IsRecording();
 | ||
| #endif
 | ||
|         }
 | ||
| 
 | ||
|         private static void TakeAndUploadUnityMemorySnapshot()
 | ||
|         {
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
| 			DateTime timestamp = DateTime.Now;
 | ||
| 			var dateString = timestamp.ToLocalTime().ToString("yyyy-MM-dd_HH-mm-ss", System.Globalization.CultureInfo.InvariantCulture);
 | ||
| 			var snapshotFileName = $"{dateString}.snap";
 | ||
| 
 | ||
| #if UNITY_2018_3_OR_NEWER && !UNITY_2022_2_OR_NEWER
 | ||
|             UnityEngine.Profiling.Memory.Experimental.MemoryProfiler.TakeSnapshot(Path.Combine(Application.persistentDataPath, snapshotFileName),
 | ||
|             WXPerfEngine_Implementation.CaptureSnapshotCallback, (UnityEngine.Profiling.Memory.Experimental.CaptureFlags)31);
 | ||
| 
 | ||
| #elif UNITY_2022_2_OR_NEWER
 | ||
|             Unity.Profiling.Memory.MemoryProfiler.TakeSnapshot(Path.Combine(Application.persistentDataPath, snapshotFileName),
 | ||
|             WXPerfEngine_Implementation.CaptureSnapshotCallback, (Unity.Profiling.Memory.CaptureFlags)31);
 | ||
| #endif
 | ||
| #endif
 | ||
|         }
 | ||
| 
 | ||
| 		/// <summary>
 | ||
|         /// 指定luaState
 | ||
|         /// </summary>
 | ||
|         /// <param name="L">luaState</param>
 | ||
|         public static void SetLuaState(IntPtr L)
 | ||
|         {
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("SetLuaState: WXPerfEngine Not Started yet! Please Call WXSDKPerf.StartWXPerfEngine first! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             m_PerfEngineImplementation.SetLuaState(L);
 | ||
| #endif
 | ||
|         }
 | ||
| 
 | ||
| 		/// <summary>
 | ||
| 		/// 声明自定义性能指标
 | ||
| 		/// </summary>
 | ||
| 		/// <param name="inStatName">性能指标名称</param>
 | ||
| 		/// <param name="inStatCategory">性能指标类别</param>
 | ||
| 		/// <param name="inStatInterpType">性能指标展示方式,0. 不插值. 1. 线性插值;2. Step插值;</param>
 | ||
| 		public static void DeclareCustomStatInfo(string inStatName, string inStatCategory, int inStatInterpType = 1)
 | ||
| 		{
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("DeclareCustomStatInfo: Invalid m_PerfEngineImplementation! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             m_PerfEngineImplementation.DeclareCustomStatInfo(inStatName, inStatCategory, inStatInterpType);
 | ||
| #endif
 | ||
| 		}
 | ||
| 
 | ||
|         /// <summary>
 | ||
| 		/// 设置自定义性能指标,目前只支持浮点数
 | ||
|         /// 若该指标未通过DeclareCustomStatInfo进行类别的声明,则将被归为默认自定义类别,以及使用默认线性插值
 | ||
| 		/// </summary>
 | ||
| 		/// <param name="inStatName">性能指标名称</param>
 | ||
| 		/// <param name="inValue">性能指标数值</param>
 | ||
| 		public static void SetCustomStatValue(string inStatName, float inValue)
 | ||
| 		{
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("SetCustomStatInfo: Invalid m_PerfEngineImplementation! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             m_PerfEngineImplementation.SetCustomStatInfo(inStatName, inValue);
 | ||
| #endif
 | ||
| 		}
 | ||
| 
 | ||
|         /// 在自定义性能指标值的基础上增加一段数值。
 | ||
|         /// 如果未进行指标声明,将自动声明该指标,该指标将出现在报告的“Project Default Stat Category”中
 | ||
|         /// </summary>
 | ||
|         /// <param name="inStatName">性能指标名称</param>
 | ||
|         /// <param name="inValue">性能指标数值</param>
 | ||
| 		public static void AddCustomStatInfoBy(string inStatName, float inValue)
 | ||
| 		{
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("AddCustomStatInfoBy: Invalid m_PerfEngineImplementation! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             m_PerfEngineImplementation.AddCustomStatInfoBy(inStatName, inValue);
 | ||
| #endif
 | ||
| 
 | ||
| 		}
 | ||
| 
 | ||
| 
 | ||
|         /// <summary>
 | ||
|         /// 手动开始记录
 | ||
|         /// </summary>
 | ||
|         /// <param name="inEnableStackTrace">是否启用堆栈跟踪</param>
 | ||
|         /// <param name="inEnableStatInfo">是否启用统计信息</param>
 | ||
|         /// <param name="inFrequentScreenShot">是否频繁截图</param>
 | ||
|         /// <param name="inEnablebRenderInst">是否记录渲染指令</param>
 | ||
|         /// <param name="inEnableCaptureResource">是否启用资源捕获</param>
 | ||
|         /// <param name="inEnableLuaMemoryMonitor">是否启用Lua内存监控</param>
 | ||
|         /// <param name="inEnableLuaFunctionMemoryTracking">是否启用Lua函数内存跟踪</param>
 | ||
|         public static void StartRecordManually(bool inEnableStackTrace, bool inEnableStatInfo, bool inFrequentScreenShot, bool inEnablebRenderInst,
 | ||
|             bool inEnableCaptureResource, bool inEnableLuaMemoryMonitor, bool inEnableLuaFunctionMemoryTracking)
 | ||
|         {
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("StartRecordManually: Invalid m_PerfEngineImplementation! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             m_PerfEngineImplementation.StartRecordManually(inEnableStackTrace, inEnableStatInfo, inFrequentScreenShot, inEnablebRenderInst,
 | ||
|                 inEnableCaptureResource, inEnableLuaMemoryMonitor, inEnableLuaFunctionMemoryTracking);
 | ||
| #endif
 | ||
|         }
 | ||
| 
 | ||
|         /// <summary>
 | ||
|         /// 手动停止记录
 | ||
|         /// </summary>
 | ||
|         public static void StopRecordManually()
 | ||
| 		{
 | ||
| #if UNITY_EDITOR
 | ||
|             return;
 | ||
| #else
 | ||
|             if (m_PerfEngineImplementation == null)
 | ||
|             {
 | ||
|                 UnityEngine.Debug.LogError("StartRecordManually: Invalid m_PerfEngineImplementation! ");
 | ||
|                 return;
 | ||
|             }
 | ||
| 
 | ||
|             m_PerfEngineImplementation.StopRecordManually();
 | ||
| #endif
 | ||
| 		}
 | ||
|     }
 | ||
| }
 | ||
| #endif
 | ||
| 
 | ||
| #endif // ENABLE_WX_PERF_FEATURE |