Fixes concaveshape not selecting in viewport

This PR resolves the issue of ConcaveShapes not being selectable in the Viewport.
This commit is contained in:
Emmanuel Barroga 2019-10-10 13:35:00 -07:00
parent 781e4f8673
commit 29690f6aec
21 changed files with 31 additions and 26 deletions

View file

@ -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)) {

View file

@ -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;

View file

@ -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();
}; };

View file

@ -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();

View file

@ -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();
}; };

View file

@ -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;

View file

@ -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();
}; };

View file

@ -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();

View file

@ -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();
}; };

View file

@ -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();

View file

@ -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();
}; };

View file

@ -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)) {

View file

@ -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();
}; };

View file

@ -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;

View file

@ -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

View file

@ -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());

View file

@ -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

View file

@ -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));

View file

@ -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);

View file

@ -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();

View file

@ -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();
}; };