mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer into et_custom_bed
This commit is contained in:
		
						commit
						37f2362aab
					
				
					 6 changed files with 111 additions and 38 deletions
				
			
		|  | @ -1641,17 +1641,7 @@ struct Plater::priv | |||
|     void split_volume(); | ||||
|     void scale_selection_to_fit_print_volume(); | ||||
| 
 | ||||
| 	void take_snapshot(const std::string& snapshot_name) | ||||
| 	{ | ||||
|         if (this->m_prevent_snapshots > 0)  | ||||
|             return; | ||||
|         assert(this->m_prevent_snapshots >= 0); | ||||
|         this->undo_redo_stack.take_snapshot(snapshot_name, model, view3D->get_canvas3d()->get_selection(), view3D->get_canvas3d()->get_gizmos_manager(), this->printer_technology); | ||||
| 	    this->undo_redo_stack.release_least_recently_used(); | ||||
| 	    // Save the last active preset name of a particular printer technology.
 | ||||
| 	    ((this->printer_technology == ptFFF) ? m_last_fff_printer_profile_name : m_last_sla_printer_profile_name) = wxGetApp().preset_bundle->printers.get_selected_preset_name(); | ||||
|     	BOOST_LOG_TRIVIAL(info) << "Undo / Redo snapshot taken: " << snapshot_name << ", Undo / Redo stack memory: " << Slic3r::format_memsize_MB(this->undo_redo_stack.memsize()) << log_memory_info(); | ||||
| 	} | ||||
| 	void take_snapshot(const std::string& snapshot_name); | ||||
| 	void take_snapshot(const wxString& snapshot_name) { this->take_snapshot(std::string(snapshot_name.ToUTF8().data())); } | ||||
|     int  get_active_snapshot_index(); | ||||
|     void undo(); | ||||
|  | @ -3596,6 +3586,21 @@ int Plater::priv::get_active_snapshot_index() | |||
|     return it - ss_stack.begin(); | ||||
| } | ||||
| 
 | ||||
| void Plater::priv::take_snapshot(const std::string& snapshot_name) | ||||
| { | ||||
|     if (this->m_prevent_snapshots > 0)  | ||||
|         return; | ||||
|     assert(this->m_prevent_snapshots >= 0); | ||||
|     unsigned int flags = 0; | ||||
|     if (this->view3D->is_layers_editing_enabled()) | ||||
|     	flags |= UndoRedo::Snapshot::VARIABLE_LAYER_EDITING_ACTIVE; | ||||
|     this->undo_redo_stack.take_snapshot(snapshot_name, model, view3D->get_canvas3d()->get_selection(), view3D->get_canvas3d()->get_gizmos_manager(), this->printer_technology, flags); | ||||
|     this->undo_redo_stack.release_least_recently_used(); | ||||
|     // Save the last active preset name of a particular printer technology.
 | ||||
|     ((this->printer_technology == ptFFF) ? m_last_fff_printer_profile_name : m_last_sla_printer_profile_name) = wxGetApp().preset_bundle->printers.get_selected_preset_name(); | ||||
| 	BOOST_LOG_TRIVIAL(info) << "Undo / Redo snapshot taken: " << snapshot_name << ", Undo / Redo stack memory: " << Slic3r::format_memsize_MB(this->undo_redo_stack.memsize()) << log_memory_info(); | ||||
| } | ||||
| 
 | ||||
| void Plater::priv::undo() | ||||
| { | ||||
| 	const std::vector<UndoRedo::Snapshot> &snapshots = this->undo_redo_stack.snapshots(); | ||||
|  | @ -3635,9 +3640,18 @@ void Plater::priv::undo_redo_to(std::vector<UndoRedo::Snapshot>::const_iterator | |||
| 	} | ||||
|     // Save the last active preset name of a particular printer technology.
 | ||||
|     ((this->printer_technology == ptFFF) ? m_last_fff_printer_profile_name : m_last_sla_printer_profile_name) = wxGetApp().preset_bundle->printers.get_selected_preset_name(); | ||||
|     // Flags made of Snapshot::Flags enum values.
 | ||||
|     unsigned int new_flags = it_snapshot->flags; | ||||
| 	unsigned int top_snapshot_flags = 0; | ||||
|     if (this->view3D->is_layers_editing_enabled()) | ||||
|     	top_snapshot_flags |= UndoRedo::Snapshot::VARIABLE_LAYER_EDITING_ACTIVE; | ||||
| 	bool   		 new_variable_layer_editing_active = (new_flags & UndoRedo::Snapshot::VARIABLE_LAYER_EDITING_ACTIVE) != 0; | ||||
| 	// Disable layer editing before the Undo / Redo jump.
 | ||||
|     if (! new_variable_layer_editing_active && view3D->is_layers_editing_enabled()) | ||||
|     	view3D->enable_layers_editing(false); | ||||
|     // Do the jump in time.
 | ||||
|     if (it_snapshot->timestamp < this->undo_redo_stack.active_snapshot_time() ? | ||||
| 		this->undo_redo_stack.undo(model, this->view3D->get_canvas3d()->get_selection(), this->view3D->get_canvas3d()->get_gizmos_manager(), this->printer_technology, it_snapshot->timestamp) : | ||||
| 		this->undo_redo_stack.undo(model, this->view3D->get_canvas3d()->get_selection(), this->view3D->get_canvas3d()->get_gizmos_manager(), this->printer_technology, top_snapshot_flags, it_snapshot->timestamp) : | ||||
| 		this->undo_redo_stack.redo(model, this->view3D->get_canvas3d()->get_gizmos_manager(), it_snapshot->timestamp)) { | ||||
| 		if (printer_technology_changed) { | ||||
| 			// Switch to the other printer technology. Switch to the last printer active for that particular technology.
 | ||||
|  | @ -3649,6 +3663,9 @@ void Plater::priv::undo_redo_to(std::vector<UndoRedo::Snapshot>::const_iterator | |||
|         	wxGetApp().load_current_presets(); | ||||
|         } | ||||
| 		this->update_after_undo_redo(temp_snapshot_was_taken); | ||||
| 		// Enable layer editing after the Undo / Redo jump.
 | ||||
| 		if (! view3D->is_layers_editing_enabled() && this->layers_height_allowed() && new_variable_layer_editing_active) | ||||
| 			view3D->enable_layers_editing(true); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | @ -4556,15 +4573,9 @@ bool Plater::can_copy_to_clipboard() const | |||
|     return true; | ||||
| } | ||||
| 
 | ||||
| bool Plater::can_undo() const | ||||
| { | ||||
|     return p->undo_redo_stack.has_undo_snapshot(); | ||||
| } | ||||
| 
 | ||||
| bool Plater::can_redo() const | ||||
| { | ||||
|     return p->undo_redo_stack.has_redo_snapshot(); | ||||
| } | ||||
| bool Plater::can_undo() const { return p->undo_redo_stack.has_undo_snapshot(); } | ||||
| bool Plater::can_redo() const { return p->undo_redo_stack.has_redo_snapshot(); } | ||||
| const UndoRedo::Stack& Plater::undo_redo_stack() const { return p->undo_redo_stack; } | ||||
| 
 | ||||
| SuppressBackgroundProcessingUpdate::SuppressBackgroundProcessingUpdate() : | ||||
|     m_was_running(wxGetApp().plater()->is_background_process_running()) | ||||
|  |  | |||
|  | @ -27,6 +27,11 @@ class ModelObject; | |||
| class Print; | ||||
| class SLAPrint; | ||||
| 
 | ||||
| namespace UndoRedo { | ||||
| 	class Stack; | ||||
| 	struct Snapshot;	 | ||||
| }; | ||||
| 
 | ||||
| namespace GUI { | ||||
| 
 | ||||
| class MainFrame; | ||||
|  | @ -191,6 +196,7 @@ public: | |||
|     void undo_to(int selection); | ||||
|     void redo_to(int selection); | ||||
|     bool undo_redo_string_getter(const bool is_undo, int idx, const char** out_text); | ||||
|     const Slic3r::UndoRedo::Stack& undo_redo_stack() const; | ||||
| 
 | ||||
|     void on_extruders_change(int extruders_count); | ||||
|     void on_config_change(const DynamicPrintConfig &config); | ||||
|  |  | |||
|  | @ -2,6 +2,7 @@ | |||
| #include "I18N.hpp" | ||||
| #include "3DScene.hpp" | ||||
| #include "GUI.hpp" | ||||
| #include "../Utils/UndoRedo.hpp" | ||||
| 
 | ||||
| #include <string> | ||||
| 
 | ||||
|  | @ -10,6 +11,14 @@ | |||
| #include "GUI_App.hpp" | ||||
| #include "wxExtensions.hpp" | ||||
| 
 | ||||
| #ifdef _WIN32 | ||||
| 	// The standard Windows includes.
 | ||||
| 	#define WIN32_LEAN_AND_MEAN | ||||
| 	#define NOMINMAX | ||||
| 	#include <Windows.h> | ||||
| 	#include <psapi.h> | ||||
| #endif /* _WIN32 */ | ||||
| 
 | ||||
| namespace Slic3r {  | ||||
| namespace GUI { | ||||
| 
 | ||||
|  | @ -36,10 +45,37 @@ std::string get_main_info(bool format_as_html) | |||
|         "System Version:      " | ||||
| #endif | ||||
|         << b_end << wxPlatformInfo::Get().GetOperatingSystemDescription() << line_end; | ||||
|     out << b_start << "Total RAM size [MB]: "  << b_end << Slic3r::format_memsize_MB(Slic3r::total_physical_memory()); | ||||
| 
 | ||||
|     return out.str(); | ||||
| } | ||||
| 
 | ||||
| std::string get_mem_info(bool format_as_html) | ||||
| { | ||||
|     std::stringstream out; | ||||
| 
 | ||||
|     std::string b_start  = format_as_html ? "<b>"  : ""; | ||||
|     std::string b_end    = format_as_html ? "</b>" : ""; | ||||
|     std::string line_end = format_as_html ? "<br>" : "\n"; | ||||
| 
 | ||||
|     const Slic3r::UndoRedo::Stack &stack = wxGetApp().plater()->undo_redo_stack(); | ||||
|     out << b_start << "RAM size reserved for the Undo / Redo stack [MB]: "  << b_end << Slic3r::format_memsize_MB(stack.get_memory_limit()) << line_end; | ||||
|     out << b_start << "RAM size occupied by the Undo / Redo stack  [MB]: "  << b_end << Slic3r::format_memsize_MB(stack.memsize()) << line_end << line_end; | ||||
| 
 | ||||
| #ifdef _WIN32 | ||||
|    	HANDLE hProcess = ::OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, ::GetCurrentProcessId()); | ||||
|     if (hProcess != nullptr) { | ||||
|         PROCESS_MEMORY_COUNTERS_EX pmc; | ||||
|         if (GetProcessMemoryInfo(hProcess, (PROCESS_MEMORY_COUNTERS*)&pmc, sizeof(pmc))) | ||||
| 			out << b_start << "WorkingSet     [MB]: "   << b_end << format_memsize_MB(pmc.WorkingSetSize) << line_end | ||||
| 				<< b_start << "PrivateBytes   [MB]: " << b_end << format_memsize_MB(pmc.PrivateUsage) << line_end | ||||
| 				<< b_start << "Pagefile(peak) [MB]: " << b_end << format_memsize_MB(pmc.PagefileUsage) << "(" << format_memsize_MB(pmc.PeakPagefileUsage) << ")" << line_end; | ||||
|         CloseHandle(hProcess); | ||||
|     } | ||||
| #endif | ||||
|     return out.str(); | ||||
| } | ||||
| 
 | ||||
| SysInfoDialog::SysInfoDialog() | ||||
|     : DPIDialog(NULL, wxID_ANY, wxString(SLIC3R_APP_NAME) + " - " + _(L("System Information")), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER) | ||||
| { | ||||
|  | @ -111,7 +147,7 @@ SysInfoDialog::SysInfoDialog() | |||
|             "</font>" | ||||
|             "</body>" | ||||
|             "</html>", bgr_clr_str, text_clr_str, text_clr_str, | ||||
|             _3DScene::get_gl_info(true, true)); | ||||
|             get_mem_info(true) + "<br>" + _3DScene::get_gl_info(true, true)); | ||||
|         m_opengl_info_html->SetPage(text); | ||||
|         main_sizer->Add(m_opengl_info_html, 1, wxEXPAND | wxBOTTOM, 15); | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri