From a080e83e882064e9b2f2e283f8ed8c79eb98ba7b Mon Sep 17 00:00:00 2001 From: Filip Sykala - NTB T15p Date: Tue, 20 Dec 2022 14:27:23 +0100 Subject: [PATCH] Put origin on surface when change style --- src/slic3r/GUI/Gizmos/GLGizmoEmboss.cpp | 32 ++++++++++++++++--------- 1 file changed, 21 insertions(+), 11 deletions(-) diff --git a/src/slic3r/GUI/Gizmos/GLGizmoEmboss.cpp b/src/slic3r/GUI/Gizmos/GLGizmoEmboss.cpp index a296650296..4e4ab5035d 100644 --- a/src/slic3r/GUI/Gizmos/GLGizmoEmboss.cpp +++ b/src/slic3r/GUI/Gizmos/GLGizmoEmboss.cpp @@ -2231,6 +2231,18 @@ void GLGizmoEmboss::draw_delete_style_button() { } } +namespace priv { +/// +/// Transform origin of Text volume onto surface of model. +/// +/// Text +/// AABB trees of object +/// Transformation of actual instance +/// True when transform otherwise false +bool transform_on_surface(ModelVolume &volume, RaycastManager &raycast_manager, const Selection &selection); +} // namespace priv + + void GLGizmoEmboss::fix_transformation(const FontProp &from, const FontProp &to) { @@ -2252,6 +2264,10 @@ void GLGizmoEmboss::fix_transformation(const FontProp &from, float t_move = t_move_opt.has_value() ? *t_move_opt : .0f; do_translate(Vec3d::UnitZ() * (t_move - f_move)); } + + // when start using surface than move volume origin onto surface + if (!from.use_surface && to.use_surface) + priv::transform_on_surface(*m_volume, m_raycast_manager, m_parent.get_selection()); } void GLGizmoEmboss::draw_style_list() { @@ -2354,8 +2370,11 @@ void GLGizmoEmboss::draw_style_list() { // selected style from combo box if (selected_style_index.has_value()) { const EmbossStyle &style = m_style_manager.get_styles()[*selected_style_index].style; - fix_transformation(actual_style.prop, style.prop); + // create copy to be able do fix transformation only when successfully load style + FontProp act_prop = actual_style.prop; // copy + FontProp new_prop = style.prop; // copy if (m_style_manager.load_style(*selected_style_index)) { + fix_transformation(act_prop, new_prop); process(); } else { wxString title = _L("Not valid style."); @@ -2867,16 +2886,8 @@ void GLGizmoEmboss::do_rotate(float relative_z_angle) // snapshot_name = L("Set text rotation"); m_parent.do_rotate(snapshot_name); } -namespace priv { -/// -/// Transform origin of Text volume onto surface of model. -/// -/// Text -/// AABB trees of object -/// Transformation of actual instance -/// True when transform otherwise false -bool transform_on_surface(ModelVolume &volume, RaycastManager &raycast_manager, const Selection &selection) +bool priv::transform_on_surface(ModelVolume &volume, RaycastManager &raycast_manager, const Selection &selection) { // Move object on surface auto cond = RaycastManager::SkipVolume({volume.id().id}); @@ -2911,7 +2922,6 @@ bool transform_on_surface(ModelVolume &volume, RaycastManager &raycast_manager, volume.set_transformation(volume.get_matrix() * Eigen::Translation(offset_volume)); return true; } -} // namespace priv void GLGizmoEmboss::draw_advanced() {