renderdoc的使用

renderdoc可以用来捕获帧渲染情况,排查一些GPU渲染、资源规格等问题。

下面讲述一些该软件连接真机调试使用。

一、下载安装renderdoc

软件的下载地址:https://renderdoc.org/可直接点击下载即可。该软件是开源免费的,不用破解。

renderdoc的使用_第1张图片

下载后直接安装即可使用。

二、打开使用renderdoc

打开界面后,默认的界面布局如下图所示,(这里我已经设置了黑色主题,可以忽略这点),renderdo中主要的窗口有Texture Viewer(纹理查看器)、Event Browser(事件浏览器)、API Inspector(API检查器)、Timeline Bar(时间轴)、Pipeline State(管道状态)、Mesh Viewer(网格查看器),后续会对这几个主要窗口功能进行介绍。

renderdoc的使用_第2张图片

renderdoc可以启动电脑上的EXE应用程序以及移动机器上的app。启动EXE文件就比较简单,

在launch Application窗口下,填入Executable Path参数,点击如下图的按钮打开window文件窗口,然后选择需要启动的exe应用程序,最后点击Launch按钮即可启动程序。

renderdoc的使用_第3张图片

下面讲一下如何启动Android端的app,目前renderdoc应该是不支持iOS的。

renderdoc连接Android设备调试的步骤:

注意:测试的目标apk要是开启debug模式的包才能连接

(1)、使用USB连接上Android移动手机;

(2)、Android机器上设置为开发者模式,并开启允许USB调试

(3)、在renderdoc界面的左下角下面点击Replay Context:Local,会弹出一个列表,一个是你连接上的Android机器,local是本地电脑的。我们这里选择Android机器选项。

renderdoc的使用_第4张图片

选择后,右边会有一行文本提示:Remote server ready,说明远程连接已经成功。

同时你的手机上还会显示安装一个renderdoc的调试程序,点击允许安装即可。安装后,手机上会打开运行一个绿色的renderdoc的主界面,说明已经成功了,退出即可。

(4)、连接成功后,将手机上的apk包加入到Executable Path中。然后点击Launch启动app即可。(在弹出的窗口中,显示了手机上所有已经安装的包列表,如果你觉得包很多,找起来不方便,可以在【3】这个地方输入你的debug包名进行搜索能快速找到目标程序。)

renderdoc的使用_第5张图片

(5)、启动成功后,界面会变成如下图所示,并且手机上会启动目标app。此时手机上可以正常跑你的app功能了。

renderdoc的使用_第6张图片

(6)、抓帧操作,点击capture frame immediately后,下面的列表中会出现一幅图片,双击图片就可以加载到刚刚抓取的这一帧GPU渲染的所有内容了。

renderdoc的使用_第7张图片

容易遇到的问题:

(1)在点击Launch启动时,容易出现如下的报错。

renderdoc的使用_第8张图片

排查步骤:

先根据提示打开diagnostic log窗口查看一下报错的原因;点击【window】——【Diagnostic Log】

renderdoc的使用_第9张图片

在log窗口中,我们看到了有红色的报错,

这时可以尝试重新连接或者重启renderdoc看看。我这边重启renderdoc并重新连接就可以了。

renderdoc连接unity调试的步骤

1、在unity中启动后,在game窗口中右击选择Load Renderdoc

renderdoc的使用_第10张图片

2、 启动游戏,在game窗口下右边的小人头按钮。点击后,会启动renderdoc软件(前提是要按照了renderdoc)。

3、启动后,会发现renderdoc里面有个localhost的连接窗口,说明连接unity成功了。测试正常跑游戏,跑到目标测试界面后,点击renderdoc里面的Capture Frame Immediately进行抓帧。

renderdoc的使用_第11张图片

4、抓帧后,会在Captures collected下显示该界面的图片,鼠标点击该图片进行数据加载,加载完后的界面图下所示:

renderdoc的使用_第12张图片

二、Renderdoc布局

renderdoc的布局是可以自定义的,可以根据我们自己的使用习惯来自行排版,这里我就不多少,这里我介绍几个重要的窗口。

Texture Viewer(纹理查看器):纹理查看器可以查看所有输入、输出的纹理,包括pvrtc, 纹理分片和表面。

纹理查看器列表,在文理查看器中,列出了所有捕获了的纹理。

renderdoc的使用_第13张图片

选中点击某一个纹理,在中间的展示中显示该纹理的资源图片。

renderdoc的使用_第14张图片

在图片中右击后,会在pixel context里面显示该部分的局部像素内容。

renderdoc的使用_第15张图片

寻找要 debug 的 pixel 和 drawCall。可以通过线选择要debug的pixel,然后通过pixel history快速定位到要debug的drawCall

renderdoc的使用_第16张图片

在renderdoc中查看某一帧的纹理名字,操作如下动图所示。左边定位是那一帧,右边显示该帧的纹理渲染情况,最右边的input窗口下会显示这一阵所有包含的所有纹理列表,并且有显示纹理的名字,这对于我们查看定位纹理提供了帮助。

Pipeline State窗口

pipeline窗口可以查看管道渲染状态,在窗口中有一条链状顺序图,其中我们常用到的有VS、PS两个,分别表示定点着色器和像素着色器。如下动图,在定位某一个drawcall后,来到pipeline窗口中,选择VS查看定点着色数据情况,窗口里面列出所有该drawcall下的shader文件,贴图资源(如果没有显示的话就点一下【show Unused Items】按钮显示出来),如果想查看shader的话,可以点击view或者edit按钮查看shader的代码内容。

在PS像素着色其中,可以看到某一帧所加载的纹理列表,列表有有纹理的名字,纹理的类型,纹理的长宽尺寸,format(纹理压缩格式)。通过长宽可以粗略计算纹理的在内存的大小范围,公式是:(长*宽)/(1024*1024)/(32/8),之所以说是粗略,是因为考虑到纹理有些会使用到纹理压缩,如果使用了压缩,那么实际的大小肯定会小于这个估算的结果的。

renderdoc的使用_第17张图片

点击Resource下的资源后面的链接图标按钮,会切到Parameter Inspecter窗口,在Parameter下会显示该纹理资源的属性信息,其中有名字以及该在内存中的大小。可以使用这种方式准确查看纹理的大小情况。

renderdoc的使用_第18张图片

Mesh View:查看模型网格、顶点信息

这个功能主要查看当前帧先模型的网格、顶点信息可以查看模型上每个顶点的位置和进行空间转化后的顶点位置信息。

结语:

renderdoc的工具能够查看某一帧的渲染情况,包括纹理情况、网格情况、渲染时间、一帧的渲染过程等内容。

通过renderdoc,可以查看到场景具体的纹理、shader等内容,这对于问题的排查定位很有帮助,其中纹理可以在着色器里面查看具体的名字和在属性窗口中查看纹理的具体大小,shader可以查看到具体的代码内容且可以进行编辑。

同时renderdoc可以查看每一帧的drawcall调用情况。当然,renderdoc的功能远不止这些,不过鉴于笔者的水平问题,就先展开讲述这么多,后续等笔者学习到更加深入的内容再做补充。

 

你可能感兴趣的:(renderdoc,测试)