【游戏测试】客户端性能 - 寻路采集热点图

2024-03-25 23:08

本文主要是介绍【游戏测试】客户端性能 - 寻路采集热点图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文由资深游戏测试开发工程师 陈子昂,发表于TesterHome社区,点击原文链接可与作者交流。

导读

写这个类型文章的原因是,很多时候会写代码的很多,但是如何少走弯路,做出一些有价值工具产出贡献一点绵薄之力。
在入职第二年也打算大力发展做这块(根据过往积累和经验写下了这个文章),但是后面平台化后,这件事会推研到 2022 年。
过去也是把这个工具开发方式小范围共享过,在对方公司也获得了好评和认可。
导读,可以先读这个drawcall 工具链 ,更有营养。

适合类型

3D 引擎或者 2.5D 引擎,测试时锁视角(确保每次测试的准确性和摄像机白话来说所见即所得)
游戏和个别引擎互联网都适合用。

适合条件阶段

条件 1.和 TA 有一定的共识后才去做,搭配分工明确。
条件 2.有一定建设程度以及稳定性自动化框架,以附件的形式。
条件 3.1 有小地图雷达并且有坐标的游戏,可以点开地图自动寻路的

条件 3.2 有 GM 指令可以输入:move 场景地图 Id 坐标,进行瞬移的。

使用条件引导

只有不满足条件 3.1 和条件 3.2 的,也可以继续看个热闹,满足条件 3.1 或者条件 3.2 就可以进行下去。
去对接 TA 合作的流程,当满足条件 1 之后,增强对条件 2 的建设。

文章核心

1.性能测试为啥要用热点图

热点图提供了一个对整个测试的场景(颜色的深浅来标记性能哪里更严重)。

客户端性能优化是一个比服务器优化更耗时的工作,通过热点图全局的发现场景性能最差的区域。

点的原因精髓在存储什么数据结构好提供后面复现和平台化。

绘制热点图和疑似问题一点是需要绑定 1.UI 自动化,2.引擎内置自动化来做的,前者通用性比后者强,后者 unity 需要 c# 的编程能力,在很多年前的 testerhome 社区 - 游戏测试白皮书上有作者写过 unity 内置自动化。

2.如何确定热点图的准确性

颜色深度的部分周围颜色一般会逐渐变浅(大部分情况),比如这种就是例外,后面就是一面墙,完全隔离了周围场景,游戏也只能从低往上看,啥也看不到。
热点图的存储的属性是正确的。

3.分析结果方式

选择场景内热点图颜色深度的坐标,飞过去看那块区域,然后用官方 profile 去看具体问题,都是和那块区域场景直接挂钩的,比如那边有一个深陷的大峡谷和一个瀑布,瀑布结果是用完全是用粒子效果实现的,大峡谷摄像机景深没有做处理。
可以用空白场景复原性能最差区域,新建一个空白场景,把那个区域的场景素材导入到新场景。
对场景很熟悉的人,可以更快的猜到是哪里问题,来源于经验,有志向的可以学习知识图谱,然后每个游戏一个,把屏幕坐标–>世界坐标存在分 type,性能倾向 (比如一些 npc 激烈战斗的场景,飞过去分析某块资源是正常的) 存储属性图里面,这个都是后话。

UI 自动化的建设

选择用什么框架不重要,但是需要把这部分做成插件,用 pypiserver 搭建私有 pypi,然后改源后就可以使用。

【】里面是插件名称,后面紧跟着是插件使用方,存在–>是指最终目标用户,下面介绍几个常用的,其他按需来。

【untiy 坐标存储插件】 脚本编写者->性能排查使用方:需要包含对于 Unity 引擎 Debug.log(向量) 导出日志,并且没有精度问题,坐标系处理存储到 web tracking。坐标系存储什么或者是否要转换需要和使用方沟通,来解决。

【雷达图数据存储插件】 脚本编写者:UI 自动化框架获取,雷达图和 unity 坐标如果有条件,条件是指游戏有雷达图是都需要的。

【地图坐标换算插件】 脚本编写者,如果满足上面条件 3.2 的,如果是世界坐标的需要换算成当前场景坐标(其实是可以不用 z,因为 3D 场景的地图本身也是个平面),最终会把整个场景要执行的位置以二维数组有序存储下来,在执行寻路时严格按这个来。
里面技巧是第一 UI 自动化本身看不到路点,也和 unity 内置的不一样,坐标和坐标之间的缝隙,拿其他框架拖拽用的 swipe([],[]),二个数组之间有关,如果有程序机器人可以给你录制一个整个场景按序跑的坐标系,自然更好。
每移动一次就采集当前场景的属性 (cpu,fps,内存),因为 UI 自动化外部采集没有办法和 profile 拿到更多信息。
推荐方式:性能差的地方对屏幕进行高精截图,屏幕上开发那边也可以打印更多的信息。

这里和【untiy 坐标存储插件】不冲突,因为看最终目标用户,所以不是一类,强调这个是因为后面文章也是和这个有关。

结尾

晚上有人问我头发还多吗,猫回答:还有 32 位的头发。欢迎有问题在原贴留言,看到就会回复。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
以上是今天的分享,你学废了吗~
想学习更多干货知识和前沿技术?
想结识测试行业大咖和业界精英?
欢迎关注2022 MTSC大会(第十届中国互联网测试开发大会)>>>

这篇关于【游戏测试】客户端性能 - 寻路采集热点图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

Redis客户端工具之RedisInsight的下载方式

《Redis客户端工具之RedisInsight的下载方式》RedisInsight是Redis官方提供的图形化客户端工具,下载步骤包括访问Redis官网、选择RedisInsight、下载链接、注册... 目录Redis客户端工具RedisInsight的下载一、点击进入Redis官网二、点击RedisI

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

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

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

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom