【Godot】解决游戏中的孤立/孤儿节点及分析器性能问题的分析处理

Godot 4.1

因为我在游戏中发现,越运行游戏变得越来越卡,当你使用 Node 节点中的 print_orphan_nodes() 方法打印信息的时候,会出现如下的孤儿节点信息

孤儿节点信息是以 节点实例ID - Stray Node: 节点名称(Type: 节点类型) 作为格式输出,可以多运行几次查看是否节点实例 ID 是否是相同的,通常不是随机性很大的,一般大概率是相同的

确定了有哪些常见或固定的节点实例ID,记录下来,使用 var obj = instance_from_id(节点实例ID) 进行获取记录孤儿节点,然后进行打印信息

复制代码
prints(obj, obj.owner, obj.get_script())

比如我得到了一个固定的节点实例ID,然后我通过一下方式进行获取输出这个节点、场景、脚本信息,来定位确定是在哪个地方出现的问题

复制代码
		var obj = instance_from_id(141431936683)
		if obj:
			prints(obj, obj.owner, obj.get_script())
			if obj.get_script():
				print(obj.get_script().resource_path)

这样排查下来就好找到具体的出现的位置了


后面我又去查看分析器中的性能波动的位置,游戏开始后,打开调试器里的分析器的开始按钮,下图左上角,点过之后变成"停止"按钮。勾选 Frame Time 查看时间耗费比较多的帧,根据这个帧波动的时间来分析。

我发现游戏中开始变卡,一看分析器果然有强烈波动,如下图所示


其中有些位置的耗费时间很高,比如我这里下面的 ScriptFunctions 里一个叫 update_fog 方法耗费挺多性能,所以我在这里入手,进行逐个解决

相关推荐
云水木石2 小时前
Android 的下一个战场:Windows 应用与游戏?
android·windows·游戏
UWA8 小时前
GPM 2.0全新功能发布|GPU精准监测 + 精细化运营,重构游戏性能管控新范式
人工智能·游戏·性能优化·重构·游戏开发·uwa
向宇it8 小时前
【unity游戏开发——网络】使用Unity+PurrNet+Heathens+Steam,在 Unity 中通过 Steam与你的朋友建立联系
网络·游戏·unity·c#·游戏引擎·steam
HUST9 小时前
C 语言 第七讲:数组和函数实践:扫雷游戏
c语言·开发语言·数据结构·vscode·算法·游戏·c#
德迅云安全—珍珍10 小时前
游戏掉线使用游戏盾SDK能优化网络吗
网络·游戏
技术小甜甜12 小时前
【Godot】【入门】编辑器界面速通:场景/节点/Inspector/信号(30 分钟上手不迷路)
编辑器·游戏引擎·godot
土丁爱吃大米饭12 小时前
游戏动作(OpenPose)素材采集与优化全攻略
游戏·序列帧动画·动捕·游戏设计·游戏素材·角色动作
锦瑟弦音21 小时前
微信小游戏分包(cocos自带分包)
笔记·游戏
ok406lhq1 天前
unity游戏调用SDK支付返回游戏会出现画面移位的问题
android·游戏·unity·游戏引擎·sdk
郝学胜-神的一滴1 天前
封装OpenGL的Shader相关类:从理论到实践
开发语言·c++·程序人生·游戏·图形渲染