Debug Draw 3D (and 2D) 1.4.5
Draw 3D debug graphics and 2D overlays with this add-on.
Loading...
Searching...
No Matches
debug_draw_3d.h
1#pragma once
2
3#include "common/colors.h"
4#include "common/i_scope_storage.h"
5#include "config_scope_3d.h"
6#include "render_instances_enums.h"
7#include "utils/profiler.h"
8
9#include <map>
10#include <memory>
11#include <mutex>
12
13GODOT_WARNING_DISABLE()
14#include <godot_cpp/classes/array_mesh.hpp>
15#include <godot_cpp/classes/node3d.hpp>
16#include <godot_cpp/classes/shader.hpp>
17#include <godot_cpp/classes/shader_material.hpp>
18#include <godot_cpp/classes/sub_viewport.hpp>
19GODOT_WARNING_RESTORE()
20using namespace godot;
21
22class DebugDraw3D;
23class DataGraphManager;
27
28#ifndef DISABLE_DEBUG_RENDERING
29class DebugGeometryContainer;
30struct DelayedRendererLine;
31#endif
32
34enum class MeshMaterialType : char {
35 Wireframe,
36 Billboard,
37 Plane,
38 Extendable,
39 MAX,
40};
41
43enum class MeshMaterialVariant : char {
44 Normal,
45 NoDepth,
46 MAX,
47};
48
49#ifndef DISABLE_DEBUG_RENDERING
51class _DD3D_WorldWatcher : public Node3D {
52 GDCLASS(_DD3D_WorldWatcher, Node3D)
53protected:
54 DebugDraw3D *m_owner = nullptr;
55 uint64_t m_world_id;
56 static void _bind_methods(){};
57
58public:
59 virtual void _process(double p_delta) override;
60 virtual void _notification(int p_what);
61
62 _DD3D_WorldWatcher() :
63 m_world_id() {}
64 _DD3D_WorldWatcher(DebugDraw3D *p_root, uint64_t p_world_id);
65};
66
67#endif
68
116class DebugDraw3D : public Object, public IScopeStorage<DebugDraw3DScopeConfig, DebugDraw3DScopeConfig::Data> {
117 GDCLASS(DebugDraw3D, Object)
118
119 friend DebugDrawManager;
120
121#ifndef DISABLE_DEBUG_RENDERING
122 friend DebugGeometryContainer;
123 friend _DD3D_WorldWatcher;
124#endif
125
126public:
130 enum PointType : int {
131 POINT_TYPE_SQUARE,
132 POINT_TYPE_SPHERE,
133 };
134
135private:
136 static DebugDraw3D *singleton;
137
138 String root_settings_section;
139 const static char *s_use_icosphere;
140 const static char *s_use_icosphere_hd;
141 const static char *s_add_bevel_to_volumetric;
142 const static char *s_default_frustum_scale;
143
144 const static char *s_default_thickness;
145 const static char *s_default_center_brightness;
146 const static char *s_default_hd_spheres;
147 const static char *s_default_plane_size;
148
149 const static char *s_render_priority;
150 const static char *s_render_mode;
151 const static char *s_render_fog_disabled;
152
153 std::vector<SubViewport *> custom_editor_viewports;
154 DebugDrawManager *root_node = nullptr;
155
156 Ref<DebugDraw3DScopeConfig> default_scoped_config;
157
158#ifndef DISABLE_DEBUG_RENDERING
159 ProfiledMutex(std::recursive_mutex, datalock, "3D Geometry lock");
160
161 struct ScopedPairIdConfig {
162 uint64_t id;
164 ScopedPairIdConfig(uint64_t id, DebugDraw3DScopeConfig *scfg) :
165 id(id), scfg(scfg) {}
166 };
167 // stores thread id and array of id's with ptrs
168 std::unordered_map<uint64_t, std::vector<ScopedPairIdConfig> > scoped_configs;
169 // stores thread id and most recent config
170 std::unordered_map<uint64_t, std::shared_ptr<DebugDraw3DScopeConfig::Data> > cached_scoped_configs;
171 uint64_t created_scoped_configs = 0;
172 struct {
173 uint64_t created;
174 uint64_t orphans;
175 } scoped_stats_3d = {};
176
177 // Inherited via IScopeStorage
178 const std::shared_ptr<DebugDraw3DScopeConfig::Data> scoped_config_for_current_thread() override;
179
180 // Meshes
182 std::vector<std::array<Ref<ArrayMesh>, (int)MeshMaterialVariant::MAX> > shared_generated_meshes;
183
185 struct ViewportToDebugContainerItem {
186 uint64_t world_id;
187 std::unique_ptr<DebugGeometryContainer> dgcs[(int)MeshMaterialVariant::MAX];
188
189 ViewportToDebugContainerItem();
190 ViewportToDebugContainerItem(ViewportToDebugContainerItem &&other) noexcept;
191 ~ViewportToDebugContainerItem();
192 };
193
194 std::unordered_map<uint64_t, ViewportToDebugContainerItem> debug_containers;
195 std::unordered_map<const Viewport *, ViewportToDebugContainerItem *> viewport_to_world_cache;
196
197 // Default materials and shaders
198 Ref<ShaderMaterial> mesh_shaders[(int)MeshMaterialType::MAX][(int)MeshMaterialVariant::MAX];
199
200 // Inherited via IScopeStorage
201 void _register_scoped_config(uint64_t p_thread_id, uint64_t p_guard_id, DebugDraw3DScopeConfig *p_cfg) override;
202 void _unregister_scoped_config(uint64_t p_thread_id, uint64_t p_guard_id) override;
203 void _clear_scoped_configs() override;
204
205 std::array<Ref<ArrayMesh>, (int)MeshMaterialVariant::MAX> *get_shared_meshes();
206 DebugGeometryContainer *get_debug_container(const DebugDraw3DScopeConfig::DebugContainerDependent &p_dgcd, const bool p_generate_new_container);
207 void _register_viewport_world_deferred(uint64_t /*Viewport * */ p_vp, const uint64_t p_world_id);
208 Viewport *_get_root_world_viewport(Viewport *p_vp);
209 void _remove_debug_container(const uint64_t &p_world_id);
210
211 _FORCE_INLINE_ Vector3 get_up_vector(const Vector3 &p_dir);
212 void add_or_update_line_with_thickness(real_t p_exp_time, std::unique_ptr<Vector3[]> p_lines, const size_t p_line_count, const Color &p_col, const std::function<void(DelayedRendererLine *)> p_custom_upd = nullptr);
213 Node *get_root_node();
214
215 void create_arrow(const Vector3 &p_a, const Vector3 &p_b, const Color &p_color, const real_t &p_arrow_size, const bool &p_is_absolute_size, const real_t &p_duration = 0);
216
217#ifdef DEV_ENABLED
218 void _save_generated_meshes();
219#endif
220
221#endif
222
223 void init(DebugDrawManager *p_root);
224
225 void set_custom_editor_viewport(std::vector<SubViewport *> p_viewports);
226 std::vector<SubViewport *> get_custom_editor_viewports();
227
228 Ref<ShaderMaterial> get_material_variant(MeshMaterialType p_type, MeshMaterialVariant p_var);
229
230 void _load_materials();
231 inline bool _is_enabled_override() const;
232
233 void process_start(double delta);
234 void process_end(double delta);
235 void physics_process_start(double p_delta);
236 void physics_process_end(double p_delta);
237
238#pragma region Exposed Parameter Values
239
241 bool debug_enabled = true;
242
243 Ref<DebugDraw3DConfig> config;
244
245#pragma endregion // Exposed Parameter Values
246
247protected:
249 static void _bind_methods();
250
251public:
252 DebugDraw3D();
253 ~DebugDraw3D();
254
259 return singleton;
260 };
261
262#pragma region Configs
270 Ref<DebugDraw3DScopeConfig> new_scoped_config();
276 Ref<DebugDraw3DScopeConfig> scoped_config() override;
277
281 void set_config(Ref<DebugDraw3DConfig> cfg);
285 Ref<DebugDraw3DConfig> get_config() const;
286
287#pragma endregion // Configs
288
289#pragma region Exposed Parameters
291 void set_empty_color(const Color &col){};
295 Color get_empty_color() const;
296
300 void set_debug_enabled(const bool &state);
301 bool is_debug_enabled() const;
302
303#pragma endregion // Exposed Parametes
304
305#pragma region Exposed Draw Methods
306
312 Ref<DebugDraw3DStats> get_render_stats();
313
319 Ref<DebugDraw3DStats> get_render_stats_for_world(Viewport *viewport);
320
321#ifndef DISABLE_DEBUG_RENDERING
322#define FAKE_FUNC_IMPL
323#else
324#define FAKE_FUNC_IMPL \
325 {}
326#endif
327
334
338 void clear_all();
339
340#pragma region Spheres
341
343 void draw_sphere_base(const Transform3D &transform, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
354 void draw_sphere(const Vector3 &position, const real_t &radius = 0.5f, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
364 void draw_sphere_xf(const Transform3D &transform, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
365
366#pragma endregion // Spheres
367
368#pragma region Cylinders
369
379 void draw_cylinder(const Transform3D &transform, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
380
392 void draw_cylinder_ab(const Vector3 &a, const Vector3 &b, const real_t &radius = 0.5f, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
393
394#pragma endregion // Cylinders
395
396#pragma region Boxes
397
412 void draw_box(const Vector3 &position, const Quaternion &rotation, const Vector3 &size, const Color &color = Colors::empty_color, const bool &is_box_centered = false, const real_t &duration = 0) FAKE_FUNC_IMPL;
413
428 void draw_box_ab(const Vector3 &a, const Vector3 &b, const Vector3 &up, const Color &color = Colors::empty_color, const bool &is_ab_diagonal = true, const real_t &duration = 0) FAKE_FUNC_IMPL;
429
438 void draw_box_xf(const Transform3D &transform, const Color &color = Colors::empty_color, const bool &is_box_centered = true, const real_t &duration = 0) FAKE_FUNC_IMPL;
439
447 void draw_aabb(const AABB &aabb, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
448
457 void draw_aabb_ab(const Vector3 &a, const Vector3 &b, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
458
459#pragma endregion // Boxes
460
461#pragma region Lines
462
479 void draw_line_hit(const Vector3 &start, const Vector3 &end, const Vector3 &hit, const bool &is_hit, const real_t &hit_size = 0.25f, const Color &hit_color = Colors::empty_color, const Color &after_hit_color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
480
497 void draw_line_hit_offset(const Vector3 &start, const Vector3 &end, const bool &is_hit, const real_t &unit_offset_of_hit = 0.5f, const real_t &hit_size = 0.25f, const Color &hit_color = Colors::empty_color, const Color &after_hit_color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
498
499#pragma region Normal
500
502 void draw_lines_c(const std::vector<Vector3> &lines, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
513 void draw_line(const Vector3 &a, const Vector3 &b, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
514
526 void draw_ray(const Vector3 &origin, const Vector3 &direction, const real_t &length, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
527
537 void draw_lines(const PackedVector3Array &lines, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
538
550 void draw_line_path(const PackedVector3Array &path, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
551
552#pragma endregion // Normal
553
554#pragma region Arrows
555
563 void draw_arrowhead(const Transform3D &transform, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
564
577 void draw_arrow(const Vector3 &a, const Vector3 &b, const Color &color = Colors::empty_color, const real_t &arrow_size = 0.5f, const bool &is_absolute_size = false, const real_t &duration = 0) FAKE_FUNC_IMPL;
578
590 void draw_arrow_ray(const Vector3 &origin, const Vector3 &direction, const real_t &length, const Color &color = Colors::empty_color, const real_t &arrow_size = 0.5f, const bool &is_absolute_size = false, const real_t &duration = 0) FAKE_FUNC_IMPL;
591
603 void draw_arrow_path(const PackedVector3Array &path, const Color &color = Colors::empty_color, const real_t &arrow_size = 0.75f, const bool &is_absolute_size = true, const real_t &duration = 0) FAKE_FUNC_IMPL;
604
605#pragma endregion // Arrows
606#pragma region Points
607
622 void draw_point_path(const PackedVector3Array &path, const PointType type = PointType::POINT_TYPE_SQUARE, const real_t &size = 0.25f, const Color &points_color = Colors::empty_color, const Color &lines_color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
623
624#pragma endregion // Points
625#pragma endregion // Lines
626
627#pragma region Misc
628
640 void draw_points(const PackedVector3Array &points, const PointType type = PointType::POINT_TYPE_SQUARE, const real_t &size = 0.25f, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
641
650 void draw_square(const Vector3 &position, const real_t &size = 0.2f, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
651
664 void draw_plane(const Plane &plane, const Color &color = Colors::empty_color, const Vector3 &anchor_point = Vector3(INFINITY, INFINITY, INFINITY), const real_t &duration = 0) FAKE_FUNC_IMPL;
665
675 void draw_position(const Transform3D &transform, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
676
689 void draw_gizmo(const Transform3D &transform, const Color &color = Colors::empty_color, const bool &is_centered = false, const real_t &duration = 0) FAKE_FUNC_IMPL;
690
704 void draw_grid(const Vector3 &origin, const Vector3 &x_size, const Vector3 &y_size, const Vector2i &subdivision, const Color &color = Colors::empty_color, const bool &is_centered = true, const real_t &duration = 0) FAKE_FUNC_IMPL;
705
717 void draw_grid_xf(const Transform3D &transform, const Vector2i &p_subdivision, const Color &color = Colors::empty_color, const bool &is_centered = true, const real_t &duration = 0) FAKE_FUNC_IMPL;
718
719#pragma region Camera Frustum
720
722 void draw_camera_frustum_planes_c(const std::array<Plane, 6> &planes, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
732 void draw_camera_frustum(const class godot::Camera3D *camera, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
733
741 void draw_camera_frustum_planes(const Array &camera_frustum, const Color &color = Colors::empty_color, const real_t &duration = 0) FAKE_FUNC_IMPL;
742
743#pragma endregion // Camera Frustum
744
745#pragma endregion // Misc
746#pragma endregion // Exposed Draw Methods
747
748#undef FAKE_FUNC_IMPL
749};
750
751VARIANT_ENUM_CAST(DebugDraw3D::PointType);
This is a class for storing part of the DebugDraw3D configuration.
Definition config_3d.h:17
This class is used to override scope parameters for DebugDraw3D.
Definition config_scope_3d.h:58
You can get statistics about 3D rendering from this class.
Definition stats_3d.h:24
Singleton class for calling debugging 3D methods.
Definition debug_draw_3d.h:116
void draw_line(const Vector3 &a, const Vector3 &b, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_points(const PackedVector3Array &points, const PointType type=PointType::POINT_TYPE_SQUARE, const real_t &size=0.25f, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_camera_frustum_planes(const Array &camera_frustum, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_square(const Vector3 &position, const real_t &size=0.2f, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_cylinder_ab(const Vector3 &a, const Vector3 &b, const real_t &radius=0.5f, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_grid_xf(const Transform3D &transform, const Vector2i &p_subdivision, const Color &color=Colors::empty_color, const bool &is_centered=true, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_arrow_ray(const Vector3 &origin, const Vector3 &direction, const real_t &length, const Color &color=Colors::empty_color, const real_t &arrow_size=0.5f, const bool &is_absolute_size=false, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_box_ab(const Vector3 &a, const Vector3 &b, const Vector3 &up, const Color &color=Colors::empty_color, const bool &is_ab_diagonal=true, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_camera_frustum(const class godot::Camera3D *camera, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void set_debug_enabled(const bool &state)
void draw_aabb(const AABB &aabb, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void clear_all()
void draw_cylinder(const Transform3D &transform, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_ray(const Vector3 &origin, const Vector3 &direction, const real_t &length, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void regenerate_geometry_meshes()
Ref< DebugDraw3DConfig > get_config() const
void draw_line_hit(const Vector3 &start, const Vector3 &end, const Vector3 &hit, const bool &is_hit, const real_t &hit_size=0.25f, const Color &hit_color=Colors::empty_color, const Color &after_hit_color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_line_path(const PackedVector3Array &path, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_sphere(const Vector3 &position, const real_t &radius=0.5f, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_aabb_ab(const Vector3 &a, const Vector3 &b, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
PointType
Definition debug_draw_3d.h:130
void draw_arrow_path(const PackedVector3Array &path, const Color &color=Colors::empty_color, const real_t &arrow_size=0.75f, const bool &is_absolute_size=true, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_box(const Vector3 &position, const Quaternion &rotation, const Vector3 &size, const Color &color=Colors::empty_color, const bool &is_box_centered=false, const real_t &duration=0) FAKE_FUNC_IMPL
Ref< DebugDraw3DScopeConfig > new_scoped_config()
Color get_empty_color() const
Ref< DebugDraw3DStats > get_render_stats()
Ref< DebugDraw3DScopeConfig > scoped_config() override
void draw_grid(const Vector3 &origin, const Vector3 &x_size, const Vector3 &y_size, const Vector2i &subdivision, const Color &color=Colors::empty_color, const bool &is_centered=true, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_gizmo(const Transform3D &transform, const Color &color=Colors::empty_color, const bool &is_centered=false, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_line_hit_offset(const Vector3 &start, const Vector3 &end, const bool &is_hit, const real_t &unit_offset_of_hit=0.5f, const real_t &hit_size=0.25f, const Color &hit_color=Colors::empty_color, const Color &after_hit_color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_plane(const Plane &plane, const Color &color=Colors::empty_color, const Vector3 &anchor_point=Vector3(INFINITY, INFINITY, INFINITY), const real_t &duration=0) FAKE_FUNC_IMPL
void draw_lines(const PackedVector3Array &lines, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_position(const Transform3D &transform, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_sphere_xf(const Transform3D &transform, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_arrow(const Vector3 &a, const Vector3 &b, const Color &color=Colors::empty_color, const real_t &arrow_size=0.5f, const bool &is_absolute_size=false, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_box_xf(const Transform3D &transform, const Color &color=Colors::empty_color, const bool &is_box_centered=true, const real_t &duration=0) FAKE_FUNC_IMPL
static DebugDraw3D * get_singleton()
Definition debug_draw_3d.h:258
void draw_arrowhead(const Transform3D &transform, const Color &color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
void draw_point_path(const PackedVector3Array &path, const PointType type=PointType::POINT_TYPE_SQUARE, const real_t &size=0.25f, const Color &points_color=Colors::empty_color, const Color &lines_color=Colors::empty_color, const real_t &duration=0) FAKE_FUNC_IMPL
Ref< DebugDraw3DStats > get_render_stats_for_world(Viewport *viewport)
void set_config(Ref< DebugDraw3DConfig > cfg)
The main singleton class that handles DebugDraw2D and DebugDraw3D.
Definition debug_draw_manager.h:54