Commit 82c39405 authored by TheNumbat's avatar TheNumbat
Browse files

fix bevel returning nullopt

parent 32c0c330
...@@ -404,39 +404,28 @@ void Model::rebuild() { ...@@ -404,39 +404,28 @@ void Model::rebuild() {
bool Model::begin_bevel(std::string& err) { bool Model::begin_bevel(std::string& err) {
auto sel = selected_element(); auto sel = selected_element();
if(sel.has_value()) { if(!sel.has_value()) return false;
if(std::holds_alternative<Halfedge_Mesh::HalfedgeRef>(*sel)) {
return false;
}
}
my_mesh->copy_to(old_mesh); my_mesh->copy_to(old_mesh);
Halfedge_Mesh::FaceRef new_face; auto new_face = std::visit(overloaded{[&](Halfedge_Mesh::VertexRef vert) {
std::visit(overloaded{[&](Halfedge_Mesh::VertexRef vert) { beveling = Bevel::vert;
auto res = my_mesh->bevel_vertex(vert); return my_mesh->bevel_vertex(vert);
if(res.has_value()) {
new_face = *res;
beveling = Bevel::vert;
}
}, },
[&](Halfedge_Mesh::EdgeRef edge) { [&](Halfedge_Mesh::EdgeRef edge) {
auto res = my_mesh->bevel_edge(edge); beveling = Bevel::edge;
if(res.has_value()) { return my_mesh->bevel_edge(edge);
new_face = *res;
beveling = Bevel::edge;
}
}, },
[&](Halfedge_Mesh::FaceRef face) { [&](Halfedge_Mesh::FaceRef face) {
auto res = my_mesh->bevel_face(face); beveling = Bevel::face;
if(res.has_value()) { return my_mesh->bevel_face(face);
new_face = *res;
beveling = Bevel::face;
}
}, },
[&](auto) {}}, [&](auto) -> std::optional<Halfedge_Mesh::FaceRef> { return std::nullopt; }},
*sel); *sel);
if(!new_face.has_value()) return false;
Halfedge_Mesh::FaceRef face = new_face.value();
err = validate(); err = validate();
if(!err.empty()) { if(!err.empty()) {
...@@ -446,15 +435,15 @@ bool Model::begin_bevel(std::string& err) { ...@@ -446,15 +435,15 @@ bool Model::begin_bevel(std::string& err) {
} else { } else {
my_mesh->render_dirty_flag = true; my_mesh->render_dirty_flag = true;
set_selected(new_face); set_selected(face);
trans_begin = {}; trans_begin = {};
auto h = new_face->halfedge(); auto h = face->halfedge();
trans_begin.center = new_face->center(); trans_begin.center = face->center();
do { do {
trans_begin.verts.push_back(h->vertex()->pos); trans_begin.verts.push_back(h->vertex()->pos);
h = h->next(); h = h->next();
} while(h != new_face->halfedge()); } while(h != face->halfedge());
return true; return true;
} }
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment