Fps.cs 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. using System.Collections;
  2. using System.Collections.Generic;
  3. using UnityEngine;
  4. using UnityEngine.UI;
  5. public class Fps : MonoBehaviour {
  6. int FrameCount = 0;
  7. private float _framesPerSecond;
  8. private TextMesh textMesh;
  9. public static float lerp = 0.01f;
  10. public static float StartALLLogicAndRenderTime = 0;
  11. public static float tempALLLogicAndRenderTime = 0;
  12. public static float ALLLogicAndRenderTime = 0;
  13. public static float tempALLLogicTime = 0;
  14. public static float ALLLogicTime = 0;
  15. public static float tempLeftRenderTime = 0;
  16. public static float LeftRenderTime = 0;
  17. public static float tempRightRenderTime = 0;
  18. public static float RightRenderTime = 0;
  19. public static float tempALLWaitLockTime = 0;
  20. public static float ALLWaitLockTime = 0;
  21. public static float tempControllerLogic1Time = 0;
  22. public static float ControllerLogic1Time = 0;
  23. public static float tempControllerLogic2Time = 0;
  24. public static float ControllerLogic2Time = 0;
  25. public static float tempRayCasterTime = 0;
  26. public static float ALLRayCasterTime = 0;
  27. // Use this for initialization
  28. void Start () {
  29. // Application.targetFrameRate = 70;
  30. textMesh = GetComponent<TextMesh>();
  31. if(textMesh) {
  32. StartCoroutine(CalculateFramesPerSecond());
  33. }
  34. }
  35. float frameTime = 0;
  36. float delat = 0;
  37. // Update is called once per frame
  38. void Update() {
  39. FrameCount++;
  40. delat = Mathf.Lerp(delat, (Time.realtimeSinceStartup - frameTime) * 1000, lerp);
  41. frameTime = Time.realtimeSinceStartup;
  42. textMesh.text = string.Format("{0:F2}", _framesPerSecond);
  43. /*
  44. textMesh.text += "\n" + string.Format("{0:F1}" + " ms", delat);
  45. textMesh.text += "\n Logic_Render:" + string.Format("{0:F3}" + " ms", ALLLogicAndRenderTime);
  46. textMesh.text += "\n Logic:" + string.Format("{0:F3}" + " ms", ALLLogicTime);
  47. textMesh.text += "\n LeftCameraRender:" + string.Format("{0:F3}" + " ms", LeftRenderTime);
  48. textMesh.text += "\n RightCameraRender:" + string.Format("{0:F3}" + " ms", RightRenderTime);
  49. textMesh.text += "\n WaitATW:" + string.Format("{0:F3}" + " ms", ALLWaitLockTime);
  50. textMesh.text += "\n ControllerUpdate:" + string.Format("{0:F3}" + " ms", ControllerLogic1Time);
  51. textMesh.text += "\n ControllerLateUpdate:" + string.Format("{0:F3}" + " ms", ControllerLogic2Time);
  52. textMesh.text += "\n ALLRayCaster:" + string.Format("{0:F3}" + " ms", ALLRayCasterTime);
  53. if (API_GSXR_Module_InputSystem_KS.GSXR_KSLeft) {
  54. textMesh.text += "\n KSLeft:" + string.Format("{0:F3}", API_GSXR_Module_InputSystem_KS.GSXR_KSLeft.inputDeviceKSPartUI.modelBase.transform.position);
  55. }
  56. if (API_GSXR_Module_InputSystem_KS.GSXR_KSRight) {
  57. textMesh.text += "\n KSRight:" + string.Format("{0:F3}", API_GSXR_Module_InputSystem_KS.GSXR_KSRight.inputDeviceKSPartUI.modelBase.transform.position);
  58. }
  59. if (API_GSXR_Slam.GSXR_Get_Head()) {
  60. textMesh.text += "\n Head Rotation:" + string.Format("{0:F3}", API_GSXR_Slam.GSXR_Get_Head().localEulerAngles);
  61. textMesh.text += "\n Head Position:" + string.Format("{0:F3}", API_GSXR_Slam.GSXR_Get_Head().localPosition);
  62. }*/
  63. }
  64. private IEnumerator CalculateFramesPerSecond() {
  65. int lastFrameCount = 0;
  66. while (true) {
  67. yield return new WaitForSecondsRealtime(1f);
  68. var elapsedFrames = FrameCount - lastFrameCount;
  69. _framesPerSecond = elapsedFrames / 1f;
  70. lastFrameCount = FrameCount;
  71. }
  72. }
  73. }