mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 04:41:06 +08:00 
			
		
		
		
	After gizmo snapshots are compacted, rename the last one to something generic
This commit is contained in:
		
							parent
							
								
									aeb18e729d
								
							
						
					
					
						commit
						c61a5d234e
					
				| @ -136,6 +136,7 @@ public: | |||||||
|     bool is_selectable() const { return on_is_selectable(); } |     bool is_selectable() const { return on_is_selectable(); } | ||||||
|     CommonGizmosDataID get_requirements() const { return on_get_requirements(); } |     CommonGizmosDataID get_requirements() const { return on_get_requirements(); } | ||||||
|     virtual bool wants_enter_leave_snapshots() const { return false; } |     virtual bool wants_enter_leave_snapshots() const { return false; } | ||||||
|  |     virtual std::string get_action_snapshot_name() { return _u8L("Gizmo action"); } | ||||||
|     void set_common_data_pool(CommonGizmosDataPool* ptr) { m_c = ptr; } |     void set_common_data_pool(CommonGizmosDataPool* ptr) { m_c = ptr; } | ||||||
| 
 | 
 | ||||||
|     unsigned int get_sprite_id() const { return m_sprite_id; } |     unsigned int get_sprite_id() const { return m_sprite_id; } | ||||||
|  | |||||||
| @ -8,6 +8,7 @@ | |||||||
| #include "slic3r/GUI/ImGuiWrapper.hpp" | #include "slic3r/GUI/ImGuiWrapper.hpp" | ||||||
| #include "slic3r/GUI/Plater.hpp" | #include "slic3r/GUI/Plater.hpp" | ||||||
| #include "slic3r/GUI/GUI_ObjectList.hpp" | #include "slic3r/GUI/GUI_ObjectList.hpp" | ||||||
|  | #include "slic3r/Utils/UndoRedo.hpp" | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #include <GL/glew.h> | #include <GL/glew.h> | ||||||
| @ -165,7 +166,8 @@ void GLGizmoFdmSupports::on_render_input_window(float x, float y, float bottom_l | |||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     if (m_imgui->button(m_desc.at("remove_all"))) { |     if (m_imgui->button(m_desc.at("remove_all"))) { | ||||||
|         Plater::TakeSnapshot snapshot(wxGetApp().plater(), wxString(_L("Reset selection"))); |         Plater::TakeSnapshot snapshot(wxGetApp().plater(), _L("Reset selection"), | ||||||
|  |                                       UndoRedo::SnapshotType::GizmoAction); | ||||||
|         ModelObject* mo = m_c->selection_info()->model_object(); |         ModelObject* mo = m_c->selection_info()->model_object(); | ||||||
|         int idx = -1; |         int idx = -1; | ||||||
|         for (ModelVolume* mv : mo->volumes) { |         for (ModelVolume* mv : mo->volumes) { | ||||||
|  | |||||||
| @ -21,6 +21,8 @@ protected: | |||||||
| 
 | 
 | ||||||
|     std::string get_gizmo_entering_text() const override { return _u8L("Entering Paint-on supports"); } |     std::string get_gizmo_entering_text() const override { return _u8L("Entering Paint-on supports"); } | ||||||
|     std::string get_gizmo_leaving_text() const override { return _u8L("Leaving Paint-on supports"); } |     std::string get_gizmo_leaving_text() const override { return _u8L("Leaving Paint-on supports"); } | ||||||
|  |     std::string get_action_snapshot_name() override { return _u8L("Paint-on supports editing"); } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     bool on_init() override; |     bool on_init() override; | ||||||
|  | |||||||
| @ -11,6 +11,7 @@ | |||||||
| #include "slic3r/GUI/NotificationManager.hpp" | #include "slic3r/GUI/NotificationManager.hpp" | ||||||
| #include "libslic3r/PresetBundle.hpp" | #include "libslic3r/PresetBundle.hpp" | ||||||
| #include "libslic3r/Model.hpp" | #include "libslic3r/Model.hpp" | ||||||
|  | #include "slic3r/Utils/UndoRedo.hpp" | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #include <GL/glew.h> | #include <GL/glew.h> | ||||||
| @ -503,7 +504,8 @@ void GLGizmoMmuSegmentation::on_render_input_window(float x, float y, float bott | |||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
|     if (m_imgui->button(m_desc.at("remove_all"))) { |     if (m_imgui->button(m_desc.at("remove_all"))) { | ||||||
|         Plater::TakeSnapshot snapshot(wxGetApp().plater(), wxString(_L("Reset selection"))); |         Plater::TakeSnapshot snapshot(wxGetApp().plater(), _L("Reset selection"), | ||||||
|  |                                       UndoRedo::SnapshotType::GizmoAction); | ||||||
|         ModelObject *        mo  = m_c->selection_info()->model_object(); |         ModelObject *        mo  = m_c->selection_info()->model_object(); | ||||||
|         int                  idx = -1; |         int                  idx = -1; | ||||||
|         for (ModelVolume *mv : mo->volumes) |         for (ModelVolume *mv : mo->volumes) | ||||||
|  | |||||||
| @ -130,6 +130,7 @@ protected: | |||||||
| 
 | 
 | ||||||
|     std::string get_gizmo_entering_text() const override { return _u8L("Entering Multimaterial painting"); } |     std::string get_gizmo_entering_text() const override { return _u8L("Entering Multimaterial painting"); } | ||||||
|     std::string get_gizmo_leaving_text() const override { return _u8L("Leaving Multimaterial painting"); } |     std::string get_gizmo_leaving_text() const override { return _u8L("Leaving Multimaterial painting"); } | ||||||
|  |     std::string get_action_snapshot_name() override { return _u8L("Multimaterial painting editing"); } | ||||||
| 
 | 
 | ||||||
|     size_t                            m_first_selected_extruder_idx  = 0; |     size_t                            m_first_selected_extruder_idx  = 0; | ||||||
|     size_t                            m_second_selected_extruder_idx = 1; |     size_t                            m_second_selected_extruder_idx = 1; | ||||||
|  | |||||||
| @ -8,6 +8,7 @@ | |||||||
| #include "slic3r/GUI/ImGuiWrapper.hpp" | #include "slic3r/GUI/ImGuiWrapper.hpp" | ||||||
| #include "slic3r/GUI/Plater.hpp" | #include "slic3r/GUI/Plater.hpp" | ||||||
| #include "slic3r/GUI/GUI_ObjectList.hpp" | #include "slic3r/GUI/GUI_ObjectList.hpp" | ||||||
|  | #include "slic3r/Utils/UndoRedo.hpp" | ||||||
| 
 | 
 | ||||||
| #include <GL/glew.h> | #include <GL/glew.h> | ||||||
| 
 | 
 | ||||||
| @ -121,7 +122,8 @@ void GLGizmoSeam::on_render_input_window(float x, float y, float bottom_limit) | |||||||
|     m_imgui->text(""); |     m_imgui->text(""); | ||||||
| 
 | 
 | ||||||
|     if (m_imgui->button(m_desc.at("remove_all"))) { |     if (m_imgui->button(m_desc.at("remove_all"))) { | ||||||
|         Plater::TakeSnapshot snapshot(wxGetApp().plater(), wxString(_L("Reset selection"))); |         Plater::TakeSnapshot snapshot(wxGetApp().plater(), _L("Reset selection"), | ||||||
|  |                                       UndoRedo::SnapshotType::GizmoAction); | ||||||
|         ModelObject* mo = m_c->selection_info()->model_object(); |         ModelObject* mo = m_c->selection_info()->model_object(); | ||||||
|         int idx = -1; |         int idx = -1; | ||||||
|         for (ModelVolume* mv : mo->volumes) { |         for (ModelVolume* mv : mo->volumes) { | ||||||
|  | |||||||
| @ -22,6 +22,7 @@ protected: | |||||||
| 
 | 
 | ||||||
|     std::string get_gizmo_entering_text() const override { return _u8L("Entering Seam painting"); } |     std::string get_gizmo_entering_text() const override { return _u8L("Entering Seam painting"); } | ||||||
|     std::string get_gizmo_leaving_text() const override { return _u8L("Leaving Seam painting"); } |     std::string get_gizmo_leaving_text() const override { return _u8L("Leaving Seam painting"); } | ||||||
|  |     std::string get_action_snapshot_name() override { return _u8L("Paint-on seam editing"); } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     bool on_init() override; |     bool on_init() override; | ||||||
|  | |||||||
| @ -4695,12 +4695,22 @@ void Plater::priv::take_snapshot(const std::string& snapshot_name, const UndoRed | |||||||
|         model.wipe_tower.position = Vec2d(config.opt_float("wipe_tower_x"), config.opt_float("wipe_tower_y")); |         model.wipe_tower.position = Vec2d(config.opt_float("wipe_tower_x"), config.opt_float("wipe_tower_y")); | ||||||
|         model.wipe_tower.rotation = config.opt_float("wipe_tower_rotation_angle"); |         model.wipe_tower.rotation = config.opt_float("wipe_tower_rotation_angle"); | ||||||
|     } |     } | ||||||
|  |     const GLGizmosManager& gizmos = view3D->get_canvas3d()->get_gizmos_manager(); | ||||||
|  | 
 | ||||||
|     if (snapshot_type == UndoRedo::SnapshotType::ProjectSeparator && wxGetApp().app_config->get("clear_undo_redo_stack_on_new_project") == "1") |     if (snapshot_type == UndoRedo::SnapshotType::ProjectSeparator && wxGetApp().app_config->get("clear_undo_redo_stack_on_new_project") == "1") | ||||||
|         this->undo_redo_stack().clear(); |         this->undo_redo_stack().clear(); | ||||||
|     this->undo_redo_stack().take_snapshot(snapshot_name, model, view3D->get_canvas3d()->get_selection(), view3D->get_canvas3d()->get_gizmos_manager(), snapshot_data); |     this->undo_redo_stack().take_snapshot(snapshot_name, model, view3D->get_canvas3d()->get_selection(), gizmos, snapshot_data); | ||||||
|     if (snapshot_type == UndoRedo::SnapshotType::LeavingGizmoWithAction) |     if (snapshot_type == UndoRedo::SnapshotType::LeavingGizmoWithAction) { | ||||||
|         // Filter all but the last UndoRedo::SnapshotType::GizmoAction in a row between the last UndoRedo::SnapshotType::EnteringGizmo and UndoRedo::SnapshotType::LeavingGizmoWithAction.
 |         // Filter all but the last UndoRedo::SnapshotType::GizmoAction in a row between the last UndoRedo::SnapshotType::EnteringGizmo and UndoRedo::SnapshotType::LeavingGizmoWithAction.
 | ||||||
|         this->undo_redo_stack().reduce_noisy_snapshots(); |         // The remaining snapshot will be renamed to a more generic name,
 | ||||||
|  |         // depending on what gizmo is being left.
 | ||||||
|  |         assert(gizmos.get_current() != nullptr); | ||||||
|  |         std::string new_name = gizmos.get_current()->get_action_snapshot_name(); | ||||||
|  |         this->undo_redo_stack().reduce_noisy_snapshots(new_name); | ||||||
|  |     } else if (snapshot_type == UndoRedo::SnapshotType::ProjectSeparator) { | ||||||
|  |         // Reset the "dirty project" flag.
 | ||||||
|  |         m_undo_redo_stack_main.mark_current_as_saved(); | ||||||
|  |     } | ||||||
|     this->undo_redo_stack().release_least_recently_used(); |     this->undo_redo_stack().release_least_recently_used(); | ||||||
| 
 | 
 | ||||||
|     dirty_state.update_from_undo_redo_stack(m_undo_redo_stack_main.project_modified()); |     dirty_state.update_from_undo_redo_stack(m_undo_redo_stack_main.project_modified()); | ||||||
|  | |||||||
| @ -576,7 +576,7 @@ public: | |||||||
| 
 | 
 | ||||||
|     // Store the current application state onto the Undo / Redo stack, remove all snapshots after m_active_snapshot_time.
 |     // Store the current application state onto the Undo / Redo stack, remove all snapshots after m_active_snapshot_time.
 | ||||||
|     void take_snapshot(const std::string& snapshot_name, const Slic3r::Model& model, const Slic3r::GUI::Selection& selection, const Slic3r::GUI::GLGizmosManager& gizmos, const SnapshotData &snapshot_data); |     void take_snapshot(const std::string& snapshot_name, const Slic3r::Model& model, const Slic3r::GUI::Selection& selection, const Slic3r::GUI::GLGizmosManager& gizmos, const SnapshotData &snapshot_data); | ||||||
|     void reduce_noisy_snapshots(); |     void reduce_noisy_snapshots(const std::string& new_name); | ||||||
|     void load_snapshot(size_t timestamp, Slic3r::Model& model, Slic3r::GUI::GLGizmosManager& gizmos); |     void load_snapshot(size_t timestamp, Slic3r::Model& model, Slic3r::GUI::GLGizmosManager& gizmos); | ||||||
| 
 | 
 | ||||||
| 	bool has_undo_snapshot() const; | 	bool has_undo_snapshot() const; | ||||||
| @ -934,7 +934,7 @@ void StackImpl::take_snapshot(const std::string& snapshot_name, const Slic3r::Mo | |||||||
| #endif /* SLIC3R_UNDOREDO_DEBUG */ | #endif /* SLIC3R_UNDOREDO_DEBUG */ | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void StackImpl::reduce_noisy_snapshots() | void StackImpl::reduce_noisy_snapshots(const std::string& new_name) | ||||||
| { | { | ||||||
| 	// Preceding snapshot must be a "leave gizmo" snapshot.
 | 	// Preceding snapshot must be a "leave gizmo" snapshot.
 | ||||||
| 	assert(! m_snapshots.empty() && m_snapshots.back().is_topmost() && m_snapshots.back().timestamp == m_active_snapshot_time); | 	assert(! m_snapshots.empty() && m_snapshots.back().is_topmost() && m_snapshots.back().timestamp == m_active_snapshot_time); | ||||||
| @ -944,6 +944,7 @@ void StackImpl::reduce_noisy_snapshots() | |||||||
| 	if (it_last->snapshot_data.snapshot_type == SnapshotType::LeavingGizmoWithAction) { | 	if (it_last->snapshot_data.snapshot_type == SnapshotType::LeavingGizmoWithAction) { | ||||||
| 		for (-- it_last; it_last->snapshot_data.snapshot_type != SnapshotType::EnteringGizmo; -- it_last) { | 		for (-- it_last; it_last->snapshot_data.snapshot_type != SnapshotType::EnteringGizmo; -- it_last) { | ||||||
| 			if (it_last->snapshot_data.snapshot_type == SnapshotType::GizmoAction) { | 			if (it_last->snapshot_data.snapshot_type == SnapshotType::GizmoAction) { | ||||||
|  |                 it_last->name = new_name; | ||||||
|                 auto it = it_last; |                 auto it = it_last; | ||||||
| 				for (-- it; it->snapshot_data.snapshot_type == SnapshotType::GizmoAction; -- it) ; | 				for (-- it; it->snapshot_data.snapshot_type == SnapshotType::GizmoAction; -- it) ; | ||||||
| 				if (++ it < it_last) { | 				if (++ it < it_last) { | ||||||
| @ -1248,7 +1249,7 @@ size_t Stack::memsize() const { return pimpl->memsize(); } | |||||||
| void Stack::release_least_recently_used() { pimpl->release_least_recently_used(); } | void Stack::release_least_recently_used() { pimpl->release_least_recently_used(); } | ||||||
| void Stack::take_snapshot(const std::string& snapshot_name, const Slic3r::Model& model, const Slic3r::GUI::Selection& selection, const Slic3r::GUI::GLGizmosManager& gizmos, const SnapshotData &snapshot_data) | void Stack::take_snapshot(const std::string& snapshot_name, const Slic3r::Model& model, const Slic3r::GUI::Selection& selection, const Slic3r::GUI::GLGizmosManager& gizmos, const SnapshotData &snapshot_data) | ||||||
| 	{ pimpl->take_snapshot(snapshot_name, model, selection, gizmos, snapshot_data); } | 	{ pimpl->take_snapshot(snapshot_name, model, selection, gizmos, snapshot_data); } | ||||||
| void Stack::reduce_noisy_snapshots() { pimpl->reduce_noisy_snapshots(); } | void Stack::reduce_noisy_snapshots(const std::string& new_name) { pimpl->reduce_noisy_snapshots(new_name); } | ||||||
| bool Stack::has_undo_snapshot() const { return pimpl->has_undo_snapshot(); } | bool Stack::has_undo_snapshot() const { return pimpl->has_undo_snapshot(); } | ||||||
| bool Stack::has_undo_snapshot(size_t time_to_load) const { return pimpl->has_undo_snapshot(time_to_load); } | bool Stack::has_undo_snapshot(size_t time_to_load) const { return pimpl->has_undo_snapshot(time_to_load); } | ||||||
| bool Stack::has_redo_snapshot() const { return pimpl->has_redo_snapshot(); } | bool Stack::has_redo_snapshot() const { return pimpl->has_redo_snapshot(); } | ||||||
|  | |||||||
| @ -8,6 +8,7 @@ | |||||||
| #include <cassert> | #include <cassert> | ||||||
| 
 | 
 | ||||||
| #include <libslic3r/ObjectID.hpp> | #include <libslic3r/ObjectID.hpp> | ||||||
|  | #include <libslic3r/Config.hpp> | ||||||
| 
 | 
 | ||||||
| typedef double                          coordf_t; | typedef double                          coordf_t; | ||||||
| typedef std::pair<coordf_t, coordf_t>   t_layer_height_range; | typedef std::pair<coordf_t, coordf_t>   t_layer_height_range; | ||||||
| @ -15,7 +16,6 @@ typedef std::pair<coordf_t, coordf_t>   t_layer_height_range; | |||||||
| namespace Slic3r { | namespace Slic3r { | ||||||
| 
 | 
 | ||||||
| class Model; | class Model; | ||||||
| enum PrinterTechnology : unsigned char; |  | ||||||
| 
 | 
 | ||||||
| namespace GUI { | namespace GUI { | ||||||
| 	class Selection; | 	class Selection; | ||||||
| @ -122,7 +122,7 @@ public: | |||||||
|     void take_snapshot(const std::string& snapshot_name, const Slic3r::Model& model, const Slic3r::GUI::Selection& selection, const Slic3r::GUI::GLGizmosManager& gizmos, const SnapshotData &snapshot_data); |     void take_snapshot(const std::string& snapshot_name, const Slic3r::Model& model, const Slic3r::GUI::Selection& selection, const Slic3r::GUI::GLGizmosManager& gizmos, const SnapshotData &snapshot_data); | ||||||
|     // To be called just after take_snapshot() when leaving a gizmo, inside which small edits like support point add / remove events or paiting actions were allowed.
 |     // To be called just after take_snapshot() when leaving a gizmo, inside which small edits like support point add / remove events or paiting actions were allowed.
 | ||||||
|     // Remove all but the last edit between the gizmo enter / leave snapshots.
 |     // Remove all but the last edit between the gizmo enter / leave snapshots.
 | ||||||
|     void reduce_noisy_snapshots(); |     void reduce_noisy_snapshots(const std::string& new_name); | ||||||
| 
 | 
 | ||||||
| 	// To be queried to enable / disable the Undo / Redo buttons at the UI.
 | 	// To be queried to enable / disable the Undo / Redo buttons at the UI.
 | ||||||
| 	bool has_undo_snapshot() const; | 	bool has_undo_snapshot() const; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Lukas Matena
						Lukas Matena