diff options
author | Rie <riedev@proton.me> | 2024-11-13 16:16:48 +0100 |
---|---|---|
committer | Rie <riedev@proton.me> | 2024-11-16 11:30:48 +0100 |
commit | 31a3b418f72f8665db1420f0c220cce28ac0069a (patch) | |
tree | 46f6f7f1013e62c981321cba363114564838f770 /editor/plugins | |
parent | 98ddec4b8b64e1253fb3a2c1ae853c604ff490fa (diff) | |
download | redot-engine-31a3b418f72f8665db1420f0c220cce28ac0069a.tar.gz |
Fix obstacle avoidance and 3D editor ignoring transform
Diffstat (limited to 'editor/plugins')
-rw-r--r-- | editor/plugins/navigation_obstacle_3d_editor_plugin.cpp | 55 |
1 files changed, 31 insertions, 24 deletions
diff --git a/editor/plugins/navigation_obstacle_3d_editor_plugin.cpp b/editor/plugins/navigation_obstacle_3d_editor_plugin.cpp index 94ad20f05a..efa98d8e4d 100644 --- a/editor/plugins/navigation_obstacle_3d_editor_plugin.cpp +++ b/editor/plugins/navigation_obstacle_3d_editor_plugin.cpp @@ -69,8 +69,10 @@ void NavigationObstacle3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) { } float height = obstacle->get_height(); - Basis gbi = obstacle->get_global_basis().inverse(); + const Basis safe_basis = Basis(Vector3(0.0, 1.0, 0.0), obstacle->get_global_rotation().y, obstacle->get_global_basis().get_scale().abs().maxf(0.001)); + const Basis gbi = obstacle->get_global_basis().inverse(); + const Basis safe_global_basis = gbi * safe_basis; const int vertex_count = vertices.size(); Vector<Vector3> lines_mesh_vertices; @@ -83,21 +85,22 @@ void NavigationObstacle3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) { Vector3 point = vertices[i]; Vector3 next_point = vertices[(i + 1) % vertex_count]; - Vector3 direction = next_point.direction_to(point); + Vector3 direction = safe_basis.xform(next_point.direction_to(point)); Vector3 arrow_dir = direction.cross(Vector3(0.0, 1.0, 0.0)); Vector3 edge_middle = point + ((next_point - point) * 0.5); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(edge_middle); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(edge_middle + (arrow_dir * 0.5)); + // Ensure vector stays perpendicular even when scaled non-uniformly. + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(edge_middle); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(edge_middle) + gbi.xform(arrow_dir) * 0.5; - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(point); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(next_point); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(point); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(next_point); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(Vector3(point.x, height, point.z)); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(Vector3(next_point.x, height, next_point.z)); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(Vector3(point.x, height, point.z)); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(Vector3(next_point.x, height, next_point.z)); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(point); - lines_mesh_vertices_ptrw[vertex_index++] = gbi.xform(Vector3(point.x, height, point.z)); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(point); + lines_mesh_vertices_ptrw[vertex_index++] = safe_global_basis.xform(Vector3(point.x, height, point.z)); } Vector<Vector2> polygon_2d_vertices; @@ -138,7 +141,8 @@ int NavigationObstacle3DGizmoPlugin::subgizmos_intersect_ray(const EditorNode3DG NavigationObstacle3D *obstacle_node = Object::cast_to<NavigationObstacle3D>(p_gizmo->get_node_3d()); ERR_FAIL_NULL_V(obstacle_node, -1); - Transform3D gt = Transform3D(Basis(), obstacle_node->get_global_position()); + const Vector3 safe_scale = obstacle_node->get_global_basis().get_scale().abs().maxf(0.001); + const Transform3D gt = Transform3D(Basis().scaled(safe_scale).rotated(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y), obstacle_node->get_global_position()); const Vector<Vector3> &vertices = obstacle_node->get_vertices(); for (int idx = 0; idx < vertices.size(); ++idx) { @@ -160,7 +164,8 @@ Vector<int> NavigationObstacle3DGizmoPlugin::subgizmos_intersect_frustum(const E NavigationObstacle3D *obstacle_node = Object::cast_to<NavigationObstacle3D>(p_gizmo->get_node_3d()); ERR_FAIL_NULL_V(obstacle_node, contained_points); - Transform3D gt = Transform3D(Basis(), obstacle_node->get_global_position()); + const Vector3 safe_scale = obstacle_node->get_global_basis().get_scale().abs().maxf(0.001); + const Transform3D gt = Transform3D(Basis().scaled(safe_scale).rotated(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y), obstacle_node->get_global_position()); const Vector<Vector3> &vertices = obstacle_node->get_vertices(); for (int idx = 0; idx < vertices.size(); ++idx) { @@ -188,9 +193,8 @@ Transform3D NavigationObstacle3DGizmoPlugin::get_subgizmo_transform(const Editor const Vector<Vector3> &vertices = obstacle_node->get_vertices(); ERR_FAIL_INDEX_V(p_id, vertices.size(), Transform3D()); - Basis gbi = obstacle_node->get_global_basis().inverse(); - - Transform3D subgizmo_transform = Transform3D(Basis(), gbi.xform(vertices[p_id])); + const Basis safe_basis_inverse = Basis(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y, obstacle_node->get_global_basis().get_scale().abs().maxf(0.001)).inverse(); + Transform3D subgizmo_transform = Transform3D(Basis(), safe_basis_inverse.xform(vertices[p_id])); return subgizmo_transform; } @@ -198,14 +202,13 @@ void NavigationObstacle3DGizmoPlugin::set_subgizmo_transform(const EditorNode3DG NavigationObstacle3D *obstacle_node = Object::cast_to<NavigationObstacle3D>(p_gizmo->get_node_3d()); ERR_FAIL_NULL(obstacle_node); - Basis gb = obstacle_node->get_global_basis(); - + const Basis safe_basis = Basis(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y, obstacle_node->get_global_basis().get_scale().abs().maxf(0.001)); Vector3 new_vertex_pos = p_transform.origin; Vector<Vector3> vertices = obstacle_node->get_vertices(); ERR_FAIL_INDEX(p_id, vertices.size()); - Vector3 vertex = gb.xform(new_vertex_pos); + Vector3 vertex = safe_basis.xform(new_vertex_pos); vertex.y = 0.0; vertices.write[p_id] = vertex; @@ -216,14 +219,14 @@ void NavigationObstacle3DGizmoPlugin::commit_subgizmos(const EditorNode3DGizmo * NavigationObstacle3D *obstacle_node = Object::cast_to<NavigationObstacle3D>(p_gizmo->get_node_3d()); ERR_FAIL_NULL(obstacle_node); - Basis gb = obstacle_node->get_global_basis(); + const Basis safe_basis = Basis(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y, obstacle_node->get_global_basis().get_scale().abs().maxf(0.001)); Vector<Vector3> vertices = obstacle_node->get_vertices(); Vector<Vector3> restore_vertices = vertices; for (int i = 0; i < p_ids.size(); ++i) { const int idx = p_ids[i]; - Vector3 vertex = gb.xform(p_restore[i].origin); + Vector3 vertex = safe_basis.xform(p_restore[i].origin); vertex.y = 0.0; restore_vertices.write[idx] = vertex; } @@ -446,7 +449,8 @@ EditorPlugin::AfterGUIInput NavigationObstacle3DEditorPlugin::forward_3d_gui_inp Vector3 ray_from = p_camera->project_ray_origin(mouse_position); Vector3 ray_dir = p_camera->project_ray_normal(mouse_position); - Transform3D gt = Transform3D(Basis(), obstacle_node->get_global_position()); + const Vector3 safe_scale = obstacle_node->get_global_basis().get_scale().abs().maxf(0.001); + const Transform3D gt = Transform3D(Basis().scaled(safe_scale).rotated(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y), obstacle_node->get_global_position()); Transform3D gi = gt.affine_inverse(); Plane projection_plane(Vector3(0.0, 1.0, 0.0), gt.origin); @@ -666,7 +670,8 @@ EditorPlugin::AfterGUIInput NavigationObstacle3DEditorPlugin::forward_3d_gui_inp Vector3 ray_from = p_camera->project_ray_origin(mouse_position); Vector3 ray_dir = p_camera->project_ray_normal(mouse_position); - Transform3D gt = Transform3D(Basis(), obstacle_node->get_global_position()); + const Vector3 safe_scale = obstacle_node->get_global_basis().get_scale().abs().maxf(0.001); + const Transform3D gt = Transform3D(Basis().scaled(safe_scale).rotated(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y), obstacle_node->get_global_position()); Transform3D gi = gt.affine_inverse(); Plane projection_plane(Vector3(0.0, 1.0, 0.0), gt.origin); @@ -762,7 +767,9 @@ void NavigationObstacle3DEditorPlugin::redraw() { rs->mesh_add_surface_from_arrays(point_lines_mesh_rid, RS::PRIMITIVE_LINES, point_lines_mesh_array); rs->instance_set_surface_override_material(point_lines_instance_rid, 0, line_material->get_rid()); - rs->instance_set_transform(point_lines_instance_rid, Transform3D(Basis(), obstacle_node->get_global_position())); + const Vector3 safe_scale = obstacle_node->get_global_basis().get_scale().abs().maxf(0.001); + const Transform3D gt = Transform3D(Basis().scaled(safe_scale).rotated(Vector3(0.0, 1.0, 0.0), obstacle_node->get_global_rotation().y), obstacle_node->get_global_position()); + rs->instance_set_transform(point_lines_instance_rid, gt); Array point_handle_mesh_array; point_handle_mesh_array.resize(Mesh::ARRAY_MAX); @@ -787,7 +794,7 @@ void NavigationObstacle3DEditorPlugin::redraw() { rs->mesh_add_surface_from_arrays(point_handle_mesh_rid, RS::PRIMITIVE_POINTS, point_handle_mesh_array); rs->instance_set_surface_override_material(point_handles_instance_rid, 0, handle_material->get_rid()); - rs->instance_set_transform(point_handles_instance_rid, Transform3D(Basis(), obstacle_node->get_global_position())); + rs->instance_set_transform(point_handles_instance_rid, gt); } NavigationObstacle3DEditorPlugin *NavigationObstacle3DEditorPlugin::singleton = nullptr; |