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

相关文章

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

Java中基于注解的代码生成工具MapStruct映射使用详解

《Java中基于注解的代码生成工具MapStruct映射使用详解》MapStruct作为一个基于注解的代码生成工具,为我们提供了一种更加优雅、高效的解决方案,本文主要为大家介绍了它的具体使用,感兴趣... 目录介绍优缺点优点缺点核心注解及详细使用语法说明@Mapper@Mapping@Mappings@Co

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端