mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 04:41:06 +08:00 
			
		
		
		
	New selection -> Gizmos methods refactored to accept selection instead of bounding box and scale gizmo in local system for single instance selections
This commit is contained in:
		
							parent
							
								
									35c7c418e9
								
							
						
					
					
						commit
						f2486bd87d
					
				| @ -2106,12 +2106,21 @@ bool GLCanvas3D::Gizmos::is_dragging() const | |||||||
|     return (curr != nullptr) ? curr->is_dragging() : false; |     return (curr != nullptr) ? curr->is_dragging() : false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLCanvas3D::Gizmos::start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | { | ||||||
|  |     GLGizmoBase* curr = _get_current(); | ||||||
|  |     if (curr != nullptr) | ||||||
|  |         curr->start_dragging(selection); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLCanvas3D::Gizmos::start_dragging(const BoundingBoxf3& box) | void GLCanvas3D::Gizmos::start_dragging(const BoundingBoxf3& box) | ||||||
| { | { | ||||||
|     GLGizmoBase* curr = _get_current(); |     GLGizmoBase* curr = _get_current(); | ||||||
|     if (curr != nullptr) |     if (curr != nullptr) | ||||||
|         curr->start_dragging(box); |         curr->start_dragging(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| void GLCanvas3D::Gizmos::stop_dragging() | void GLCanvas3D::Gizmos::stop_dragging() | ||||||
| { | { | ||||||
| @ -2256,17 +2265,36 @@ void GLCanvas3D::Gizmos::set_flattening_data(const ModelObject* model_object) | |||||||
|         reinterpret_cast<GLGizmoFlatten*>(it->second)->set_flattening_data(model_object); |         reinterpret_cast<GLGizmoFlatten*>(it->second)->set_flattening_data(model_object); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLCanvas3D::Gizmos::render_current_gizmo(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLCanvas3D::Gizmos::render_current_gizmo(const BoundingBoxf3& box) const | void GLCanvas3D::Gizmos::render_current_gizmo(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     if (!m_enabled) |     if (!m_enabled) | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|     ::glDisable(GL_DEPTH_TEST); |     ::glDisable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     _render_current_gizmo(selection); | ||||||
|  | #else | ||||||
|     if (box.radius() > 0.0) |     if (box.radius() > 0.0) | ||||||
|         _render_current_gizmo(box); |         _render_current_gizmo(box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLCanvas3D::Gizmos::render_current_gizmo_for_picking_pass(const GLCanvas3D::Selection& selection) const | ||||||
|  | { | ||||||
|  |     if (!m_enabled) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     GLGizmoBase* curr = _get_current(); | ||||||
|  |     if (curr != nullptr) | ||||||
|  |         curr->render_for_picking(selection); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLCanvas3D::Gizmos::render_current_gizmo_for_picking_pass(const BoundingBoxf3& box) const | void GLCanvas3D::Gizmos::render_current_gizmo_for_picking_pass(const BoundingBoxf3& box) const | ||||||
| { | { | ||||||
|     if (!m_enabled) |     if (!m_enabled) | ||||||
| @ -2276,6 +2304,7 @@ void GLCanvas3D::Gizmos::render_current_gizmo_for_picking_pass(const BoundingBox | |||||||
|     if (curr != nullptr) |     if (curr != nullptr) | ||||||
|         curr->render_for_picking(box); |         curr->render_for_picking(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| void GLCanvas3D::Gizmos::render_overlay(const GLCanvas3D& canvas) const | void GLCanvas3D::Gizmos::render_overlay(const GLCanvas3D& canvas) const | ||||||
| { | { | ||||||
| @ -2324,12 +2353,21 @@ void GLCanvas3D::Gizmos::_render_overlay(const GLCanvas3D& canvas) const | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLCanvas3D::Gizmos::_render_current_gizmo(const GLCanvas3D::Selection& selection) const | ||||||
|  | { | ||||||
|  |     GLGizmoBase* curr = _get_current(); | ||||||
|  |     if (curr != nullptr) | ||||||
|  |         curr->render(selection); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLCanvas3D::Gizmos::_render_current_gizmo(const BoundingBoxf3& box) const | void GLCanvas3D::Gizmos::_render_current_gizmo(const BoundingBoxf3& box) const | ||||||
| { | { | ||||||
|     GLGizmoBase* curr = _get_current(); |     GLGizmoBase* curr = _get_current(); | ||||||
|     if (curr != nullptr) |     if (curr != nullptr) | ||||||
|         curr->render(box); |         curr->render(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| float GLCanvas3D::Gizmos::_get_total_overlay_height() const | float GLCanvas3D::Gizmos::_get_total_overlay_height() const | ||||||
| { | { | ||||||
| @ -3922,7 +3960,7 @@ void GLCanvas3D::on_mouse(wxMouseEvent& evt) | |||||||
|             update_gizmos_data(); |             update_gizmos_data(); | ||||||
| #if ENABLE_EXTENDED_SELECTION | #if ENABLE_EXTENDED_SELECTION | ||||||
|             m_selection.start_dragging(); |             m_selection.start_dragging(); | ||||||
|             m_gizmos.start_dragging(m_selection.get_bounding_box()); |             m_gizmos.start_dragging(m_selection); | ||||||
| #else | #else | ||||||
|             m_gizmos.start_dragging(_selected_volumes_bounding_box()); |             m_gizmos.start_dragging(_selected_volumes_bounding_box()); | ||||||
|             m_mouse.drag.gizmo_volume_idx = _get_first_selected_volume_id(selected_object_idx); |             m_mouse.drag.gizmo_volume_idx = _get_first_selected_volume_id(selected_object_idx); | ||||||
| @ -4932,7 +4970,7 @@ void GLCanvas3D::_picking_pass() const | |||||||
| 
 | 
 | ||||||
|         _render_volumes(true); |         _render_volumes(true); | ||||||
| #if ENABLE_EXTENDED_SELECTION | #if ENABLE_EXTENDED_SELECTION | ||||||
|         m_gizmos.render_current_gizmo_for_picking_pass(m_selection.get_bounding_box()); |         m_gizmos.render_current_gizmo_for_picking_pass(m_selection); | ||||||
| #else | #else | ||||||
|         m_gizmos.render_current_gizmo_for_picking_pass(_selected_volumes_bounding_box()); |         m_gizmos.render_current_gizmo_for_picking_pass(_selected_volumes_bounding_box()); | ||||||
| #endif // ENABLE_EXTENDED_SELECTION
 | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| @ -5207,7 +5245,7 @@ void GLCanvas3D::_render_volumes(bool fake_colors) const | |||||||
| void GLCanvas3D::_render_current_gizmo() const | void GLCanvas3D::_render_current_gizmo() const | ||||||
| { | { | ||||||
| #if ENABLE_EXTENDED_SELECTION | #if ENABLE_EXTENDED_SELECTION | ||||||
|     m_gizmos.render_current_gizmo(m_selection.get_bounding_box()); |     m_gizmos.render_current_gizmo(m_selection); | ||||||
| #else | #else | ||||||
|     m_gizmos.render_current_gizmo(_selected_volumes_bounding_box()); |     m_gizmos.render_current_gizmo(_selected_volumes_bounding_box()); | ||||||
| #endif // ENABLE_EXTENDED_SELECTION
 | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|  | |||||||
| @ -573,7 +573,11 @@ private: | |||||||
|         bool is_running() const; |         bool is_running() const; | ||||||
| 
 | 
 | ||||||
|         bool is_dragging() const; |         bool is_dragging() const; | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |         void start_dragging(const Selection& selection); | ||||||
|  | #else | ||||||
|         void start_dragging(const BoundingBoxf3& box); |         void start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|         void stop_dragging(); |         void stop_dragging(); | ||||||
| 
 | 
 | ||||||
| #if ENABLE_EXTENDED_SELECTION | #if ENABLE_EXTENDED_SELECTION | ||||||
| @ -603,16 +607,25 @@ private: | |||||||
| 
 | 
 | ||||||
|         void set_flattening_data(const ModelObject* model_object); |         void set_flattening_data(const ModelObject* model_object); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |         void render_current_gizmo(const Selection& selection) const; | ||||||
|  |         void render_current_gizmo_for_picking_pass(const Selection& selection) const; | ||||||
|  | #else | ||||||
|         void render_current_gizmo(const BoundingBoxf3& box) const; |         void render_current_gizmo(const BoundingBoxf3& box) const; | ||||||
| 
 |  | ||||||
|         void render_current_gizmo_for_picking_pass(const BoundingBoxf3& box) const; |         void render_current_gizmo_for_picking_pass(const BoundingBoxf3& box) const; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|  | 
 | ||||||
|         void render_overlay(const GLCanvas3D& canvas) const; |         void render_overlay(const GLCanvas3D& canvas) const; | ||||||
| 
 | 
 | ||||||
|     private: |     private: | ||||||
|         void _reset(); |         void _reset(); | ||||||
| 
 | 
 | ||||||
|         void _render_overlay(const GLCanvas3D& canvas) const; |         void _render_overlay(const GLCanvas3D& canvas) const; | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |         void _render_current_gizmo(const Selection& selection) const; | ||||||
|  | #else | ||||||
|         void _render_current_gizmo(const BoundingBoxf3& box) const; |         void _render_current_gizmo(const BoundingBoxf3& box) const; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
|         float _get_total_overlay_height() const; |         float _get_total_overlay_height() const; | ||||||
|         GLGizmoBase* _get_current() const; |         GLGizmoBase* _get_current() const; | ||||||
|  | |||||||
| @ -1,7 +1,10 @@ | |||||||
|  | #include "../../libslic3r/libslic3r.h" | ||||||
| #include "GLGizmo.hpp" | #include "GLGizmo.hpp" | ||||||
| 
 | 
 | ||||||
| #include "../../libslic3r/Utils.hpp" | #include "../../libslic3r/Utils.hpp" | ||||||
|  | #if !ENABLE_EXTENDED_SELECTION | ||||||
| #include "../../slic3r/GUI/GLCanvas3D.hpp" | #include "../../slic3r/GUI/GLCanvas3D.hpp" | ||||||
|  | #endif // !ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| #include <Eigen/Dense> | #include <Eigen/Dense> | ||||||
| #include "../../libslic3r/Geometry.hpp" | #include "../../libslic3r/Geometry.hpp" | ||||||
| @ -146,10 +149,9 @@ void GLGizmoBase::Grabber::render(float size, const float* render_color, bool us | |||||||
|     ::glPushMatrix(); |     ::glPushMatrix(); | ||||||
|     ::glTranslated(center(0), center(1), center(2)); |     ::glTranslated(center(0), center(1), center(2)); | ||||||
| 
 | 
 | ||||||
|     double rad_to_deg = 180.0 / (double)PI; |     ::glRotated(Geometry::rad2deg(angles(2)), 0.0, 0.0, 1.0); | ||||||
|     ::glRotated(angles(0) * rad_to_deg, 1.0, 0.0, 0.0); |     ::glRotated(Geometry::rad2deg(angles(1)), 0.0, 1.0, 0.0); | ||||||
|     ::glRotated(angles(1) * rad_to_deg, 0.0, 1.0, 0.0); |     ::glRotated(Geometry::rad2deg(angles(0)), 1.0, 0.0, 0.0); | ||||||
|     ::glRotated(angles(2) * rad_to_deg, 0.0, 0.0, 1.0); |  | ||||||
| 
 | 
 | ||||||
|     // face min x
 |     // face min x
 | ||||||
|     ::glPushMatrix(); |     ::glPushMatrix(); | ||||||
| @ -257,7 +259,11 @@ void GLGizmoBase::disable_grabber(unsigned int id) | |||||||
|     on_disable_grabber(id); |     on_disable_grabber(id); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoBase::start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | #else | ||||||
| void GLGizmoBase::start_dragging(const BoundingBoxf3& box) | void GLGizmoBase::start_dragging(const BoundingBoxf3& box) | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     m_dragging = true; |     m_dragging = true; | ||||||
| 
 | 
 | ||||||
| @ -266,7 +272,11 @@ void GLGizmoBase::start_dragging(const BoundingBoxf3& box) | |||||||
|         m_grabbers[i].dragging = (m_hover_id == i); |         m_grabbers[i].dragging = (m_hover_id == i); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     on_start_dragging(selection); | ||||||
|  | #else | ||||||
|     on_start_dragging(box); |     on_start_dragging(box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GLGizmoBase::stop_dragging() | void GLGizmoBase::stop_dragging() | ||||||
| @ -373,8 +383,15 @@ bool GLGizmoRotate::on_init() | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoRotate::on_start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | #else | ||||||
| void GLGizmoRotate::on_start_dragging(const BoundingBoxf3& box) | void GLGizmoRotate::on_start_dragging(const BoundingBoxf3& box) | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     const BoundingBoxf3& box = selection.get_bounding_box(); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     m_center = box.center(); |     m_center = box.center(); | ||||||
|     m_radius = Offset + box.radius(); |     m_radius = Offset + box.radius(); | ||||||
|     m_snap_coarse_in_radius = m_radius / 3.0f; |     m_snap_coarse_in_radius = m_radius / 3.0f; | ||||||
| @ -418,11 +435,19 @@ void GLGizmoRotate::on_update(const Linef3& mouse_ray) | |||||||
|     m_angle = theta; |     m_angle = theta; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoRotate::on_render(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLGizmoRotate::on_render(const BoundingBoxf3& box) const | void GLGizmoRotate::on_render(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     if (!m_grabbers[0].enabled) |     if (!m_grabbers[0].enabled) | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     const BoundingBoxf3& box = selection.get_bounding_box(); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|  | 
 | ||||||
|     if (m_dragging) |     if (m_dragging) | ||||||
|         set_tooltip(format(m_angle * 180.0f / (float)PI, 4)); |         set_tooltip(format(m_angle * 180.0f / (float)PI, 4)); | ||||||
|     else |     else | ||||||
| @ -462,14 +487,22 @@ void GLGizmoRotate::on_render(const BoundingBoxf3& box) const | |||||||
|     ::glPopMatrix(); |     ::glPopMatrix(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoRotate::on_render_for_picking(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLGizmoRotate::on_render_for_picking(const BoundingBoxf3& box) const | void GLGizmoRotate::on_render_for_picking(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     ::glDisable(GL_DEPTH_TEST); |     ::glDisable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|     ::glPushMatrix(); |     ::glPushMatrix(); | ||||||
| 
 | 
 | ||||||
|     transform_to_local(); |     transform_to_local(); | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     render_grabbers_for_picking(selection.get_bounding_box()); | ||||||
|  | #else | ||||||
|     render_grabbers_for_picking(box); |     render_grabbers_for_picking(box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
|     ::glPopMatrix(); |     ::glPopMatrix(); | ||||||
| } | } | ||||||
| @ -681,11 +714,19 @@ bool GLGizmoRotate3D::on_init() | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoRotate3D::on_start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | { | ||||||
|  |     if ((0 <= m_hover_id) && (m_hover_id < 3)) | ||||||
|  |         m_gizmos[m_hover_id].start_dragging(selection); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLGizmoRotate3D::on_start_dragging(const BoundingBoxf3& box) | void GLGizmoRotate3D::on_start_dragging(const BoundingBoxf3& box) | ||||||
| { | { | ||||||
|     if ((0 <= m_hover_id) && (m_hover_id < 3)) |     if ((0 <= m_hover_id) && (m_hover_id < 3)) | ||||||
|         m_gizmos[m_hover_id].start_dragging(box); |         m_gizmos[m_hover_id].start_dragging(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| void GLGizmoRotate3D::on_stop_dragging() | void GLGizmoRotate3D::on_stop_dragging() | ||||||
| { | { | ||||||
| @ -693,6 +734,19 @@ void GLGizmoRotate3D::on_stop_dragging() | |||||||
|         m_gizmos[m_hover_id].stop_dragging(); |         m_gizmos[m_hover_id].stop_dragging(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoRotate3D::on_render(const GLCanvas3D::Selection& selection) const | ||||||
|  | { | ||||||
|  |     if ((m_hover_id == -1) || (m_hover_id == 0)) | ||||||
|  |         m_gizmos[X].render(selection); | ||||||
|  | 
 | ||||||
|  |     if ((m_hover_id == -1) || (m_hover_id == 1)) | ||||||
|  |         m_gizmos[Y].render(selection); | ||||||
|  | 
 | ||||||
|  |     if ((m_hover_id == -1) || (m_hover_id == 2)) | ||||||
|  |         m_gizmos[Z].render(selection); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLGizmoRotate3D::on_render(const BoundingBoxf3& box) const | void GLGizmoRotate3D::on_render(const BoundingBoxf3& box) const | ||||||
| { | { | ||||||
|     if ((m_hover_id == -1) || (m_hover_id == 0)) |     if ((m_hover_id == -1) || (m_hover_id == 0)) | ||||||
| @ -704,6 +758,7 @@ void GLGizmoRotate3D::on_render(const BoundingBoxf3& box) const | |||||||
|     if ((m_hover_id == -1) || (m_hover_id == 2)) |     if ((m_hover_id == -1) || (m_hover_id == 2)) | ||||||
|         m_gizmos[Z].render(box); |         m_gizmos[Z].render(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| const float GLGizmoScale3D::Offset = 5.0f; | const float GLGizmoScale3D::Offset = 5.0f; | ||||||
| const Vec3d GLGizmoScale3D::OffsetVec = (double)GLGizmoScale3D::Offset * Vec3d::Ones(); | const Vec3d GLGizmoScale3D::OffsetVec = (double)GLGizmoScale3D::Offset * Vec3d::Ones(); | ||||||
| @ -749,11 +804,18 @@ bool GLGizmoScale3D::on_init() | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoScale3D::on_start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | #else | ||||||
| void GLGizmoScale3D::on_start_dragging(const BoundingBoxf3& box) | void GLGizmoScale3D::on_start_dragging(const BoundingBoxf3& box) | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     if (m_hover_id != -1) |     if (m_hover_id != -1) | ||||||
|     { |     { | ||||||
|         m_starting_drag_position = m_grabbers[m_hover_id].center; |         m_starting_drag_position = m_grabbers[m_hover_id].center; | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |         const BoundingBoxf3& box = selection.get_bounding_box(); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|         m_starting_box = BoundingBoxf3(box.min - OffsetVec, box.max + OffsetVec); |         m_starting_box = BoundingBoxf3(box.min - OffsetVec, box.max + OffsetVec); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -778,7 +840,11 @@ void GLGizmoScale3D::on_process_double_click() | |||||||
| } | } | ||||||
| #endif // ENABLE_GIZMOS_RESET
 | #endif // ENABLE_GIZMOS_RESET
 | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoScale3D::on_render(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLGizmoScale3D::on_render(const BoundingBoxf3& box) const | void GLGizmoScale3D::on_render(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     if (m_grabbers[0].dragging || m_grabbers[1].dragging) |     if (m_grabbers[0].dragging || m_grabbers[1].dragging) | ||||||
|         set_tooltip("X: " + format(100.0f * m_scale(0), 4) + "%"); |         set_tooltip("X: " + format(100.0f * m_scale(0), 4) + "%"); | ||||||
| @ -796,37 +862,91 @@ void GLGizmoScale3D::on_render(const BoundingBoxf3& box) const | |||||||
| 
 | 
 | ||||||
|     ::glEnable(GL_DEPTH_TEST); |     ::glEnable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     BoundingBoxf3 box; | ||||||
|  |     Transform3d transform = Transform3d::Identity(); | ||||||
|  |     Vec3d angles = Vec3d::Zero(); | ||||||
|  | 
 | ||||||
|  |     if (selection.is_from_single_instance()) | ||||||
|  |     { | ||||||
|  |         // calculate bounding box in instance local reference system
 | ||||||
|  |         const GLCanvas3D::Selection::IndicesList& idxs = selection.get_volume_idxs(); | ||||||
|  |         for (unsigned int idx : idxs) | ||||||
|  |         { | ||||||
|  |             box.merge(selection.get_volume(idx)->bounding_box); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // gets transform from first selected volume
 | ||||||
|  |         transform = selection.get_volume(*idxs.begin())->world_matrix().cast<double>(); | ||||||
|  | 
 | ||||||
|  |         // extract angles from transform
 | ||||||
|  |         angles = Slic3r::Geometry::extract_euler_angles(transform); | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |         box = selection.get_bounding_box(); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|  | 
 | ||||||
|     m_box = BoundingBoxf3(box.min - OffsetVec, box.max + OffsetVec); |     m_box = BoundingBoxf3(box.min - OffsetVec, box.max + OffsetVec); | ||||||
|     const Vec3d& center = m_box.center(); |     const Vec3d& center = m_box.center(); | ||||||
| 
 | 
 | ||||||
|     // x axis
 |     // x axis
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     m_grabbers[0].center = transform * Vec3d(m_box.min(0), center(1), center(2)); | ||||||
|  |     m_grabbers[1].center = transform * Vec3d(m_box.max(0), center(1), center(2)); | ||||||
|  | #else | ||||||
|     m_grabbers[0].center = Vec3d(m_box.min(0), center(1), center(2)); |     m_grabbers[0].center = Vec3d(m_box.min(0), center(1), center(2)); | ||||||
|     m_grabbers[1].center = Vec3d(m_box.max(0), center(1), center(2)); |     m_grabbers[1].center = Vec3d(m_box.max(0), center(1), center(2)); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     ::memcpy((void*)m_grabbers[0].color, (const void*)&AXES_COLOR[0], 3 * sizeof(float)); |     ::memcpy((void*)m_grabbers[0].color, (const void*)&AXES_COLOR[0], 3 * sizeof(float)); | ||||||
|     ::memcpy((void*)m_grabbers[1].color, (const void*)&AXES_COLOR[0], 3 * sizeof(float)); |     ::memcpy((void*)m_grabbers[1].color, (const void*)&AXES_COLOR[0], 3 * sizeof(float)); | ||||||
| 
 | 
 | ||||||
|     // y axis
 |     // y axis
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     m_grabbers[2].center = transform * Vec3d(center(0), m_box.min(1), center(2)); | ||||||
|  |     m_grabbers[3].center = transform * Vec3d(center(0), m_box.max(1), center(2)); | ||||||
|  | #else | ||||||
|     m_grabbers[2].center = Vec3d(center(0), m_box.min(1), center(2)); |     m_grabbers[2].center = Vec3d(center(0), m_box.min(1), center(2)); | ||||||
|     m_grabbers[3].center = Vec3d(center(0), m_box.max(1), center(2)); |     m_grabbers[3].center = Vec3d(center(0), m_box.max(1), center(2)); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     ::memcpy((void*)m_grabbers[2].color, (const void*)&AXES_COLOR[1], 3 * sizeof(float)); |     ::memcpy((void*)m_grabbers[2].color, (const void*)&AXES_COLOR[1], 3 * sizeof(float)); | ||||||
|     ::memcpy((void*)m_grabbers[3].color, (const void*)&AXES_COLOR[1], 3 * sizeof(float)); |     ::memcpy((void*)m_grabbers[3].color, (const void*)&AXES_COLOR[1], 3 * sizeof(float)); | ||||||
| 
 | 
 | ||||||
|     // z axis
 |     // z axis
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     m_grabbers[4].center = transform * Vec3d(center(0), center(1), m_box.min(2)); | ||||||
|  |     m_grabbers[5].center = transform * Vec3d(center(0), center(1), m_box.max(2)); | ||||||
|  | #else | ||||||
|     m_grabbers[4].center = Vec3d(center(0), center(1), m_box.min(2)); |     m_grabbers[4].center = Vec3d(center(0), center(1), m_box.min(2)); | ||||||
|     m_grabbers[5].center = Vec3d(center(0), center(1), m_box.max(2)); |     m_grabbers[5].center = Vec3d(center(0), center(1), m_box.max(2)); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     ::memcpy((void*)m_grabbers[4].color, (const void*)&AXES_COLOR[2], 3 * sizeof(float)); |     ::memcpy((void*)m_grabbers[4].color, (const void*)&AXES_COLOR[2], 3 * sizeof(float)); | ||||||
|     ::memcpy((void*)m_grabbers[5].color, (const void*)&AXES_COLOR[2], 3 * sizeof(float)); |     ::memcpy((void*)m_grabbers[5].color, (const void*)&AXES_COLOR[2], 3 * sizeof(float)); | ||||||
| 
 | 
 | ||||||
|     // uniform
 |     // uniform
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     m_grabbers[6].center = transform * Vec3d(m_box.min(0), m_box.min(1), center(2)); | ||||||
|  |     m_grabbers[7].center = transform * Vec3d(m_box.max(0), m_box.min(1), center(2)); | ||||||
|  |     m_grabbers[8].center = transform * Vec3d(m_box.max(0), m_box.max(1), center(2)); | ||||||
|  |     m_grabbers[9].center = transform * Vec3d(m_box.min(0), m_box.max(1), center(2)); | ||||||
|  | #else | ||||||
|     m_grabbers[6].center = Vec3d(m_box.min(0), m_box.min(1), center(2)); |     m_grabbers[6].center = Vec3d(m_box.min(0), m_box.min(1), center(2)); | ||||||
|     m_grabbers[7].center = Vec3d(m_box.max(0), m_box.min(1), center(2)); |     m_grabbers[7].center = Vec3d(m_box.max(0), m_box.min(1), center(2)); | ||||||
|     m_grabbers[8].center = Vec3d(m_box.max(0), m_box.max(1), center(2)); |     m_grabbers[8].center = Vec3d(m_box.max(0), m_box.max(1), center(2)); | ||||||
|     m_grabbers[9].center = Vec3d(m_box.min(0), m_box.max(1), center(2)); |     m_grabbers[9].center = Vec3d(m_box.min(0), m_box.max(1), center(2)); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     for (int i = 6; i < 10; ++i) |     for (int i = 6; i < 10; ++i) | ||||||
|     { |     { | ||||||
|         ::memcpy((void*)m_grabbers[i].color, (const void*)m_highlight_color, 3 * sizeof(float)); |         ::memcpy((void*)m_grabbers[i].color, (const void*)m_highlight_color, 3 * sizeof(float)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     // sets grabbers orientation
 | ||||||
|  |     for (int i = 0; i < 10; ++i) | ||||||
|  |     { | ||||||
|  |         m_grabbers[i].angles = angles; | ||||||
|  |     } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|  | 
 | ||||||
|     ::glLineWidth((m_hover_id != -1) ? 2.0f : 1.5f); |     ::glLineWidth((m_hover_id != -1) ? 2.0f : 1.5f); | ||||||
| 
 | 
 | ||||||
|     float box_max_size = (float)m_box.max_size(); |     float box_max_size = (float)m_box.max_size(); | ||||||
| @ -900,12 +1020,21 @@ void GLGizmoScale3D::on_render(const BoundingBoxf3& box) const | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoScale3D::on_render_for_picking(const GLCanvas3D::Selection& selection) const | ||||||
|  | { | ||||||
|  |     ::glDisable(GL_DEPTH_TEST); | ||||||
|  | 
 | ||||||
|  |     render_grabbers_for_picking(selection.get_bounding_box()); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLGizmoScale3D::on_render_for_picking(const BoundingBoxf3& box) const | void GLGizmoScale3D::on_render_for_picking(const BoundingBoxf3& box) const | ||||||
| { | { | ||||||
|     ::glDisable(GL_DEPTH_TEST); |     ::glDisable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|     render_grabbers_for_picking(box); |     render_grabbers_for_picking(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| void GLGizmoScale3D::render_grabbers_connection(unsigned int id_1, unsigned int id_2) const | void GLGizmoScale3D::render_grabbers_connection(unsigned int id_1, unsigned int id_2) const | ||||||
| { | { | ||||||
| @ -1040,12 +1169,17 @@ bool GLGizmoMove3D::on_init() | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoMove3D::on_start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | #else | ||||||
| void GLGizmoMove3D::on_start_dragging(const BoundingBoxf3& box) | void GLGizmoMove3D::on_start_dragging(const BoundingBoxf3& box) | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     if (m_hover_id != -1) |     if (m_hover_id != -1) | ||||||
|     { |     { | ||||||
| #if ENABLE_EXTENDED_SELECTION | #if ENABLE_EXTENDED_SELECTION | ||||||
|         m_displacement = Vec3d::Zero(); |         m_displacement = Vec3d::Zero(); | ||||||
|  |         const BoundingBoxf3& box = selection.get_bounding_box(); | ||||||
| #endif // ENABLE_EXTENDED_SELECTION
 | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|         m_starting_drag_position = m_grabbers[m_hover_id].center; |         m_starting_drag_position = m_grabbers[m_hover_id].center; | ||||||
|         m_starting_box_center = box.center(); |         m_starting_box_center = box.center(); | ||||||
| @ -1073,7 +1207,11 @@ void GLGizmoMove3D::on_update(const Linef3& mouse_ray) | |||||||
| #endif // ENABLE_EXTENDED_SELECTION
 | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoMove3D::on_render(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLGizmoMove3D::on_render(const BoundingBoxf3& box) const | void GLGizmoMove3D::on_render(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
| #if ENABLE_EXTENDED_SELECTION | #if ENABLE_EXTENDED_SELECTION | ||||||
|     if (m_grabbers[0].dragging) |     if (m_grabbers[0].dragging) | ||||||
| @ -1093,6 +1231,9 @@ void GLGizmoMove3D::on_render(const BoundingBoxf3& box) const | |||||||
| 
 | 
 | ||||||
|     ::glEnable(GL_DEPTH_TEST); |     ::glEnable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     const BoundingBoxf3& box = selection.get_bounding_box(); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     const Vec3d& center = box.center(); |     const Vec3d& center = box.center(); | ||||||
| 
 | 
 | ||||||
|     // x axis
 |     // x axis
 | ||||||
| @ -1141,12 +1282,21 @@ void GLGizmoMove3D::on_render(const BoundingBoxf3& box) const | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoMove3D::on_render_for_picking(const GLCanvas3D::Selection& selection) const | ||||||
|  | { | ||||||
|  |     ::glDisable(GL_DEPTH_TEST); | ||||||
|  | 
 | ||||||
|  |     render_grabbers_for_picking(selection.get_bounding_box()); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void GLGizmoMove3D::on_render_for_picking(const BoundingBoxf3& box) const | void GLGizmoMove3D::on_render_for_picking(const BoundingBoxf3& box) const | ||||||
| { | { | ||||||
|     ::glDisable(GL_DEPTH_TEST); |     ::glDisable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|     render_grabbers_for_picking(box); |     render_grabbers_for_picking(box); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| double GLGizmoMove3D::calc_projection(Axis axis, unsigned int preferred_plane_id, const Linef3& mouse_ray) const | double GLGizmoMove3D::calc_projection(Axis axis, unsigned int preferred_plane_id, const Linef3& mouse_ray) const | ||||||
| { | { | ||||||
| @ -1210,23 +1360,39 @@ bool GLGizmoFlatten::on_init() | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoFlatten::on_start_dragging(const GLCanvas3D::Selection& selection) | ||||||
|  | #else | ||||||
| void GLGizmoFlatten::on_start_dragging(const BoundingBoxf3& box) | void GLGizmoFlatten::on_start_dragging(const BoundingBoxf3& box) | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     if (m_hover_id != -1) |     if (m_hover_id != -1) | ||||||
|     { |     { | ||||||
|         m_normal = m_planes[m_hover_id].normal; |         m_normal = m_planes[m_hover_id].normal; | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |         m_starting_center = selection.get_bounding_box().center(); | ||||||
|  | #else | ||||||
|         m_starting_center = box.center(); |         m_starting_center = box.center(); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoFlatten::on_render(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLGizmoFlatten::on_render(const BoundingBoxf3& box) const | void GLGizmoFlatten::on_render(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     // the dragged_offset is a vector measuring where was the object moved
 |     // the dragged_offset is a vector measuring where was the object moved
 | ||||||
|     // with the gizmo being on. This is reset in set_flattening_data and
 |     // with the gizmo being on. This is reset in set_flattening_data and
 | ||||||
|     // does not work correctly when there are multiple copies.
 |     // does not work correctly when there are multiple copies.
 | ||||||
|     Vec3d dragged_offset(Vec3d::Zero()); |     Vec3d dragged_offset(Vec3d::Zero()); | ||||||
|     if (m_dragging) |     if (m_dragging) | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |         dragged_offset = selection.get_bounding_box().center() - m_starting_center; | ||||||
|  | #else | ||||||
|         dragged_offset = box.center() - m_starting_center; |         dragged_offset = box.center() - m_starting_center; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
|     ::glEnable(GL_BLEND); |     ::glEnable(GL_BLEND); | ||||||
|     ::glEnable(GL_DEPTH_TEST); |     ::glEnable(GL_DEPTH_TEST); | ||||||
| @ -1260,7 +1426,11 @@ void GLGizmoFlatten::on_render(const BoundingBoxf3& box) const | |||||||
|     ::glDisable(GL_BLEND); |     ::glDisable(GL_BLEND); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | void GLGizmoFlatten::on_render_for_picking(const GLCanvas3D::Selection& selection) const | ||||||
|  | #else | ||||||
| void GLGizmoFlatten::on_render_for_picking(const BoundingBoxf3& box) const | void GLGizmoFlatten::on_render_for_picking(const BoundingBoxf3& box) const | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| { | { | ||||||
|     ::glEnable(GL_DEPTH_TEST); |     ::glEnable(GL_DEPTH_TEST); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2,6 +2,9 @@ | |||||||
| #define slic3r_GLGizmo_hpp_ | #define slic3r_GLGizmo_hpp_ | ||||||
| 
 | 
 | ||||||
| #include "../../slic3r/GUI/GLTexture.hpp" | #include "../../slic3r/GUI/GLTexture.hpp" | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  | #include "../../slic3r/GUI/GLCanvas3D.hpp" | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| #include "../../libslic3r/Point.hpp" | #include "../../libslic3r/Point.hpp" | ||||||
| #include "../../libslic3r/BoundingBox.hpp" | #include "../../libslic3r/BoundingBox.hpp" | ||||||
| 
 | 
 | ||||||
| @ -96,7 +99,11 @@ public: | |||||||
|     void enable_grabber(unsigned int id); |     void enable_grabber(unsigned int id); | ||||||
|     void disable_grabber(unsigned int id); |     void disable_grabber(unsigned int id); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     void start_dragging(const GLCanvas3D::Selection& selection); | ||||||
|  | #else | ||||||
|     void start_dragging(const BoundingBoxf3& box); |     void start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     void stop_dragging(); |     void stop_dragging(); | ||||||
|     bool is_dragging() const { return m_dragging; } |     bool is_dragging() const { return m_dragging; } | ||||||
| 
 | 
 | ||||||
| @ -106,8 +113,13 @@ public: | |||||||
|     void process_double_click() { on_process_double_click(); } |     void process_double_click() { on_process_double_click(); } | ||||||
| #endif // ENABLE_GIZMOS_RESET
 | #endif // ENABLE_GIZMOS_RESET
 | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     void render(const GLCanvas3D::Selection& selection) const { on_render(selection); } | ||||||
|  |     void render_for_picking(const GLCanvas3D::Selection& selection) const { on_render_for_picking(selection); } | ||||||
|  | #else | ||||||
|     void render(const BoundingBoxf3& box) const { on_render(box); } |     void render(const BoundingBoxf3& box) const { on_render(box); } | ||||||
|     void render_for_picking(const BoundingBoxf3& box) const { on_render_for_picking(box); } |     void render_for_picking(const BoundingBoxf3& box) const { on_render_for_picking(box); } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual bool on_init() = 0; |     virtual bool on_init() = 0; | ||||||
| @ -115,14 +127,23 @@ protected: | |||||||
|     virtual void on_set_hover_id() {} |     virtual void on_set_hover_id() {} | ||||||
|     virtual void on_enable_grabber(unsigned int id) {} |     virtual void on_enable_grabber(unsigned int id) {} | ||||||
|     virtual void on_disable_grabber(unsigned int id) {} |     virtual void on_disable_grabber(unsigned int id) {} | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_start_dragging(const GLCanvas3D::Selection& selection) {} | ||||||
|  | #else | ||||||
|     virtual void on_start_dragging(const BoundingBoxf3& box) {} |     virtual void on_start_dragging(const BoundingBoxf3& box) {} | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_stop_dragging() {} |     virtual void on_stop_dragging() {} | ||||||
|     virtual void on_update(const Linef3& mouse_ray) = 0; |     virtual void on_update(const Linef3& mouse_ray) = 0; | ||||||
| #if ENABLE_GIZMOS_RESET | #if ENABLE_GIZMOS_RESET | ||||||
|     virtual void on_process_double_click() {} |     virtual void on_process_double_click() {} | ||||||
| #endif // ENABLE_GIZMOS_RESET
 | #endif // ENABLE_GIZMOS_RESET
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_render(const GLCanvas3D::Selection& selection) const = 0; | ||||||
|  |     virtual void on_render_for_picking(const GLCanvas3D::Selection& selection) const = 0; | ||||||
|  | #else | ||||||
|     virtual void on_render(const BoundingBoxf3& box) const = 0; |     virtual void on_render(const BoundingBoxf3& box) const = 0; | ||||||
|     virtual void on_render_for_picking(const BoundingBoxf3& box) const = 0; |     virtual void on_render_for_picking(const BoundingBoxf3& box) const = 0; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
|     float picking_color_component(unsigned int id) const; |     float picking_color_component(unsigned int id) const; | ||||||
|     void render_grabbers(const BoundingBoxf3& box) const; |     void render_grabbers(const BoundingBoxf3& box) const; | ||||||
| @ -172,13 +193,22 @@ public: | |||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual bool on_init(); |     virtual bool on_init(); | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_start_dragging(const GLCanvas3D::Selection& selection); | ||||||
|  | #else | ||||||
|     virtual void on_start_dragging(const BoundingBoxf3& box); |     virtual void on_start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_update(const Linef3& mouse_ray); |     virtual void on_update(const Linef3& mouse_ray); | ||||||
| #if ENABLE_GIZMOS_RESET | #if ENABLE_GIZMOS_RESET | ||||||
|     virtual void on_process_double_click() { m_angle = 0.0; } |     virtual void on_process_double_click() { m_angle = 0.0; } | ||||||
| #endif // ENABLE_GIZMOS_RESET
 | #endif // ENABLE_GIZMOS_RESET
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_render(const GLCanvas3D::Selection& selection) const; | ||||||
|  |     virtual void on_render_for_picking(const GLCanvas3D::Selection& selection) const; | ||||||
|  | #else | ||||||
|     virtual void on_render(const BoundingBoxf3& box) const; |     virtual void on_render(const BoundingBoxf3& box) const; | ||||||
|     virtual void on_render_for_picking(const BoundingBoxf3& box) const; |     virtual void on_render_for_picking(const BoundingBoxf3& box) const; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     void render_circle() const; |     void render_circle() const; | ||||||
| @ -240,7 +270,11 @@ protected: | |||||||
|         if ((0 <= id) && (id < 3)) |         if ((0 <= id) && (id < 3)) | ||||||
|             m_gizmos[id].disable_grabber(0); |             m_gizmos[id].disable_grabber(0); | ||||||
|     } |     } | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_start_dragging(const GLCanvas3D::Selection& selection); | ||||||
|  | #else | ||||||
|     virtual void on_start_dragging(const BoundingBoxf3& box); |     virtual void on_start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_stop_dragging(); |     virtual void on_stop_dragging(); | ||||||
|     virtual void on_update(const Linef3& mouse_ray) |     virtual void on_update(const Linef3& mouse_ray) | ||||||
|     { |     { | ||||||
| @ -256,6 +290,16 @@ protected: | |||||||
|             m_gizmos[m_hover_id].process_double_click(); |             m_gizmos[m_hover_id].process_double_click(); | ||||||
|     } |     } | ||||||
| #endif // ENABLE_GIZMOS_RESET
 | #endif // ENABLE_GIZMOS_RESET
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_render(const GLCanvas3D::Selection& selection) const; | ||||||
|  |     virtual void on_render_for_picking(const GLCanvas3D::Selection& selection) const | ||||||
|  |     { | ||||||
|  |         for (const GLGizmoRotate& g : m_gizmos) | ||||||
|  |         { | ||||||
|  |             g.render_for_picking(selection); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | #else | ||||||
|     virtual void on_render(const BoundingBoxf3& box) const; |     virtual void on_render(const BoundingBoxf3& box) const; | ||||||
|     virtual void on_render_for_picking(const BoundingBoxf3& box) const |     virtual void on_render_for_picking(const BoundingBoxf3& box) const | ||||||
|     { |     { | ||||||
| @ -264,6 +308,7 @@ protected: | |||||||
|             g.render_for_picking(box); |             g.render_for_picking(box); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class GLGizmoScale3D : public GLGizmoBase | class GLGizmoScale3D : public GLGizmoBase | ||||||
| @ -300,13 +345,22 @@ public: | |||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual bool on_init(); |     virtual bool on_init(); | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_start_dragging(const GLCanvas3D::Selection& selection); | ||||||
|  | #else | ||||||
|     virtual void on_start_dragging(const BoundingBoxf3& box); |     virtual void on_start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_update(const Linef3& mouse_ray); |     virtual void on_update(const Linef3& mouse_ray); | ||||||
| #if ENABLE_GIZMOS_RESET | #if ENABLE_GIZMOS_RESET | ||||||
|     virtual void on_process_double_click(); |     virtual void on_process_double_click(); | ||||||
| #endif // ENABLE_GIZMOS_RESET
 | #endif // ENABLE_GIZMOS_RESET
 | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_render(const GLCanvas3D::Selection& selection) const; | ||||||
|  |     virtual void on_render_for_picking(const GLCanvas3D::Selection& selection) const; | ||||||
|  | #else | ||||||
|     virtual void on_render(const BoundingBoxf3& box) const; |     virtual void on_render(const BoundingBoxf3& box) const; | ||||||
|     virtual void on_render_for_picking(const BoundingBoxf3& box) const; |     virtual void on_render_for_picking(const BoundingBoxf3& box) const; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     void render_grabbers_connection(unsigned int id_1, unsigned int id_2) const; |     void render_grabbers_connection(unsigned int id_1, unsigned int id_2) const; | ||||||
| @ -344,10 +398,19 @@ public: | |||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual bool on_init(); |     virtual bool on_init(); | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_start_dragging(const GLCanvas3D::Selection& selection); | ||||||
|  | #else | ||||||
|     virtual void on_start_dragging(const BoundingBoxf3& box); |     virtual void on_start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_update(const Linef3& mouse_ray); |     virtual void on_update(const Linef3& mouse_ray); | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_render(const GLCanvas3D::Selection& selection) const; | ||||||
|  |     virtual void on_render_for_picking(const GLCanvas3D::Selection& selection) const; | ||||||
|  | #else | ||||||
|     virtual void on_render(const BoundingBoxf3& box) const; |     virtual void on_render(const BoundingBoxf3& box) const; | ||||||
|     virtual void on_render_for_picking(const BoundingBoxf3& box) const; |     virtual void on_render_for_picking(const BoundingBoxf3& box) const; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     double calc_projection(Axis axis, unsigned int preferred_plane_id, const Linef3& mouse_ray) const; |     double calc_projection(Axis axis, unsigned int preferred_plane_id, const Linef3& mouse_ray) const; | ||||||
| @ -406,10 +469,19 @@ public: | |||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual bool on_init(); |     virtual bool on_init(); | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_start_dragging(const GLCanvas3D::Selection& selection); | ||||||
|  | #else | ||||||
|     virtual void on_start_dragging(const BoundingBoxf3& box); |     virtual void on_start_dragging(const BoundingBoxf3& box); | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_update(const Linef3& mouse_ray) {} |     virtual void on_update(const Linef3& mouse_ray) {} | ||||||
|  | #if ENABLE_EXTENDED_SELECTION | ||||||
|  |     virtual void on_render(const GLCanvas3D::Selection& selection) const; | ||||||
|  |     virtual void on_render_for_picking(const GLCanvas3D::Selection& selection) const; | ||||||
|  | #else | ||||||
|     virtual void on_render(const BoundingBoxf3& box) const; |     virtual void on_render(const BoundingBoxf3& box) const; | ||||||
|     virtual void on_render_for_picking(const BoundingBoxf3& box) const; |     virtual void on_render_for_picking(const BoundingBoxf3& box) const; | ||||||
|  | #endif // ENABLE_EXTENDED_SELECTION
 | ||||||
|     virtual void on_set_state() |     virtual void on_set_state() | ||||||
|     { |     { | ||||||
|         if (m_state == On && is_plane_update_necessary()) |         if (m_state == On && is_plane_update_necessary()) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Enrico Turri
						Enrico Turri