aboutsummaryrefslogtreecommitdiff
path: root/client/gui/overlays/debug
diff options
context:
space:
mode:
Diffstat (limited to 'client/gui/overlays/debug')
-rw-r--r--client/gui/overlays/debug/debug.gd39
-rw-r--r--client/gui/overlays/debug/debug.gd.uid1
-rw-r--r--client/gui/overlays/debug/debug.tscn43
-rw-r--r--client/gui/overlays/debug/debug_pie.gd108
-rw-r--r--client/gui/overlays/debug/debug_pie.gd.uid1
-rw-r--r--client/gui/overlays/debug/pie.tscn9
6 files changed, 201 insertions, 0 deletions
diff --git a/client/gui/overlays/debug/debug.gd b/client/gui/overlays/debug/debug.gd
new file mode 100644
index 00000000..3a37a1b7
--- /dev/null
+++ b/client/gui/overlays/debug/debug.gd
@@ -0,0 +1,39 @@
+# Hurry Curry! - a game about cooking
+# Copyright (C) 2025 Hurry Curry! contributors
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, version 3 of the License only.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
+#
+extends RichTextLabel
+
+func _ready():
+ Settings.hook_changed_init("graphics.debug_info", "main", func (v):
+ visible = v
+ RenderingServer.viewport_set_measure_render_time(get_viewport().get_viewport_rid(), visible)
+ )
+
+func _process(_delta):
+ if not visible: return
+ var t = ""
+ t += " Renderer: %s (%s)\n" % [RenderingServer.get_current_rendering_driver_name(), RenderingServer.get_video_adapter_name()]
+ t += " Timing: %.01fms CPU; %.01fms GPU\n" % [
+ RenderingServer.viewport_get_measured_render_time_cpu(get_viewport().get_viewport_rid()),
+ RenderingServer.viewport_get_measured_render_time_gpu(get_viewport().get_viewport_rid())
+ ]
+ t += " Resolution: %dx%d\n" % [get_tree().root.size.x, get_tree().root.size.y]
+ t += " FPS: %d\n" % Engine.get_frames_per_second()
+ t += " Node count: %d\n" % get_tree().get_node_count()
+ text = t
+
+func _input(_event):
+ if Input.is_action_just_pressed("toggle_debug"):
+ Settings.write("graphics.debug_info", not Settings.read("graphics.debug_info"))
diff --git a/client/gui/overlays/debug/debug.gd.uid b/client/gui/overlays/debug/debug.gd.uid
new file mode 100644
index 00000000..318ab745
--- /dev/null
+++ b/client/gui/overlays/debug/debug.gd.uid
@@ -0,0 +1 @@
+uid://bpmdfuqjtwf5v
diff --git a/client/gui/overlays/debug/debug.tscn b/client/gui/overlays/debug/debug.tscn
new file mode 100644
index 00000000..c794c161
--- /dev/null
+++ b/client/gui/overlays/debug/debug.tscn
@@ -0,0 +1,43 @@
+[gd_scene load_steps=6 format=3 uid="uid://3lytexnfrub6"]
+
+[ext_resource type="Script" uid="uid://bpmdfuqjtwf5v" path="res://gui/overlays/debug/debug.gd" id="1_62otr"]
+[ext_resource type="Script" uid="uid://byshs20og68tn" path="res://gui/components/smart_margin_container.gd" id="1_c21gy"]
+[ext_resource type="Script" uid="uid://c40pm2fx0t5t8" path="res://gui/overlays/debug/debug_pie.gd" id="3_weeal"]
+[ext_resource type="FontFile" uid="uid://bk704sc5gkrb3" path="res://gui/resources/fonts/font-azaret-mono.woff2" id="4_fa78f"]
+
+[sub_resource type="FontVariation" id="FontVariation_42mmf"]
+base_font = ExtResource("4_fa78f")
+variation_opentype = {
+2003265652: 700
+}
+
+[node name="SmartMarginContainer" type="MarginContainer"]
+anchors_preset = 15
+anchor_right = 1.0
+anchor_bottom = 1.0
+grow_horizontal = 2
+grow_vertical = 2
+mouse_filter = 2
+theme_override_constants/margin_left = 10
+theme_override_constants/margin_top = 10
+theme_override_constants/margin_right = 10
+theme_override_constants/margin_bottom = 10
+script = ExtResource("1_c21gy")
+metadata/_custom_type_script = "uid://byshs20og68tn"
+
+[node name="Debug" type="RichTextLabel" parent="."]
+visible = false
+layout_mode = 2
+mouse_filter = 2
+theme_override_colors/font_outline_color = Color(0, 0, 0, 1)
+theme_override_constants/outline_size = 10
+script = ExtResource("1_62otr")
+
+[node name="DebugPie" type="Control" parent="."]
+visible = false
+layout_mode = 2
+size_flags_horizontal = 8
+size_flags_vertical = 8
+mouse_filter = 2
+script = ExtResource("3_weeal")
+font = SubResource("FontVariation_42mmf")
diff --git a/client/gui/overlays/debug/debug_pie.gd b/client/gui/overlays/debug/debug_pie.gd
new file mode 100644
index 00000000..c1140683
--- /dev/null
+++ b/client/gui/overlays/debug/debug_pie.gd
@@ -0,0 +1,108 @@
+extends Control
+
+@export var radius: float = 150
+@export var pie_squish: float = 0.6
+@export var font: Font
+const circle_res := 128.
+
+var current_class := "Node"
+var data = {}
+var class_lookup = {}
+
+var offset = 0.
+var font_size = radius / 10
+
+var sorted := []
+var total = 0
+
+func _ready():
+ custom_minimum_size = get_draw_size()
+
+func _process(_dt):
+ setup_counters()
+ traverse(get_tree().root)
+ sort_counters()
+ queue_redraw()
+
+func _input(event: InputEvent):
+ if event is InputEventKey and event.is_pressed():
+ if Input.is_action_pressed("toggle_debug"):
+ visible = event.as_text_key_label() == "1"
+ current_class = "Node"
+ return
+ if not visible: return
+ var text = event.as_text()
+ if not text.is_valid_int(): return
+ var num = int(text)
+ if num > sorted.size(): return
+ if num == 0:
+ if current_class == "Node": return
+ current_class = ClassDB.get_parent_class(current_class)
+ else: current_class = sorted[num - 1][0]
+
+func setup_counters():
+ class_lookup.clear()
+ data.clear()
+ for c in ClassDB.get_inheriters_from_class(current_class):
+ if ClassDB.get_parent_class(c) == current_class:
+ class_lookup[c] = c
+ data[c] = 0
+ for c2 in ClassDB.get_inheriters_from_class(c):
+ class_lookup[c2] = c
+
+func traverse(node: Node):
+ var cls = node.get_class()
+ if class_lookup.has(cls): data[class_lookup[cls]] += 1
+ for c in node.get_children(): traverse(c)
+
+func sort_counters():
+ total = 0
+ sorted.clear()
+ for key in data:
+ if data[key] == 0: continue
+ sorted.append([key, data[key]])
+ total += data[key]
+ sorted.sort_custom(func(a,b): return a[1] > b[1])
+
+func draw_slice(start: float, end: float, color: Color):
+ var a = PackedVector2Array()
+ a.append(Vector2.ZERO)
+ var res = ceil((end - start) * 128)
+ for i in range(res + 1):
+ var ang = lerpf(start, end, float(i) / res)
+ a.append(Vector2(sin(ang), -cos(ang) * pie_squish) * radius)
+ draw_colored_polygon(a, color)
+
+func get_draw_size():
+ return Vector2(1, 1.5) * radius * 2.
+
+func _draw():
+ draw_rect(Rect2(Vector2.ZERO, get_draw_size()), Color(.1,.1,.1,0.8))
+ offset = 0.
+ draw_row(0, current_class, total)
+ draw_pie()
+ for i in range(sorted.size()):
+ var label = sorted[i][0]; var value = sorted[i][1]
+ draw_row(i + 1, label, value)
+
+func draw_pie():
+ draw_set_transform(Vector2(radius, offset + radius * pie_squish))
+ var angle = 0.
+ for i in range(sorted.size()):
+ var label = sorted[i][0]; var value = sorted[i][1]
+ var inc = float(value) / float(total) * PI * 2.
+ draw_slice(angle, angle + inc, label_color(i+1, label))
+ angle += inc
+ offset += radius * 2 * pie_squish
+ draw_set_transform(Vector2.ZERO)
+
+func draw_row(index: int, label: String, value: int):
+ offset += font_size
+ var color = label_color(index, label)
+ var text_left = "[%d] %s" % [index, label]
+ var text_right = "%3d" % value
+ draw_string(font, Vector2(0., offset), text_left, HORIZONTAL_ALIGNMENT_LEFT, radius * 1.5, font_size, color)
+ draw_string(font, Vector2(radius * 1.5, offset), text_right, HORIZONTAL_ALIGNMENT_LEFT, radius * 0.5, font_size, color)
+
+func label_color(i: int, _label: String) -> Color:
+ return Color.from_hsv(fmod(float(i + current_class.hash() & 0xffff) / 3.5, 1.), 0.5, 1.)
diff --git a/client/gui/overlays/debug/debug_pie.gd.uid b/client/gui/overlays/debug/debug_pie.gd.uid
new file mode 100644
index 00000000..24590101
--- /dev/null
+++ b/client/gui/overlays/debug/debug_pie.gd.uid
@@ -0,0 +1 @@
+uid://c40pm2fx0t5t8
diff --git a/client/gui/overlays/debug/pie.tscn b/client/gui/overlays/debug/pie.tscn
new file mode 100644
index 00000000..69872d72
--- /dev/null
+++ b/client/gui/overlays/debug/pie.tscn
@@ -0,0 +1,9 @@
+[gd_scene format=3 uid="uid://27qwbrf7mh7i"]
+
+[node name="DebugPie" type="Control"]
+layout_mode = 3
+anchors_preset = 15
+anchor_right = 1.0
+anchor_bottom = 1.0
+grow_horizontal = 2
+grow_vertical = 2