Fixes concaveshape not selecting in viewport
This PR resolves the issue of ConcaveShapes not being selectable in the Viewport.
This commit is contained in:
parent
781e4f8673
commit
29690f6aec
21 changed files with 31 additions and 26 deletions
|
@ -3730,6 +3730,7 @@ void CollisionShapeSpatialGizmoPlugin::redraw(EditorSpatialGizmo *p_gizmo) {
|
||||||
Ref<ConcavePolygonShape> cs2 = s;
|
Ref<ConcavePolygonShape> cs2 = s;
|
||||||
Ref<ArrayMesh> mesh = cs2->get_debug_mesh();
|
Ref<ArrayMesh> mesh = cs2->get_debug_mesh();
|
||||||
p_gizmo->add_mesh(mesh, false, Ref<SkinReference>(), material);
|
p_gizmo->add_mesh(mesh, false, Ref<SkinReference>(), material);
|
||||||
|
p_gizmo->add_collision_segments(cs2->get_debug_mesh_lines());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Object::cast_to<RayShape>(*s)) {
|
if (Object::cast_to<RayShape>(*s)) {
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "box_shape.h"
|
#include "box_shape.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> BoxShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> BoxShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
Vector<Vector3> lines;
|
Vector<Vector3> lines;
|
||||||
AABB aabb;
|
AABB aabb;
|
||||||
|
|
|
@ -42,12 +42,13 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_extents(const Vector3 &p_extents);
|
void set_extents(const Vector3 &p_extents);
|
||||||
Vector3 get_extents() const;
|
Vector3 get_extents() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
BoxShape();
|
BoxShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "capsule_shape.h"
|
#include "capsule_shape.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> CapsuleShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> CapsuleShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
float radius = get_radius();
|
float radius = get_radius();
|
||||||
float height = get_height();
|
float height = get_height();
|
||||||
|
|
|
@ -44,14 +44,14 @@ protected:
|
||||||
|
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
|
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_radius(float p_radius);
|
void set_radius(float p_radius);
|
||||||
float get_radius() const;
|
float get_radius() const;
|
||||||
void set_height(float p_height);
|
void set_height(float p_height);
|
||||||
float get_height() const;
|
float get_height() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
CapsuleShape();
|
CapsuleShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
|
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> ConcavePolygonShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> ConcavePolygonShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
Set<DrawEdge> edges;
|
Set<DrawEdge> edges;
|
||||||
|
|
||||||
|
|
|
@ -61,12 +61,13 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_faces(const PoolVector<Vector3> &p_faces);
|
void set_faces(const PoolVector<Vector3> &p_faces);
|
||||||
PoolVector<Vector3> get_faces() const;
|
PoolVector<Vector3> get_faces() const;
|
||||||
|
|
||||||
|
Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
ConcavePolygonShape();
|
ConcavePolygonShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include "core/math/quick_hull.h"
|
#include "core/math/quick_hull.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> ConvexPolygonShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> ConvexPolygonShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
PoolVector<Vector3> points = get_points();
|
PoolVector<Vector3> points = get_points();
|
||||||
|
|
||||||
|
|
|
@ -43,12 +43,12 @@ protected:
|
||||||
|
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
|
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_points(const PoolVector<Vector3> &p_points);
|
void set_points(const PoolVector<Vector3> &p_points);
|
||||||
PoolVector<Vector3> get_points() const;
|
PoolVector<Vector3> get_points() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
ConvexPolygonShape();
|
ConvexPolygonShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "cylinder_shape.h"
|
#include "cylinder_shape.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> CylinderShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> CylinderShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
float radius = get_radius();
|
float radius = get_radius();
|
||||||
float height = get_height();
|
float height = get_height();
|
||||||
|
|
|
@ -43,14 +43,14 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
|
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_radius(float p_radius);
|
void set_radius(float p_radius);
|
||||||
float get_radius() const;
|
float get_radius() const;
|
||||||
void set_height(float p_height);
|
void set_height(float p_height);
|
||||||
float get_height() const;
|
float get_height() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
CylinderShape();
|
CylinderShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "height_map_shape.h"
|
#include "height_map_shape.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> HeightMapShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> HeightMapShape::get_debug_mesh_lines() {
|
||||||
Vector<Vector3> points;
|
Vector<Vector3> points;
|
||||||
|
|
||||||
if ((map_width != 0) && (map_depth != 0)) {
|
if ((map_width != 0) && (map_depth != 0)) {
|
||||||
|
|
|
@ -46,8 +46,6 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
|
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_map_width(int p_new);
|
void set_map_width(int p_new);
|
||||||
int get_map_width() const;
|
int get_map_width() const;
|
||||||
|
@ -56,6 +54,8 @@ public:
|
||||||
void set_map_data(PoolRealArray p_new);
|
void set_map_data(PoolRealArray p_new);
|
||||||
PoolRealArray get_map_data() const;
|
PoolRealArray get_map_data() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
HeightMapShape();
|
HeightMapShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
|
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> PlaneShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> PlaneShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
Plane p = get_plane();
|
Plane p = get_plane();
|
||||||
Vector<Vector3> points;
|
Vector<Vector3> points;
|
||||||
|
|
|
@ -42,12 +42,12 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
|
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_plane(Plane p_plane);
|
void set_plane(Plane p_plane);
|
||||||
Plane get_plane() const;
|
Plane get_plane() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
PlaneShape();
|
PlaneShape();
|
||||||
};
|
};
|
||||||
#endif // PLANE_SHAPE_H
|
#endif // PLANE_SHAPE_H
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
|
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> RayShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> RayShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
Vector<Vector3> points;
|
Vector<Vector3> points;
|
||||||
points.push_back(Vector3());
|
points.push_back(Vector3());
|
||||||
|
|
|
@ -41,7 +41,6 @@ class RayShape : public Shape {
|
||||||
protected:
|
protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_length(float p_length);
|
void set_length(float p_length);
|
||||||
|
@ -50,6 +49,8 @@ public:
|
||||||
void set_slips_on_slope(bool p_active);
|
void set_slips_on_slope(bool p_active);
|
||||||
bool get_slips_on_slope() const;
|
bool get_slips_on_slope() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
RayShape();
|
RayShape();
|
||||||
};
|
};
|
||||||
#endif // RAY_SHAPE_H
|
#endif // RAY_SHAPE_H
|
||||||
|
|
|
@ -37,7 +37,7 @@
|
||||||
|
|
||||||
void Shape::add_vertices_to_array(PoolVector<Vector3> &array, const Transform &p_xform) {
|
void Shape::add_vertices_to_array(PoolVector<Vector3> &array, const Transform &p_xform) {
|
||||||
|
|
||||||
Vector<Vector3> toadd = _gen_debug_mesh_lines();
|
Vector<Vector3> toadd = get_debug_mesh_lines();
|
||||||
|
|
||||||
if (toadd.size()) {
|
if (toadd.size()) {
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ Ref<ArrayMesh> Shape::get_debug_mesh() {
|
||||||
if (debug_mesh_cache.is_valid())
|
if (debug_mesh_cache.is_valid())
|
||||||
return debug_mesh_cache;
|
return debug_mesh_cache;
|
||||||
|
|
||||||
Vector<Vector3> lines = _gen_debug_mesh_lines();
|
Vector<Vector3> lines = get_debug_mesh_lines();
|
||||||
|
|
||||||
debug_mesh_cache = Ref<ArrayMesh>(memnew(ArrayMesh));
|
debug_mesh_cache = Ref<ArrayMesh>(memnew(ArrayMesh));
|
||||||
|
|
||||||
|
|
|
@ -50,13 +50,13 @@ protected:
|
||||||
_FORCE_INLINE_ RID get_shape() const { return shape; }
|
_FORCE_INLINE_ RID get_shape() const { return shape; }
|
||||||
Shape(RID p_shape);
|
Shape(RID p_shape);
|
||||||
|
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines() = 0; // { return Vector<Vector3>(); }
|
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual RID get_rid() const { return shape; }
|
virtual RID get_rid() const { return shape; }
|
||||||
|
|
||||||
Ref<ArrayMesh> get_debug_mesh();
|
Ref<ArrayMesh> get_debug_mesh();
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines() = 0; // { return Vector<Vector3>(); }
|
||||||
|
|
||||||
void add_vertices_to_array(PoolVector<Vector3> &array, const Transform &p_xform);
|
void add_vertices_to_array(PoolVector<Vector3> &array, const Transform &p_xform);
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "sphere_shape.h"
|
#include "sphere_shape.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
Vector<Vector3> SphereShape::_gen_debug_mesh_lines() {
|
Vector<Vector3> SphereShape::get_debug_mesh_lines() {
|
||||||
|
|
||||||
float r = get_radius();
|
float r = get_radius();
|
||||||
|
|
||||||
|
|
|
@ -42,12 +42,13 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
virtual void _update_shape();
|
virtual void _update_shape();
|
||||||
virtual Vector<Vector3> _gen_debug_mesh_lines();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void set_radius(float p_radius);
|
void set_radius(float p_radius);
|
||||||
float get_radius() const;
|
float get_radius() const;
|
||||||
|
|
||||||
|
virtual Vector<Vector3> get_debug_mesh_lines();
|
||||||
|
|
||||||
SphereShape();
|
SphereShape();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue