using UnityEngine;
using System.Text;
using UnityEditor;

public class ShowFps : MonoBehaviour
{

public bool m_isShow = true;

private int m_FrameCounter;
private float m_ClientTimeAccumulator;
private float m_RenderTimeAccumulator;
private float m_MaxTimeAccumulator;
private float m_ClientFrameTime;
private float m_RenderFrameTime;
private float m_MaxFrameTime;
private GUIStyle s_SectionHeaderStyle;
private GUIStyle s_LabelStyle;
[Range(0, 1)]
public float position = 0.5f;
void Start()
{
}

void OnGUI()
{
if (m_isShow)
{
GameViewStatsGUI();
}

}

private GUIStyle sectionHeaderStyle
{
get
{
if (s_SectionHeaderStyle == null)
{
s_SectionHeaderStyle = EditorGUIUtility.GetBuiltinSkin(EditorSkin.Scene).GetStyle("BoldLabel");
}
return s_SectionHeaderStyle;
}
}
private GUIStyle labelStyle
{
get
{
if (s_LabelStyle == null)
{
s_LabelStyle = new GUIStyle(EditorGUIUtility.GetBuiltinSkin(EditorSkin.Scene).label);
s_LabelStyle.richText = true;
}
return s_LabelStyle;
}
}
private string FormatNumber(int num)
{
if (num < 1000)
{
return num.ToString();
}
if (num < 1000000)
{
return ((double)num * 0.001).ToString("f1") + "k";
}
return ((double)num * 1E-06).ToString("f1") + "M";
}
public void UpdateFrameTime()
{
float frameTime = UnityStats.frameTime;
float renderTime = UnityStats.renderTime;
m_ClientTimeAccumulator += frameTime;
m_RenderTimeAccumulator += renderTime;
m_MaxTimeAccumulator += Mathf.Max(frameTime, renderTime);
m_FrameCounter++;
bool flag = m_ClientFrameTime == 0f && m_RenderFrameTime == 0f;
bool flag2 = m_FrameCounter > 30 || m_ClientTimeAccumulator > 0.3f || m_RenderTimeAccumulator > 0.3f;
if (flag || flag2)
{
m_ClientFrameTime = m_ClientTimeAccumulator / (float)m_FrameCounter;
m_RenderFrameTime = m_RenderTimeAccumulator / (float)m_FrameCounter;
m_MaxFrameTime = m_MaxTimeAccumulator / (float)m_FrameCounter;
}
if (flag2)
{
m_ClientTimeAccumulator = 0f;
m_RenderTimeAccumulator = 0f;
m_MaxTimeAccumulator = 0f;
m_FrameCounter = 0;
}
}
private static string FormatDb(float vol)
{
if (vol == 0f)
{
return "-∞ dB";
}
return string.Format("{0:F1} dB", 20f * Mathf.Log10(vol));
}
public void GameViewStatsGUI()
{
GUI.skin = EditorGUIUtility.GetBuiltinSkin(EditorSkin.Scene);
GUI.color = new Color(1f, 1f, 1f, 0.75f);
float num = 300f;
float num2 = 204f;
int num3 = Network.connections.Length;
if (num3 != 0)
{
num2 += 220f;
}
GUILayout.BeginArea(new Rect(Screen.width * position - num - 10f, 27f, num, num2), "Statistics", GUI.skin.window);
GUILayout.Label("Audio:", sectionHeaderStyle, new GUILayoutOption[0]);
StringBuilder stringBuilder = new StringBuilder(400);
float audioLevel = UnityStats.audioLevel;
stringBuilder.Append(" Level: " + FormatDb(audioLevel) + ((!EditorUtility.audioMasterMute) ? "\n" : " (MUTED)\n"));
stringBuilder.Append(string.Format(" Clipping: {0:F1}%", 100f * UnityStats.audioClippingAmount));
GUILayout.Label(stringBuilder.ToString(), new GUILayoutOption[0]);
GUI.Label(new Rect(170f, 40f, 120f, 20f), string.Format("DSP load: {0:F1}%", 100f * UnityStats.audioDSPLoad));
GUI.Label(new Rect(170f, 53f, 120f, 20f), string.Format("Stream load: {0:F1}%", 100f * UnityStats.audioStreamLoad));
GUILayout.Label("Graphics:", sectionHeaderStyle, new GUILayoutOption[0]);
UpdateFrameTime();
string text = string.Format("{0:F1} FPS ({1:F1}ms)", 1f / Mathf.Max(m_MaxFrameTime, 1E-05f), m_MaxFrameTime * 1000f);
GUI.Label(new Rect(170f, 75f, 120f, 20f), text);
int screenBytes = UnityStats.screenBytes;
int num4 = UnityStats.dynamicBatchedDrawCalls - UnityStats.dynamicBatches;
int num5 = UnityStats.staticBatchedDrawCalls - UnityStats.staticBatches;
StringBuilder stringBuilder2 = new StringBuilder(400);
if (m_ClientFrameTime > m_RenderFrameTime)
{
stringBuilder2.Append(string.Format(" CPU: main <b>{0:F1}</b>ms render thread {1:F1}ms\n", m_ClientFrameTime * 1000f, m_RenderFrameTime * 1000f));
}
else
{
stringBuilder2.Append(string.Format(" CPU: main {0:F1}ms render thread <b>{1:F1}</b>ms\n", m_ClientFrameTime * 1000f, m_RenderFrameTime * 1000f));
}
stringBuilder2.Append(string.Format(" Batches: <b>{0}</b> \tSaved by batching: {1}\n", UnityStats.batches, num4 + num5));
stringBuilder2.Append(string.Format(" Tris: {0} \tVerts: {1} \n", FormatNumber(UnityStats.triangles), FormatNumber(UnityStats.vertices)));
stringBuilder2.Append(string.Format(" Screen: {0} - {1}\n", UnityStats.screenRes, EditorUtility.FormatBytes(screenBytes)));
stringBuilder2.Append(string.Format(" SetPass calls: {0} \tShadow casters: {1} \n", UnityStats.setPassCalls, UnityStats.shadowCasters));
stringBuilder2.Append(string.Format(" Visible skinned meshes: {0} s: {1}", UnityStats.visibleSkinnedMeshes, UnityStats.visibleAnimations));
GUILayout.Label(stringBuilder2.ToString(), labelStyle, new GUILayoutOption[0]);
if (num3 != 0)
{
GUILayout.Label("Network:", sectionHeaderStyle, new GUILayoutOption[0]);
GUILayout.BeginHorizontal(new GUILayoutOption[0]);
for (int i = 0; i < num3; i++)
{
GUILayout.Label(UnityStats.GetNetworkStats(i), new GUILayoutOption[0]);
}
GUILayout.EndHorizontal();
}
else
{
GUILayout.Label("Network: (no players connected)", sectionHeaderStyle, new GUILayoutOption[0]);
}
GUILayout.EndArea();
}
}

unity 实现Game窗口的Stats 【转自蛮牛】的更多相关文章

  1. Ubuntu/Unity中更改窗口修饰键Alt为Super

    在Ubuntu中的Unity桌面环境里,可以使用Alt配合鼠标左键拖动窗口,这一方便的设定有许多不方便的地方.和很多的软件有热键上的冲突,比如Visual Stdio Code的多光标控制功能. 注意 ...

  2. Unity 修改windows窗口的标题

    修改windows窗口的标题名称,就是修改下图的东西: 第一种: using UnityEngine; using System; using System.Runtime.InteropServic ...

  3. GJM : Unity调用系统窗口选择本地文件

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  4. Unity 自定义编辑器窗口 画线

    最近在学习状态机, 想自己实现一个可视化编辑器, 需要将多个状态之间用线条连接起来, 效果如下: 代码如下: Material m;Vector2 start;Vector2 end;Color co ...

  5. Unity 5 Stats窗口

    Unity5的 Statistics上的统计信息和Unity4 有一些区别, Statistics窗口,全称叫做 Rendering Statistics Window,即渲染统计窗口(或渲染数据统计 ...

  6. Unity用GUI绘制Debug/print窗口/控制台-打包后测试

    Unity游戏视窗控制台输出 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享 ...

  7. unity 实现调用Windows窗口/对话框交互

    Unity调用Window窗口 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分 ...

  8. Unity 3D调用Windows打开、保存窗口、文件浏览器

    Unity调用Window窗口 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分 ...

  9. 【Unity】自定义编辑器窗口——拓展编辑器功能

    最近学习了Unity自定义编辑器窗口,下面简单总结,方便用到时回顾. 新建一个脚本: using UnityEngine; using System.Collections; using UnityE ...

  10. [cb] Unity Editor 添加右键菜单

    需求 为Unity的Editor窗口添加右键菜单 实现代码 // This example shows how to create a context menu inside a custom Edi ...

随机推荐

  1. [C++标准模板库:自修教程与参考手册]关于auto_ptr

    什么是auto_ptr指针 auto_ptr是这样一种指针:它是"它所指的对象"的拥有者,所以,当身为对象拥有者的auto_ptr指针被摧毁时,该对象也会被摧毁,auto_ptr要 ...

  2. 个别编程语言在OJ平台上的输入输出方式

    OJ 平台输入输出 一. C/ C++ 输入 scanf() gets() getchar() 输出 printf() puts() putchar() C++ cin >> cout & ...

  3. 除了Navicat和DBeaver,还有没有免费又好用的数据库管理/SQL工具推荐

    很多国内SQL学习者和开发者对Navicat.DBeaver等国外数据库管理工具已经很熟悉了.但是,有没有比他们更适合SQL开发者的数据库管理/SQL工具呢?这里,笔者结合自己的调研来聊一下. 笔者做 ...

  4. 穿透的switch语句-循环概述与基本组成部分

    穿透的switch语句 在switch语句中,如果case的后面不写break,将出现穿透现象,也就是不会在判断下一个case的值,直接向后运 行,直到遇到break,或者整体switch结束. pu ...

  5. Docker命令的自动补齐

    Docker命令的自动补齐 背景 在linux下输入命令或文件都是可以自动补齐的,这个特性极大的提高了我们的效率,多数情况下我们很少用命令参数的自动补齐. 但对docker git这类参数特别多的命令 ...

  6. Vue组件之间的通信方式都有哪些?

    一.组件间通信的概念 我们通常把组件间通信这个词进行拆分 组件 通信 都知道组件是vue最强大的功能之一,vue中每一个.vue我们都可以视之为一个组件通信指的是发送者通过某种媒体以某种格式来传递信息 ...

  7. 美团点评CAT部署了各种环境不下10次,遇到的坑整理

    CAT是什么 我的理解是一个收集服务调用等运行情况的监控系统. 相信你能搜到这篇博客我就不多介绍了,这里有链接 传送门 本博客仅仅只帮助大家解决部署方面的问题 来自一个用户的吐槽 1.部署真他娘的困难 ...

  8. Symbol详解

    Symbol Symbol是es6引入的一个新的原始数据类型,是一个独一无二的值. 目前为止,js的数据类型有以下几种: 数据类型 说明 undefined undefined null null b ...

  9. LG P2839 [国家集训队]middle

    \(\text{Solution}\) 不考虑起点区间和终点区间的限制,求区间中位数 可以二分中位数,大于等于中位数的位置赋为 \(1\),小于的位置赋 \(-1\) 当区间和大于等于 \(0\) 时 ...

  10. JZOJ 4895【NOIP2016提高A组集训第16场11.15】三部曲

    题目 对于 \(50%\) 的数据,\(1<=n<=1000,1<=p<=300\) 对于 \(100%\) 的数据,\(1<=n<=50000,1<=p&l ...