mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
Merge remote-tracking branch 'remotes/origin/master' into tm_zero_elev_ui
This commit is contained in:
commit
75f36b83d5
2 changed files with 14 additions and 19 deletions
|
@ -422,9 +422,9 @@ void GLGizmoSlaSupports::update_mesh()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Unprojects the mouse position on the mesh and return the hit point and normal of the facet.
|
// Unprojects the mouse position on the mesh and saves hit point and normal of the facet into pos_and_normal
|
||||||
// The function throws if no intersection if found.
|
// Return false if no intersection was found, true otherwise.
|
||||||
std::pair<Vec3f, Vec3f> GLGizmoSlaSupports::unproject_on_mesh(const Vec2d& mouse_pos)
|
bool GLGizmoSlaSupports::unproject_on_mesh(const Vec2d& mouse_pos, std::pair<Vec3f, Vec3f>& pos_and_normal)
|
||||||
{
|
{
|
||||||
// if the gizmo doesn't have the V, F structures for igl, calculate them first:
|
// if the gizmo doesn't have the V, F structures for igl, calculate them first:
|
||||||
if (m_its == nullptr)
|
if (m_its == nullptr)
|
||||||
|
@ -457,7 +457,7 @@ std::pair<Vec3f, Vec3f> GLGizmoSlaSupports::unproject_on_mesh(const Vec2d& mouse
|
||||||
MapMatrixXfUnaligned(m_its->vertices.front().data(), m_its->vertices.size(), 3),
|
MapMatrixXfUnaligned(m_its->vertices.front().data(), m_its->vertices.size(), 3),
|
||||||
MapMatrixXiUnaligned(m_its->indices.front().data(), m_its->indices.size(), 3),
|
MapMatrixXiUnaligned(m_its->indices.front().data(), m_its->indices.size(), 3),
|
||||||
point1.cast<float>(), (point2-point1).cast<float>(), hits))
|
point1.cast<float>(), (point2-point1).cast<float>(), hits))
|
||||||
throw std::invalid_argument("unproject_on_mesh(): No intersection found.");
|
return false; // no intersection found
|
||||||
|
|
||||||
std::sort(hits.begin(), hits.end(), [](const igl::Hit& a, const igl::Hit& b) { return a.t < b.t; });
|
std::sort(hits.begin(), hits.end(), [](const igl::Hit& a, const igl::Hit& b) { return a.t < b.t; });
|
||||||
|
|
||||||
|
@ -481,14 +481,12 @@ std::pair<Vec3f, Vec3f> GLGizmoSlaSupports::unproject_on_mesh(const Vec2d& mouse
|
||||||
if (i==hits.size() || (hits.size()-i) % 2 != 0) {
|
if (i==hits.size() || (hits.size()-i) % 2 != 0) {
|
||||||
// All hits are either clipped, or there is an odd number of unclipped
|
// All hits are either clipped, or there is an odd number of unclipped
|
||||||
// hits - meaning the nearest must be from inside the mesh.
|
// hits - meaning the nearest must be from inside the mesh.
|
||||||
throw std::invalid_argument("unproject_on_mesh(): No intersection found.");
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Calculate and return both the point and the facet normal.
|
// Calculate and return both the point and the facet normal.
|
||||||
return std::make_pair(
|
pos_and_normal = std::make_pair(result, a.cross(b));
|
||||||
result,
|
return true;
|
||||||
a.cross(b)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Following function is called from GLCanvas3D to inform the gizmo about a mouse/keyboard event.
|
// Following function is called from GLCanvas3D to inform the gizmo about a mouse/keyboard event.
|
||||||
|
@ -526,17 +524,16 @@ bool GLGizmoSlaSupports::gizmo_event(SLAGizmoEventType action, const Vec2d& mous
|
||||||
|
|
||||||
// If there is some selection, don't add new point and deselect everything instead.
|
// If there is some selection, don't add new point and deselect everything instead.
|
||||||
if (m_selection_empty) {
|
if (m_selection_empty) {
|
||||||
try {
|
std::pair<Vec3f, Vec3f> pos_and_normal;
|
||||||
std::pair<Vec3f, Vec3f> pos_and_normal = unproject_on_mesh(mouse_position); // don't create anything if this throws
|
if (unproject_on_mesh(mouse_position, pos_and_normal)) { // we got an intersection
|
||||||
wxGetApp().plater()->take_snapshot(_(L("Add support point")));
|
wxGetApp().plater()->take_snapshot(_(L("Add support point")));
|
||||||
m_editing_cache.emplace_back(sla::SupportPoint(pos_and_normal.first, m_new_point_head_diameter/2.f, false), false, pos_and_normal.second);
|
m_editing_cache.emplace_back(sla::SupportPoint(pos_and_normal.first, m_new_point_head_diameter/2.f, false), false, pos_and_normal.second);
|
||||||
m_parent.set_as_dirty();
|
m_parent.set_as_dirty();
|
||||||
m_wait_for_up_event = true;
|
m_wait_for_up_event = true;
|
||||||
}
|
}
|
||||||
catch (...) { // not clicked on object
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
else
|
||||||
select_point(NoPoints);
|
select_point(NoPoints);
|
||||||
|
|
||||||
|
@ -739,10 +736,8 @@ void GLGizmoSlaSupports::on_update(const UpdateData& data)
|
||||||
else {
|
else {
|
||||||
if (m_hover_id != -1 && (! m_editing_cache[m_hover_id].support_point.is_new_island || !m_lock_unique_islands)) {
|
if (m_hover_id != -1 && (! m_editing_cache[m_hover_id].support_point.is_new_island || !m_lock_unique_islands)) {
|
||||||
std::pair<Vec3f, Vec3f> pos_and_normal;
|
std::pair<Vec3f, Vec3f> pos_and_normal;
|
||||||
try {
|
if (! unproject_on_mesh(data.mouse_pos.cast<double>(), pos_and_normal))
|
||||||
pos_and_normal = unproject_on_mesh(data.mouse_pos.cast<double>());
|
return;
|
||||||
}
|
|
||||||
catch (...) { return; }
|
|
||||||
m_editing_cache[m_hover_id].support_point.pos = pos_and_normal.first;
|
m_editing_cache[m_hover_id].support_point.pos = pos_and_normal.first;
|
||||||
m_editing_cache[m_hover_id].support_point.is_new_island = false;
|
m_editing_cache[m_hover_id].support_point.is_new_island = false;
|
||||||
m_editing_cache[m_hover_id].normal = pos_and_normal.second;
|
m_editing_cache[m_hover_id].normal = pos_and_normal.second;
|
||||||
|
|
|
@ -32,7 +32,7 @@ private:
|
||||||
int m_active_instance = -1;
|
int m_active_instance = -1;
|
||||||
float m_active_instance_bb_radius; // to cache the bb
|
float m_active_instance_bb_radius; // to cache the bb
|
||||||
mutable float m_z_shift = 0.f;
|
mutable float m_z_shift = 0.f;
|
||||||
std::pair<Vec3f, Vec3f> unproject_on_mesh(const Vec2d& mouse_pos);
|
bool unproject_on_mesh(const Vec2d& mouse_pos, std::pair<Vec3f, Vec3f>& pos_and_normal);
|
||||||
|
|
||||||
const float RenderPointScale = 1.f;
|
const float RenderPointScale = 1.f;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue