Clipping plane is now common for Hollowing and SLA supports gizmos
This commit is contained in:
parent
f28d0ebc18
commit
79da3a95e1
6 changed files with 73 additions and 55 deletions
|
@ -374,6 +374,8 @@ bool CommonGizmosData::update_from_backend(GLCanvas3D& canvas, ModelObject* mode
|
||||||
m_object_clipper.reset();
|
m_object_clipper.reset();
|
||||||
m_supports_clipper.reset();
|
m_supports_clipper.reset();
|
||||||
m_old_mesh = m_mesh;
|
m_old_mesh = m_mesh;
|
||||||
|
m_clipping_plane_distance = 0.f;
|
||||||
|
m_clipping_plane_distance_stash = 0.f;
|
||||||
recent_update = true;
|
recent_update = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,6 +32,7 @@ static const float CONSTRAINED_COLOR[4] = { 0.5f, 0.5f, 0.5f, 1.0f };
|
||||||
class ImGuiWrapper;
|
class ImGuiWrapper;
|
||||||
class CommonGizmosData;
|
class CommonGizmosData;
|
||||||
class GLCanvas3D;
|
class GLCanvas3D;
|
||||||
|
class ClippingPlane;
|
||||||
|
|
||||||
class GLGizmoBase
|
class GLGizmoBase
|
||||||
{
|
{
|
||||||
|
@ -215,9 +216,21 @@ public:
|
||||||
int m_print_objects_count = -1;
|
int m_print_objects_count = -1;
|
||||||
int m_old_timestamp = -1;
|
int m_old_timestamp = -1;
|
||||||
|
|
||||||
|
float m_clipping_plane_distance = 0.f;
|
||||||
|
std::unique_ptr<ClippingPlane> m_clipping_plane;
|
||||||
|
|
||||||
|
void stash_clipping_plane() {
|
||||||
|
m_clipping_plane_distance_stash = m_clipping_plane_distance;
|
||||||
|
}
|
||||||
|
|
||||||
|
void unstash_clipping_plane() {
|
||||||
|
m_clipping_plane_distance = m_clipping_plane_distance_stash;
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const TriangleMesh* m_old_mesh;
|
const TriangleMesh* m_old_mesh;
|
||||||
TriangleMesh m_backend_mesh_transformed;
|
TriangleMesh m_backend_mesh_transformed;
|
||||||
|
float m_clipping_plane_distance_stash = 0.f;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace GUI
|
} // namespace GUI
|
||||||
|
|
|
@ -22,7 +22,7 @@ GLGizmoHollow::GLGizmoHollow(GLCanvas3D& parent, const std::string& icon_filenam
|
||||||
: GLGizmoBase(parent, icon_filename, sprite_id, cd)
|
: GLGizmoBase(parent, icon_filename, sprite_id, cd)
|
||||||
, m_quadric(nullptr)
|
, m_quadric(nullptr)
|
||||||
{
|
{
|
||||||
m_clipping_plane.reset(new ClippingPlane(Vec3d::Zero(), 0.));
|
m_c->m_clipping_plane.reset(new ClippingPlane(Vec3d::Zero(), 0.));
|
||||||
m_quadric = ::gluNewQuadric();
|
m_quadric = ::gluNewQuadric();
|
||||||
if (m_quadric != nullptr)
|
if (m_quadric != nullptr)
|
||||||
// using GLU_FILL does not work when the instance's transformation
|
// using GLU_FILL does not work when the instance's transformation
|
||||||
|
@ -132,7 +132,7 @@ void GLGizmoHollow::render_hollowed_mesh() const
|
||||||
|
|
||||||
void GLGizmoHollow::render_clipping_plane(const Selection& selection) const
|
void GLGizmoHollow::render_clipping_plane(const Selection& selection) const
|
||||||
{
|
{
|
||||||
if (m_clipping_plane_distance == 0.f)
|
if (m_c->m_clipping_plane_distance == 0.f)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Get transformation of the instance
|
// Get transformation of the instance
|
||||||
|
@ -154,7 +154,7 @@ void GLGizmoHollow::render_clipping_plane(const Selection& selection) const
|
||||||
m_c->m_object_clipper.reset(new MeshClipper);
|
m_c->m_object_clipper.reset(new MeshClipper);
|
||||||
m_c->m_object_clipper->set_mesh(*m_c->mesh());
|
m_c->m_object_clipper->set_mesh(*m_c->mesh());
|
||||||
}
|
}
|
||||||
m_c->m_object_clipper->set_plane(*m_clipping_plane);
|
m_c->m_object_clipper->set_plane(*m_c->m_clipping_plane);
|
||||||
m_c->m_object_clipper->set_transformation(trafo);
|
m_c->m_object_clipper->set_transformation(trafo);
|
||||||
|
|
||||||
|
|
||||||
|
@ -177,7 +177,7 @@ void GLGizmoHollow::render_clipping_plane(const Selection& selection) const
|
||||||
m_c->m_supports_clipper->set_mesh(print_object->support_mesh());
|
m_c->m_supports_clipper->set_mesh(print_object->support_mesh());
|
||||||
m_c->m_old_timestamp = timestamp;
|
m_c->m_old_timestamp = timestamp;
|
||||||
}
|
}
|
||||||
m_c->m_supports_clipper->set_plane(*m_clipping_plane);
|
m_c->m_supports_clipper->set_plane(*m_c->m_clipping_plane);
|
||||||
m_c->m_supports_clipper->set_transformation(supports_trafo);
|
m_c->m_supports_clipper->set_transformation(supports_trafo);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -314,12 +314,12 @@ void GLGizmoHollow::render_points(const Selection& selection, bool picking) cons
|
||||||
|
|
||||||
bool GLGizmoHollow::is_mesh_point_clipped(const Vec3d& point) const
|
bool GLGizmoHollow::is_mesh_point_clipped(const Vec3d& point) const
|
||||||
{
|
{
|
||||||
if (m_clipping_plane_distance == 0.f)
|
if (m_c->m_clipping_plane_distance == 0.f)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Vec3d transformed_point = m_c->m_model_object->instances[m_c->m_active_instance]->get_transformation().get_matrix() * point;
|
Vec3d transformed_point = m_c->m_model_object->instances[m_c->m_active_instance]->get_transformation().get_matrix() * point;
|
||||||
transformed_point(2) += m_z_shift;
|
transformed_point(2) += m_z_shift;
|
||||||
return m_clipping_plane->is_point_clipped(transformed_point);
|
return m_c->m_clipping_plane->is_point_clipped(transformed_point);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -343,7 +343,7 @@ bool GLGizmoHollow::unproject_on_mesh(const Vec2d& mouse_pos, std::pair<Vec3f, V
|
||||||
// The raycaster query
|
// The raycaster query
|
||||||
Vec3f hit;
|
Vec3f hit;
|
||||||
Vec3f normal;
|
Vec3f normal;
|
||||||
if (m_c->m_mesh_raycaster->unproject_on_mesh(mouse_pos, trafo.get_matrix(), camera, hit, normal, m_clipping_plane.get())) {
|
if (m_c->m_mesh_raycaster->unproject_on_mesh(mouse_pos, trafo.get_matrix(), camera, hit, normal, m_c->m_clipping_plane.get())) {
|
||||||
// Return both the point and the facet normal.
|
// Return both the point and the facet normal.
|
||||||
pos_and_normal = std::make_pair(hit, normal);
|
pos_and_normal = std::make_pair(hit, normal);
|
||||||
return true;
|
return true;
|
||||||
|
@ -429,7 +429,7 @@ bool GLGizmoHollow::gizmo_event(SLAGizmoEventType action, const Vec2d& mouse_pos
|
||||||
points_inside.push_back(points[idx].cast<float>());
|
points_inside.push_back(points[idx].cast<float>());
|
||||||
|
|
||||||
// Only select/deselect points that are actually visible
|
// Only select/deselect points that are actually visible
|
||||||
for (size_t idx : m_c->m_mesh_raycaster->get_unobscured_idxs(trafo, m_parent.get_camera(), points_inside, m_clipping_plane.get()))
|
for (size_t idx : m_c->m_mesh_raycaster->get_unobscured_idxs(trafo, m_parent.get_camera(), points_inside, m_c->m_clipping_plane.get()))
|
||||||
{
|
{
|
||||||
if (rectangle_status == GLSelectionRectangle::Deselect)
|
if (rectangle_status == GLSelectionRectangle::Deselect)
|
||||||
unselect_point(points_idxs[idx]);
|
unselect_point(points_idxs[idx]);
|
||||||
|
@ -483,13 +483,13 @@ bool GLGizmoHollow::gizmo_event(SLAGizmoEventType action, const Vec2d& mouse_pos
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action == SLAGizmoEventType::MouseWheelUp && control_down) {
|
if (action == SLAGizmoEventType::MouseWheelUp && control_down) {
|
||||||
m_clipping_plane_distance = std::min(1.f, m_clipping_plane_distance + 0.01f);
|
m_c->m_clipping_plane_distance = std::min(1.f, m_c->m_clipping_plane_distance + 0.01f);
|
||||||
update_clipping_plane(true);
|
update_clipping_plane(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action == SLAGizmoEventType::MouseWheelDown && control_down) {
|
if (action == SLAGizmoEventType::MouseWheelDown && control_down) {
|
||||||
m_clipping_plane_distance = std::max(0.f, m_clipping_plane_distance - 0.01f);
|
m_c->m_clipping_plane_distance = std::max(0.f, m_c->m_clipping_plane_distance - 0.01f);
|
||||||
update_clipping_plane(true);
|
update_clipping_plane(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -602,8 +602,8 @@ void GLGizmoHollow::update_hollowed_mesh(std::unique_ptr<TriangleMesh> &&mesh)
|
||||||
m_c->m_mesh_raycaster.reset(new MeshRaycaster(*m_c->mesh()));
|
m_c->m_mesh_raycaster.reset(new MeshRaycaster(*m_c->mesh()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_clipping_plane_distance == 0.f) {
|
if (m_c->m_clipping_plane_distance == 0.f) {
|
||||||
m_clipping_plane_distance = 0.5f;
|
m_c->m_clipping_plane_distance = 0.5f;
|
||||||
update_clipping_plane();
|
update_clipping_plane();
|
||||||
}*/
|
}*/
|
||||||
}
|
}
|
||||||
|
@ -638,10 +638,10 @@ std::vector<std::pair<const ConfigOption*, const ConfigOptionDef*>> GLGizmoHollo
|
||||||
|
|
||||||
ClippingPlane GLGizmoHollow::get_sla_clipping_plane() const
|
ClippingPlane GLGizmoHollow::get_sla_clipping_plane() const
|
||||||
{
|
{
|
||||||
if (!m_c->m_model_object || m_state == Off || m_clipping_plane_distance == 0.f)
|
if (!m_c->m_model_object || m_state == Off || m_c->m_clipping_plane_distance == 0.f)
|
||||||
return ClippingPlane::ClipsNothing();
|
return ClippingPlane::ClipsNothing();
|
||||||
else
|
else
|
||||||
return ClippingPlane(-m_clipping_plane->get_normal(), m_clipping_plane->get_data()[3]);
|
return ClippingPlane(-m_c->m_clipping_plane->get_normal(), m_c->m_clipping_plane->get_data()[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -842,7 +842,7 @@ RENDER_AGAIN:
|
||||||
// Following is rendered in both editing and non-editing mode:
|
// Following is rendered in both editing and non-editing mode:
|
||||||
// m_imgui->text("");
|
// m_imgui->text("");
|
||||||
ImGui::Separator();
|
ImGui::Separator();
|
||||||
if (m_clipping_plane_distance == 0.f)
|
if (m_c->m_clipping_plane_distance == 0.f)
|
||||||
m_imgui->text(m_desc.at("clipping_of_view"));
|
m_imgui->text(m_desc.at("clipping_of_view"));
|
||||||
else {
|
else {
|
||||||
if (m_imgui->button(m_desc.at("reset_direction"))) {
|
if (m_imgui->button(m_desc.at("reset_direction"))) {
|
||||||
|
@ -854,7 +854,7 @@ RENDER_AGAIN:
|
||||||
|
|
||||||
ImGui::SameLine(clipping_slider_left);
|
ImGui::SameLine(clipping_slider_left);
|
||||||
ImGui::PushItemWidth(window_width - clipping_slider_left);
|
ImGui::PushItemWidth(window_width - clipping_slider_left);
|
||||||
if (ImGui::SliderFloat(" ", &m_clipping_plane_distance, 0.f, 1.f, "%.2f"))
|
if (ImGui::SliderFloat(" ", &m_c->m_clipping_plane_distance, 0.f, 1.f, "%.2f"))
|
||||||
update_clipping_plane(true);
|
update_clipping_plane(true);
|
||||||
|
|
||||||
// make sure supports are shown/hidden as appropriate
|
// make sure supports are shown/hidden as appropriate
|
||||||
|
@ -934,6 +934,8 @@ void GLGizmoHollow::on_set_state()
|
||||||
if (m_state == On && m_old_state != On) { // the gizmo was just turned on
|
if (m_state == On && m_old_state != On) { // the gizmo was just turned on
|
||||||
//Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned on")));
|
//Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned on")));
|
||||||
//m_c->update_from_backend(m_parent, m_c->m_model_object);
|
//m_c->update_from_backend(m_parent, m_c->m_model_object);
|
||||||
|
m_c->unstash_clipping_plane();
|
||||||
|
update_clipping_plane(m_c->m_clipping_plane_distance != 0.f);
|
||||||
|
|
||||||
// we'll now reload support points:
|
// we'll now reload support points:
|
||||||
if (m_c->m_model_object)
|
if (m_c->m_model_object)
|
||||||
|
@ -952,8 +954,9 @@ void GLGizmoHollow::on_set_state()
|
||||||
if (m_state == Off && m_old_state != Off) { // the gizmo was just turned Off
|
if (m_state == Off && m_old_state != Off) { // the gizmo was just turned Off
|
||||||
//Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned off")));
|
//Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned off")));
|
||||||
m_parent.toggle_model_objects_visibility(true);
|
m_parent.toggle_model_objects_visibility(true);
|
||||||
m_clipping_plane_distance = 0.f;
|
m_c->stash_clipping_plane();
|
||||||
update_clipping_plane();
|
m_c->m_clipping_plane_distance = 0.f;
|
||||||
|
update_clipping_plane(true);
|
||||||
// Release clippers and the AABB raycaster.
|
// Release clippers and the AABB raycaster.
|
||||||
m_c->m_object_clipper.reset();
|
m_c->m_object_clipper.reset();
|
||||||
m_c->m_supports_clipper.reset();
|
m_c->m_supports_clipper.reset();
|
||||||
|
@ -998,8 +1001,8 @@ void GLGizmoHollow::on_stop_dragging()
|
||||||
|
|
||||||
void GLGizmoHollow::on_load(cereal::BinaryInputArchive& ar)
|
void GLGizmoHollow::on_load(cereal::BinaryInputArchive& ar)
|
||||||
{
|
{
|
||||||
ar(m_clipping_plane_distance,
|
ar(m_c->m_clipping_plane_distance,
|
||||||
*m_clipping_plane,
|
*m_c->m_clipping_plane,
|
||||||
m_c->m_model_object_id,
|
m_c->m_model_object_id,
|
||||||
m_new_hole_radius,
|
m_new_hole_radius,
|
||||||
m_new_hole_height,
|
m_new_hole_height,
|
||||||
|
@ -1012,8 +1015,8 @@ void GLGizmoHollow::on_load(cereal::BinaryInputArchive& ar)
|
||||||
|
|
||||||
void GLGizmoHollow::on_save(cereal::BinaryOutputArchive& ar) const
|
void GLGizmoHollow::on_save(cereal::BinaryOutputArchive& ar) const
|
||||||
{
|
{
|
||||||
ar(m_clipping_plane_distance,
|
ar(m_c->m_clipping_plane_distance,
|
||||||
*m_clipping_plane,
|
*m_c->m_clipping_plane,
|
||||||
m_c->m_model_object_id,
|
m_c->m_model_object_id,
|
||||||
m_new_hole_radius,
|
m_new_hole_radius,
|
||||||
m_new_hole_height,
|
m_new_hole_height,
|
||||||
|
@ -1068,12 +1071,12 @@ void GLGizmoHollow::update_clipping_plane(bool keep_normal) const
|
||||||
{
|
{
|
||||||
if (! m_c->m_model_object)
|
if (! m_c->m_model_object)
|
||||||
return;
|
return;
|
||||||
Vec3d normal = (keep_normal && m_clipping_plane->get_normal() != Vec3d::Zero() ?
|
Vec3d normal = (keep_normal && m_c->m_clipping_plane->get_normal() != Vec3d::Zero() ?
|
||||||
m_clipping_plane->get_normal() : -m_parent.get_camera().get_dir_forward());
|
m_c->m_clipping_plane->get_normal() : -m_parent.get_camera().get_dir_forward());
|
||||||
|
|
||||||
const Vec3d& center = m_c->m_model_object->instances[m_c->m_active_instance]->get_offset() + Vec3d(0., 0., m_z_shift);
|
const Vec3d& center = m_c->m_model_object->instances[m_c->m_active_instance]->get_offset() + Vec3d(0., 0., m_z_shift);
|
||||||
float dist = normal.dot(center);
|
float dist = normal.dot(center);
|
||||||
*m_clipping_plane = ClippingPlane(normal, (dist - (-m_c->m_active_instance_bb_radius) - m_clipping_plane_distance * 2*m_c->m_active_instance_bb_radius));
|
*m_c->m_clipping_plane = ClippingPlane(normal, (dist - (-m_c->m_active_instance_bb_radius) - m_c->m_clipping_plane_distance * 2*m_c->m_active_instance_bb_radius));
|
||||||
m_parent.set_as_dirty();
|
m_parent.set_as_dirty();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -70,13 +70,9 @@ private:
|
||||||
float m_closing_d_stash = 2.f;
|
float m_closing_d_stash = 2.f;
|
||||||
Vec3f m_hole_before_drag = Vec3f::Zero();
|
Vec3f m_hole_before_drag = Vec3f::Zero();
|
||||||
|
|
||||||
|
|
||||||
sla::DrainHoles m_holes_stash;
|
sla::DrainHoles m_holes_stash;
|
||||||
|
|
||||||
|
//std::unique_ptr<ClippingPlane> m_clipping_plane;
|
||||||
|
|
||||||
float m_clipping_plane_distance = 0.f;
|
|
||||||
std::unique_ptr<ClippingPlane> m_clipping_plane;
|
|
||||||
|
|
||||||
// This map holds all translated description texts, so they can be easily referenced during layout calculations
|
// This map holds all translated description texts, so they can be easily referenced during layout calculations
|
||||||
// etc. When language changes, GUI is recreated and this class constructed again, so the change takes effect.
|
// etc. When language changes, GUI is recreated and this class constructed again, so the change takes effect.
|
||||||
|
|
|
@ -27,7 +27,7 @@ GLGizmoSlaSupports::GLGizmoSlaSupports(GLCanvas3D& parent, const std::string& ic
|
||||||
, m_quadric(nullptr)
|
, m_quadric(nullptr)
|
||||||
, m_its(nullptr)
|
, m_its(nullptr)
|
||||||
{
|
{
|
||||||
m_clipping_plane.reset(new ClippingPlane(Vec3d::Zero(), 0.));
|
m_c->m_clipping_plane.reset(new ClippingPlane(Vec3d::Zero(), 0.));
|
||||||
m_quadric = ::gluNewQuadric();
|
m_quadric = ::gluNewQuadric();
|
||||||
if (m_quadric != nullptr)
|
if (m_quadric != nullptr)
|
||||||
// using GLU_FILL does not work when the instance's transformation
|
// using GLU_FILL does not work when the instance's transformation
|
||||||
|
@ -142,7 +142,7 @@ void GLGizmoSlaSupports::render_hollowed_mesh() const
|
||||||
|
|
||||||
void GLGizmoSlaSupports::render_clipping_plane(const Selection& selection) const
|
void GLGizmoSlaSupports::render_clipping_plane(const Selection& selection) const
|
||||||
{
|
{
|
||||||
if (m_clipping_plane_distance == 0.f || m_c->m_mesh->empty())
|
if (m_c->m_clipping_plane_distance == 0.f || m_c->m_mesh->empty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Get transformation of the instance
|
// Get transformation of the instance
|
||||||
|
@ -164,7 +164,7 @@ void GLGizmoSlaSupports::render_clipping_plane(const Selection& selection) const
|
||||||
m_c->m_object_clipper.reset(new MeshClipper);
|
m_c->m_object_clipper.reset(new MeshClipper);
|
||||||
m_c->m_object_clipper->set_mesh(*m_c->mesh());
|
m_c->m_object_clipper->set_mesh(*m_c->mesh());
|
||||||
}
|
}
|
||||||
m_c->m_object_clipper->set_plane(*m_clipping_plane);
|
m_c->m_object_clipper->set_plane(*m_c->m_clipping_plane);
|
||||||
m_c->m_object_clipper->set_transformation(trafo);
|
m_c->m_object_clipper->set_transformation(trafo);
|
||||||
|
|
||||||
|
|
||||||
|
@ -195,7 +195,7 @@ void GLGizmoSlaSupports::render_clipping_plane(const Selection& selection) const
|
||||||
m_c->m_supports_clipper->set_mesh(print_object->support_mesh());
|
m_c->m_supports_clipper->set_mesh(print_object->support_mesh());
|
||||||
m_c->m_old_timestamp = timestamp;
|
m_c->m_old_timestamp = timestamp;
|
||||||
}
|
}
|
||||||
m_c->m_supports_clipper->set_plane(*m_clipping_plane);
|
m_c->m_supports_clipper->set_plane(*m_c->m_clipping_plane);
|
||||||
m_c->m_supports_clipper->set_transformation(supports_trafo);
|
m_c->m_supports_clipper->set_transformation(supports_trafo);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -382,12 +382,12 @@ void GLGizmoSlaSupports::render_points(const Selection& selection, bool picking)
|
||||||
|
|
||||||
bool GLGizmoSlaSupports::is_mesh_point_clipped(const Vec3d& point) const
|
bool GLGizmoSlaSupports::is_mesh_point_clipped(const Vec3d& point) const
|
||||||
{
|
{
|
||||||
if (m_clipping_plane_distance == 0.f)
|
if (m_c->m_clipping_plane_distance == 0.f)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Vec3d transformed_point = m_c->m_model_object->instances[m_c->m_active_instance]->get_transformation().get_matrix() * point;
|
Vec3d transformed_point = m_c->m_model_object->instances[m_c->m_active_instance]->get_transformation().get_matrix() * point;
|
||||||
transformed_point(2) += m_z_shift;
|
transformed_point(2) += m_z_shift;
|
||||||
return m_clipping_plane->is_point_clipped(transformed_point);
|
return m_c->m_clipping_plane->is_point_clipped(transformed_point);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -408,7 +408,7 @@ bool GLGizmoSlaSupports::unproject_on_mesh(const Vec2d& mouse_pos, std::pair<Vec
|
||||||
// The raycaster query
|
// The raycaster query
|
||||||
Vec3f hit;
|
Vec3f hit;
|
||||||
Vec3f normal;
|
Vec3f normal;
|
||||||
if (m_c->m_mesh_raycaster->unproject_on_mesh(mouse_pos, trafo.get_matrix(), camera, hit, normal, m_clipping_plane.get())) {
|
if (m_c->m_mesh_raycaster->unproject_on_mesh(mouse_pos, trafo.get_matrix(), camera, hit, normal, m_c->m_clipping_plane.get())) {
|
||||||
// Check whether the hit is in a hole
|
// Check whether the hit is in a hole
|
||||||
bool in_hole = false;
|
bool in_hole = false;
|
||||||
// In case the hollowed and drilled mesh is available, we can allow
|
// In case the hollowed and drilled mesh is available, we can allow
|
||||||
|
@ -502,7 +502,7 @@ bool GLGizmoSlaSupports::gizmo_event(SLAGizmoEventType action, const Vec2d& mous
|
||||||
points_inside.push_back(points[idx].cast<float>());
|
points_inside.push_back(points[idx].cast<float>());
|
||||||
|
|
||||||
// Only select/deselect points that are actually visible
|
// Only select/deselect points that are actually visible
|
||||||
for (size_t idx : m_c->m_mesh_raycaster->get_unobscured_idxs(trafo, m_parent.get_camera(), points_inside, m_clipping_plane.get()))
|
for (size_t idx : m_c->m_mesh_raycaster->get_unobscured_idxs(trafo, m_parent.get_camera(), points_inside, m_c->m_clipping_plane.get()))
|
||||||
{
|
{
|
||||||
if (rectangle_status == GLSelectionRectangle::Deselect)
|
if (rectangle_status == GLSelectionRectangle::Deselect)
|
||||||
unselect_point(points_idxs[idx]);
|
unselect_point(points_idxs[idx]);
|
||||||
|
@ -579,13 +579,13 @@ bool GLGizmoSlaSupports::gizmo_event(SLAGizmoEventType action, const Vec2d& mous
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action == SLAGizmoEventType::MouseWheelUp && control_down) {
|
if (action == SLAGizmoEventType::MouseWheelUp && control_down) {
|
||||||
m_clipping_plane_distance = std::min(1.f, m_clipping_plane_distance + 0.01f);
|
m_c->m_clipping_plane_distance = std::min(1.f, m_c->m_clipping_plane_distance + 0.01f);
|
||||||
update_clipping_plane(true);
|
update_clipping_plane(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action == SLAGizmoEventType::MouseWheelDown && control_down) {
|
if (action == SLAGizmoEventType::MouseWheelDown && control_down) {
|
||||||
m_clipping_plane_distance = std::max(0.f, m_clipping_plane_distance - 0.01f);
|
m_c->m_clipping_plane_distance = std::max(0.f, m_c->m_clipping_plane_distance - 0.01f);
|
||||||
update_clipping_plane(true);
|
update_clipping_plane(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -666,10 +666,10 @@ std::vector<const ConfigOption*> GLGizmoSlaSupports::get_config_options(const st
|
||||||
|
|
||||||
ClippingPlane GLGizmoSlaSupports::get_sla_clipping_plane() const
|
ClippingPlane GLGizmoSlaSupports::get_sla_clipping_plane() const
|
||||||
{
|
{
|
||||||
if (!m_c->m_model_object || m_state == Off || m_clipping_plane_distance == 0.f)
|
if (!m_c->m_model_object || m_state == Off || m_c->m_clipping_plane_distance == 0.f)
|
||||||
return ClippingPlane::ClipsNothing();
|
return ClippingPlane::ClipsNothing();
|
||||||
else
|
else
|
||||||
return ClippingPlane(-m_clipping_plane->get_normal(), m_clipping_plane->get_data()[3]);
|
return ClippingPlane(-m_c->m_clipping_plane->get_normal(), m_c->m_clipping_plane->get_data()[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -891,7 +891,7 @@ RENDER_AGAIN:
|
||||||
|
|
||||||
// Following is rendered in both editing and non-editing mode:
|
// Following is rendered in both editing and non-editing mode:
|
||||||
ImGui::Separator();
|
ImGui::Separator();
|
||||||
if (m_clipping_plane_distance == 0.f)
|
if (m_c->m_clipping_plane_distance == 0.f)
|
||||||
{
|
{
|
||||||
ImGui::AlignTextToFramePadding();
|
ImGui::AlignTextToFramePadding();
|
||||||
m_imgui->text(m_desc.at("clipping_of_view"));
|
m_imgui->text(m_desc.at("clipping_of_view"));
|
||||||
|
@ -906,7 +906,7 @@ RENDER_AGAIN:
|
||||||
|
|
||||||
ImGui::SameLine(clipping_slider_left);
|
ImGui::SameLine(clipping_slider_left);
|
||||||
ImGui::PushItemWidth(window_width - clipping_slider_left);
|
ImGui::PushItemWidth(window_width - clipping_slider_left);
|
||||||
if (ImGui::SliderFloat(" ", &m_clipping_plane_distance, 0.f, 1.f, "%.2f"))
|
if (ImGui::SliderFloat(" ", &m_c->m_clipping_plane_distance, 0.f, 1.f, "%.2f"))
|
||||||
update_clipping_plane(true);
|
update_clipping_plane(true);
|
||||||
|
|
||||||
|
|
||||||
|
@ -991,6 +991,10 @@ void GLGizmoSlaSupports::on_set_state()
|
||||||
if (m_state == On && m_old_state != On) { // the gizmo was just turned on
|
if (m_state == On && m_old_state != On) { // the gizmo was just turned on
|
||||||
Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned on")));
|
Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned on")));
|
||||||
|
|
||||||
|
m_c->unstash_clipping_plane();
|
||||||
|
update_clipping_plane(m_c->m_clipping_plane_distance != 0.f);
|
||||||
|
|
||||||
|
|
||||||
// we'll now reload support points:
|
// we'll now reload support points:
|
||||||
if (m_c->m_model_object)
|
if (m_c->m_model_object)
|
||||||
reload_cache();
|
reload_cache();
|
||||||
|
@ -1026,8 +1030,9 @@ void GLGizmoSlaSupports::on_set_state()
|
||||||
Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned off")));
|
Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned off")));
|
||||||
m_parent.toggle_model_objects_visibility(true);
|
m_parent.toggle_model_objects_visibility(true);
|
||||||
m_normal_cache.clear();
|
m_normal_cache.clear();
|
||||||
m_clipping_plane_distance = 0.f;
|
m_c->stash_clipping_plane();
|
||||||
update_clipping_plane();
|
m_c->m_clipping_plane_distance = 0.f;
|
||||||
|
update_clipping_plane(true);
|
||||||
// Release clippers and the AABB raycaster.
|
// Release clippers and the AABB raycaster.
|
||||||
m_its = nullptr;
|
m_its = nullptr;
|
||||||
m_c->m_object_clipper.reset();
|
m_c->m_object_clipper.reset();
|
||||||
|
@ -1072,8 +1077,8 @@ void GLGizmoSlaSupports::on_stop_dragging()
|
||||||
|
|
||||||
void GLGizmoSlaSupports::on_load(cereal::BinaryInputArchive& ar)
|
void GLGizmoSlaSupports::on_load(cereal::BinaryInputArchive& ar)
|
||||||
{
|
{
|
||||||
ar(m_clipping_plane_distance,
|
ar(m_c->m_clipping_plane_distance,
|
||||||
*m_clipping_plane,
|
*m_c->m_clipping_plane,
|
||||||
m_c->m_model_object_id,
|
m_c->m_model_object_id,
|
||||||
m_new_point_head_diameter,
|
m_new_point_head_diameter,
|
||||||
m_normal_cache,
|
m_normal_cache,
|
||||||
|
@ -1086,8 +1091,8 @@ void GLGizmoSlaSupports::on_load(cereal::BinaryInputArchive& ar)
|
||||||
|
|
||||||
void GLGizmoSlaSupports::on_save(cereal::BinaryOutputArchive& ar) const
|
void GLGizmoSlaSupports::on_save(cereal::BinaryOutputArchive& ar) const
|
||||||
{
|
{
|
||||||
ar(m_clipping_plane_distance,
|
ar(m_c->m_clipping_plane_distance,
|
||||||
*m_clipping_plane,
|
*m_c->m_clipping_plane,
|
||||||
m_c->m_model_object_id,
|
m_c->m_model_object_id,
|
||||||
m_new_point_head_diameter,
|
m_new_point_head_diameter,
|
||||||
m_normal_cache,
|
m_normal_cache,
|
||||||
|
@ -1286,12 +1291,12 @@ bool GLGizmoSlaSupports::unsaved_changes() const
|
||||||
|
|
||||||
void GLGizmoSlaSupports::update_clipping_plane(bool keep_normal) const
|
void GLGizmoSlaSupports::update_clipping_plane(bool keep_normal) const
|
||||||
{
|
{
|
||||||
Vec3d normal = (keep_normal && m_clipping_plane->get_normal() != Vec3d::Zero() ?
|
Vec3d normal = (keep_normal && m_c->m_clipping_plane->get_normal() != Vec3d::Zero() ?
|
||||||
m_clipping_plane->get_normal() : -m_parent.get_camera().get_dir_forward());
|
m_c->m_clipping_plane->get_normal() : -m_parent.get_camera().get_dir_forward());
|
||||||
|
|
||||||
const Vec3d& center = m_c->m_model_object->instances[m_c->m_active_instance]->get_offset() + Vec3d(0., 0., m_z_shift);
|
const Vec3d& center = m_c->m_model_object->instances[m_c->m_active_instance]->get_offset() + Vec3d(0., 0., m_z_shift);
|
||||||
float dist = normal.dot(center);
|
float dist = normal.dot(center);
|
||||||
*m_clipping_plane = ClippingPlane(normal, (dist - (-m_c->m_active_instance_bb_radius) - m_clipping_plane_distance * 2*m_c->m_active_instance_bb_radius));
|
*m_c->m_clipping_plane = ClippingPlane(normal, (dist - (-m_c->m_active_instance_bb_radius) - m_c->m_clipping_plane_distance * 2*m_c->m_active_instance_bb_radius));
|
||||||
m_parent.set_as_dirty();
|
m_parent.set_as_dirty();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -103,8 +103,7 @@ private:
|
||||||
mutable std::vector<CacheEntry> m_editing_cache; // a support point and whether it is currently selected
|
mutable std::vector<CacheEntry> m_editing_cache; // a support point and whether it is currently selected
|
||||||
std::vector<sla::SupportPoint> m_normal_cache; // to restore after discarding changes or undo/redo
|
std::vector<sla::SupportPoint> m_normal_cache; // to restore after discarding changes or undo/redo
|
||||||
|
|
||||||
float m_clipping_plane_distance = 0.f;
|
//std::unique_ptr<ClippingPlane> m_clipping_plane;
|
||||||
std::unique_ptr<ClippingPlane> m_clipping_plane;
|
|
||||||
|
|
||||||
// This map holds all translated description texts, so they can be easily referenced during layout calculations
|
// This map holds all translated description texts, so they can be easily referenced during layout calculations
|
||||||
// etc. When language changes, GUI is recreated and this class constructed again, so the change takes effect.
|
// etc. When language changes, GUI is recreated and this class constructed again, so the change takes effect.
|
||||||
|
|
Loading…
Reference in a new issue