Merge pull request #48173 from madmiraal/fix-empty-csgshape-error-3.x
[3.x] Fix new `CSGMesh` errors
This commit is contained in:
commit
137f71fd75
1 changed files with 20 additions and 16 deletions
|
@ -317,27 +317,16 @@ bool CSGShapeSpatialGizmoPlugin::is_selectable_when_hidden() const {
|
|||
|
||||
void CSGShapeSpatialGizmoPlugin::redraw(EditorSpatialGizmo *p_gizmo) {
|
||||
|
||||
CSGShape *cs = Object::cast_to<CSGShape>(p_gizmo->get_spatial_node());
|
||||
|
||||
p_gizmo->clear();
|
||||
|
||||
Ref<Material> material;
|
||||
switch (cs->get_operation()) {
|
||||
case CSGShape::OPERATION_UNION:
|
||||
material = get_material("shape_union_material", p_gizmo);
|
||||
break;
|
||||
case CSGShape::OPERATION_INTERSECTION:
|
||||
material = get_material("shape_intersection_material", p_gizmo);
|
||||
break;
|
||||
case CSGShape::OPERATION_SUBTRACTION:
|
||||
material = get_material("shape_subtraction_material", p_gizmo);
|
||||
break;
|
||||
}
|
||||
|
||||
Ref<Material> handles_material = get_material("handles");
|
||||
CSGShape *cs = Object::cast_to<CSGShape>(p_gizmo->get_spatial_node());
|
||||
|
||||
PoolVector<Vector3> faces = cs->get_brush_faces();
|
||||
|
||||
if (faces.size() == 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
Vector<Vector3> lines;
|
||||
lines.resize(faces.size() * 2);
|
||||
{
|
||||
|
@ -353,6 +342,21 @@ void CSGShapeSpatialGizmoPlugin::redraw(EditorSpatialGizmo *p_gizmo) {
|
|||
}
|
||||
}
|
||||
|
||||
Ref<Material> material;
|
||||
switch (cs->get_operation()) {
|
||||
case CSGShape::OPERATION_UNION:
|
||||
material = get_material("shape_union_material", p_gizmo);
|
||||
break;
|
||||
case CSGShape::OPERATION_INTERSECTION:
|
||||
material = get_material("shape_intersection_material", p_gizmo);
|
||||
break;
|
||||
case CSGShape::OPERATION_SUBTRACTION:
|
||||
material = get_material("shape_subtraction_material", p_gizmo);
|
||||
break;
|
||||
}
|
||||
|
||||
Ref<Material> handles_material = get_material("handles");
|
||||
|
||||
p_gizmo->add_lines(lines, material);
|
||||
p_gizmo->add_collision_segments(lines);
|
||||
|
||||
|
|
Loading…
Reference in a new issue