Unity3D美术特效分析工具

2024-03-23 09:38

本文主要是介绍Unity3D美术特效分析工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在游戏性能优化阶段,对美术性能的优化是必不可少的。

为了给美术一个比较直观的分析结果,故此编写了一个分析工具脚本,只需要将需要分析的特效拖入其中即可。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEditor;
using System.IO;
using System;/// <summary>
/// 循环创建获得特效的数据
/// 设计:每个特效跑10遍,取中间值
/// </summary>
public class ArParticlesTool : MonoBehaviour
{/// <summary>/// 特效参数/// </summary>class Particles{public float loadTime;//加载时间public float creatTime;//创建时间public int maxBatches;//最大渲染批次public int averageBatches;//平均渲染批次public float maxBatchesTime;//最大渲染批次时间public int maxTris;//最大顶点数public int averageTris;//平均顶点数public int maxVerts;//最大面数public int averageVerts;//平均面数}public List<GameObject> objPool;// Start is called before the first frame updatevoid Start(){StartCoroutine(CreatParticles());}   List<Particles> parList = new List<Particles>();int creatID = 0;//创建特效的IDstring str = "";List<int> startStats = new List<int>();bool isDebug = false;float startTime = 0;float maxTime = 0;int maxB = 0;int maxT = 0;int maxV = 0;List<int> batches = new List<int>();List<int> tris = new List<int>();List<int> verts = new List<int>();/// <summary>/// 创建特效/// </summary>/// <returns></returns>IEnumerator CreatParticles(){yield return new WaitForSeconds(5f);if (startStats.Count == 0){//初始化str += "特效名,(Win)初次加载时间(微秒),(Win)创建时间(微秒),最大渲染批次,平均渲染批次,最大渲染批次时间,最大顶点数,平均顶点数,最大面数,平均面数\n";startStats.Add(UnityStats.triangles);startStats.Add(UnityStats.vertices);startStats.Add(UnityStats.batches);}if (creatID < objPool.Count){isDebug = true;startTime = Time.time; maxTime = 0; maxB = 0; maxT = 0; maxV = 0;batches.Clear();tris.Clear();verts.Clear();var _startT = TimeStampLongTicks();//创建下一个预制体var _obj = Instantiate(objPool[creatID]);var _f = GetTimestamp(TimeStampLongTicks() - _startT);Particles _p = new Particles();if (parList.Count == 0) _p.loadTime = _f;else _p.creatTime = _f;StartCoroutine(EndCreat(_obj, _p));StartCoroutine(CreatParticles());}else{SaveStats();}}// Update is called once per framevoid FixedUpdate(){if (isDebug){var _dis = UnityStats.batches - startStats[2];if (_dis > 0){batches.Add(_dis);var _t = UnityStats.triangles - startStats[0];tris.Add(_t);var _v = UnityStats.vertices - startStats[1];verts.Add(_v);if (_dis > maxB){maxB = _dis;maxTime = Time.time - startTime;}if (_t > maxT) maxT = _t;if (_v > maxV) maxV = _v;}           }}/// <summary>/// 结束创建/// </summary>/// <returns></returns>IEnumerator EndCreat(GameObject _obj,Particles _p){       yield return new WaitForSeconds(3f);isDebug = false;DestroyImmediate(_obj);_p.maxTris = maxT; _p.maxVerts = maxV;_p.averageBatches = GetAverage(batches);_p.averageTris = GetAverage(tris);_p.averageVerts = GetAverage(verts);_p.maxBatches = maxB;_p.maxBatchesTime = maxTime;parList.Add(_p);Debug.Log("结束记录" + maxB + "  " + maxTime + "  " + maxT + "  " + maxV);var _max = 10;if (parList.Count >= _max){var _l = 0f; var _c = 0f;var _mB = 0; var _aB = 0; var _mBf = 0f;var _mT = 0; var _aT = 0;var _mV = 0; var _aV = 0;var _a = 0;//总结foreach (var idx in parList){if (idx.loadTime > 0) _l = idx.loadTime;_c += idx.creatTime;if (idx.maxBatches > 0){_a++;_mB += idx.maxBatches;_aB += idx.averageBatches;_mBf += idx.maxBatchesTime;_mT += idx.maxTris;_aT += idx.averageTris;_mV += idx.maxVerts;_aV += idx.averageVerts;}               }_a = Mathf.Clamp(_a, 1, _max);str += objPool[creatID].name + ","+ _l + "," + (int)(_c / (parList.Count - 1) * 100) / 100 + ","+ _mB / _a + "," + _aB / _a + "," + _mBf / _a + "," ++_mT / _a + "," + _aT / _a + "," ++_mV / _a + "," + _aV / _a + "," +"\n";parList.Clear();creatID++;Debug.LogError(str);}}int GetAverage(List<int> _list){var _t = 0;foreach (var _i in _list) _t += _i;var _f = Mathf.Clamp(_list.Count, 1, 10000);return _t / _f;}void SaveStats(){AssetDatabase.Refresh();Directory.CreateDirectory("Assets/TablesOther");using (StreamWriter writer = File.CreateText("Assets/TablesOther/表格.csv"))writer.Write(str);AssetDatabase.Refresh();Debug.Log(gameObject.name + "转表完毕");}/// <summary>/// 转换时间戳 /// </summary>/// <returns></returns>public long TimeStampLongTicks(){DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1, 0, 0, 0, 0));return (DateTime.Now.Ticks - startTime.Ticks);}/// <summary>/// 获得纳秒/// </summary>/// <returns></returns>public int GetTimestamp(long _t){        return (int)_t/10;}}

为了比较准确的结果,建议在跑分的过程中,不要开关其他软件,以保证比较稳定的运行环境。

打印结果如下图所示:

 

这篇关于Unity3D美术特效分析工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/837900

相关文章

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加