mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	ENABLE_GCODE_VIEWER -> Estimated print time statistics moved from PrintStatistics to GCodeProcessor
This commit is contained in:
		
							parent
							
								
									69a0a1c96e
								
							
						
					
					
						commit
						5249b3e018
					
				
					 7 changed files with 227 additions and 258 deletions
				
			
		|  | @ -775,12 +775,9 @@ void GCode::do_export(Print* print, const char* path, GCodePreviewData* preview_ | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| #if ENABLE_GCODE_VIEWER | #if ENABLE_GCODE_VIEWER | ||||||
|     print->m_print_statistics.clear_time_estimates(); |  | ||||||
|     m_processor.process_file(path_tmp); |     m_processor.process_file(path_tmp); | ||||||
|     if (result != nullptr) { |     if (result != nullptr) | ||||||
|         *result = std::move(m_processor.extract_result()); |         *result = std::move(m_processor.extract_result()); | ||||||
|         m_processor.update_print_stats_estimated_times(print->m_print_statistics); |  | ||||||
|     } |  | ||||||
| #endif // ENABLE_GCODE_VIEWER
 | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| 
 | 
 | ||||||
|     GCodeTimeEstimator::PostProcessData normal_data = m_normal_time_estimator.get_post_process_data(); |     GCodeTimeEstimator::PostProcessData normal_data = m_normal_time_estimator.get_post_process_data(); | ||||||
|  |  | ||||||
|  | @ -570,31 +570,13 @@ void GCodeProcessor::process_file(const std::string& filename) | ||||||
|             gcode_time.times.push_back({ CustomGCode::ColorChange, gcode_time.cache }); |             gcode_time.times.push_back({ CustomGCode::ColorChange, gcode_time.cache }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     update_estimated_times_stats(); | ||||||
|  | 
 | ||||||
| #if ENABLE_GCODE_VIEWER_STATISTICS | #if ENABLE_GCODE_VIEWER_STATISTICS | ||||||
|     m_result.time = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::high_resolution_clock::now() - start_time).count(); |     m_result.time = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::high_resolution_clock::now() - start_time).count(); | ||||||
| #endif // ENABLE_GCODE_VIEWER_STATISTICS
 | #endif // ENABLE_GCODE_VIEWER_STATISTICS
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GCodeProcessor::update_print_stats_estimated_times(PrintStatistics& print_statistics) |  | ||||||
| { |  | ||||||
|     print_statistics.estimated_normal_print_time = get_time(GCodeProcessor::ETimeMode::Normal); |  | ||||||
|     print_statistics.estimated_normal_custom_gcode_print_times = get_custom_gcode_times(GCodeProcessor::ETimeMode::Normal, true); |  | ||||||
|     print_statistics.estimated_normal_moves_times = get_moves_time(GCodeProcessor::ETimeMode::Normal); |  | ||||||
|     print_statistics.estimated_normal_roles_times = get_roles_time(GCodeProcessor::ETimeMode::Normal); |  | ||||||
|     if (m_time_processor.machines[static_cast<size_t>(GCodeProcessor::ETimeMode::Stealth)].enabled) { |  | ||||||
|         print_statistics.estimated_silent_print_time = get_time(GCodeProcessor::ETimeMode::Stealth); |  | ||||||
|         print_statistics.estimated_silent_custom_gcode_print_times = get_custom_gcode_times(GCodeProcessor::ETimeMode::Stealth, true); |  | ||||||
|         print_statistics.estimated_silent_moves_times = get_moves_time(GCodeProcessor::ETimeMode::Stealth); |  | ||||||
|         print_statistics.estimated_silent_roles_times = get_roles_time(GCodeProcessor::ETimeMode::Stealth); |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         print_statistics.estimated_silent_print_time = 0.0f; |  | ||||||
|         print_statistics.estimated_silent_custom_gcode_print_times.clear(); |  | ||||||
|         print_statistics.estimated_silent_moves_times.clear(); |  | ||||||
|         print_statistics.estimated_silent_roles_times.clear(); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| float GCodeProcessor::get_time(ETimeMode mode) const | float GCodeProcessor::get_time(ETimeMode mode) const | ||||||
| { | { | ||||||
|     return (mode < ETimeMode::Count) ? m_time_processor.machines[static_cast<size_t>(mode)].time : 0.0f; |     return (mode < ETimeMode::Count) ? m_time_processor.machines[static_cast<size_t>(mode)].time : 0.0f; | ||||||
|  | @ -620,7 +602,7 @@ std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> GCodeProcesso | ||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::vector<std::pair<GCodeProcessor::EMoveType, float>> GCodeProcessor::get_moves_time(ETimeMode mode) const | std::vector<std::pair<EMoveType, float>> GCodeProcessor::get_moves_time(ETimeMode mode) const | ||||||
| { | { | ||||||
|     std::vector<std::pair<EMoveType, float>> ret; |     std::vector<std::pair<EMoveType, float>> ret; | ||||||
|     if (mode < ETimeMode::Count) { |     if (mode < ETimeMode::Count) { | ||||||
|  | @ -1892,6 +1874,23 @@ void GCodeProcessor::simulate_st_synchronize(float additional_time) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void GCodeProcessor::update_estimated_times_stats() | ||||||
|  | { | ||||||
|  |     auto update_mode = [this](GCodeProcessor::ETimeMode mode) { | ||||||
|  |         PrintEstimatedTimeStatistics::Mode& data = m_result.time_statistics.modes[static_cast<size_t>(mode)]; | ||||||
|  |         data.time = get_time(mode); | ||||||
|  |         data.custom_gcode_times = get_custom_gcode_times(mode, true); | ||||||
|  |         data.moves_times = get_moves_time(mode); | ||||||
|  |         data.roles_times = get_roles_time(mode); | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     update_mode(GCodeProcessor::ETimeMode::Normal); | ||||||
|  |     if (m_time_processor.machines[static_cast<size_t>(GCodeProcessor::ETimeMode::Stealth)].enabled) | ||||||
|  |         update_mode(GCodeProcessor::ETimeMode::Stealth); | ||||||
|  |     else | ||||||
|  |         m_result.time_statistics.modes[static_cast<size_t>(GCodeProcessor::ETimeMode::Stealth)].reset(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| } /* namespace Slic3r */ | } /* namespace Slic3r */ | ||||||
| 
 | 
 | ||||||
| #endif // ENABLE_GCODE_VIEWER
 | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|  |  | ||||||
|  | @ -14,7 +14,54 @@ | ||||||
| 
 | 
 | ||||||
| namespace Slic3r { | namespace Slic3r { | ||||||
| 
 | 
 | ||||||
|     struct PrintStatistics; |     enum class EMoveType : unsigned char | ||||||
|  |     { | ||||||
|  |         Noop, | ||||||
|  |         Retract, | ||||||
|  |         Unretract, | ||||||
|  |         Tool_change, | ||||||
|  |         Color_change, | ||||||
|  |         Pause_Print, | ||||||
|  |         Custom_GCode, | ||||||
|  |         Travel, | ||||||
|  |         Extrude, | ||||||
|  |         Count | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     struct PrintEstimatedTimeStatistics | ||||||
|  |     { | ||||||
|  |         enum class ETimeMode : unsigned char | ||||||
|  |         { | ||||||
|  |             Normal, | ||||||
|  |             Stealth, | ||||||
|  |             Count | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         struct Mode | ||||||
|  |         { | ||||||
|  |             float time; | ||||||
|  |             std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> custom_gcode_times; | ||||||
|  |             std::vector<std::pair<EMoveType, float>> moves_times; | ||||||
|  |             std::vector<std::pair<ExtrusionRole, float>> roles_times; | ||||||
|  | 
 | ||||||
|  |             void reset() { | ||||||
|  |                 time = 0.0f; | ||||||
|  |                 custom_gcode_times.clear(); | ||||||
|  |                 moves_times.clear(); | ||||||
|  |                 roles_times.clear(); | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         std::array<Mode, static_cast<size_t>(ETimeMode::Count)> modes; | ||||||
|  | 
 | ||||||
|  |         PrintEstimatedTimeStatistics() { reset(); } | ||||||
|  | 
 | ||||||
|  |         void reset() { | ||||||
|  |             for (auto m : modes) { | ||||||
|  |                 m.reset(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|     class GCodeProcessor |     class GCodeProcessor | ||||||
|     { |     { | ||||||
|  | @ -59,20 +106,6 @@ namespace Slic3r { | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|     public: |     public: | ||||||
|         enum class EMoveType : unsigned char |  | ||||||
|         { |  | ||||||
|             Noop, |  | ||||||
|             Retract, |  | ||||||
|             Unretract, |  | ||||||
|             Tool_change, |  | ||||||
|             Color_change, |  | ||||||
|             Pause_Print, |  | ||||||
|             Custom_GCode, |  | ||||||
|             Travel, |  | ||||||
|             Extrude, |  | ||||||
|             Count |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         struct FeedrateProfile |         struct FeedrateProfile | ||||||
|         { |         { | ||||||
|             float entry{ 0.0f }; // mm/s
 |             float entry{ 0.0f }; // mm/s
 | ||||||
|  | @ -215,6 +248,8 @@ namespace Slic3r { | ||||||
|             Pointfs bed_shape; |             Pointfs bed_shape; | ||||||
|             std::vector<std::string> extruder_colors; |             std::vector<std::string> extruder_colors; | ||||||
| #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | ||||||
|  |             PrintEstimatedTimeStatistics time_statistics; | ||||||
|  | 
 | ||||||
| #if ENABLE_GCODE_VIEWER_STATISTICS | #if ENABLE_GCODE_VIEWER_STATISTICS | ||||||
|             long long time{ 0 }; |             long long time{ 0 }; | ||||||
|             void reset() |             void reset() | ||||||
|  | @ -297,7 +332,6 @@ namespace Slic3r { | ||||||
|         // Process the gcode contained in the file with the given filename
 |         // Process the gcode contained in the file with the given filename
 | ||||||
|         void process_file(const std::string& filename); |         void process_file(const std::string& filename); | ||||||
| 
 | 
 | ||||||
|         void update_print_stats_estimated_times(PrintStatistics& print_statistics); |  | ||||||
|         float get_time(ETimeMode mode) const; |         float get_time(ETimeMode mode) const; | ||||||
|         std::string get_time_dhm(ETimeMode mode) const; |         std::string get_time_dhm(ETimeMode mode) const; | ||||||
|         std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> get_custom_gcode_times(ETimeMode mode, bool include_remaining) const; |         std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> get_custom_gcode_times(ETimeMode mode, bool include_remaining) const; | ||||||
|  | @ -422,6 +456,8 @@ namespace Slic3r { | ||||||
| 
 | 
 | ||||||
|         // Simulates firmware st_synchronize() call
 |         // Simulates firmware st_synchronize() call
 | ||||||
|         void simulate_st_synchronize(float additional_time = 0.0f); |         void simulate_st_synchronize(float additional_time = 0.0f); | ||||||
|  | 
 | ||||||
|  |         void update_estimated_times_stats(); | ||||||
|    }; |    }; | ||||||
| 
 | 
 | ||||||
| } /* namespace Slic3r */ | } /* namespace Slic3r */ | ||||||
|  |  | ||||||
|  | @ -304,22 +304,12 @@ struct PrintStatistics | ||||||
| { | { | ||||||
|     PrintStatistics() { clear(); } |     PrintStatistics() { clear(); } | ||||||
| #if ENABLE_GCODE_VIEWER | #if ENABLE_GCODE_VIEWER | ||||||
|     float                           estimated_normal_print_time; |  | ||||||
|     float                           estimated_silent_print_time; |  | ||||||
| #if ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR | #if ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR | ||||||
|     std::string                     estimated_normal_print_time_str; |     std::string                     estimated_normal_print_time_str; | ||||||
|     std::string                     estimated_silent_print_time_str; |     std::string                     estimated_silent_print_time_str; | ||||||
| #endif // ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR
 |  | ||||||
|     std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> estimated_normal_custom_gcode_print_times; |  | ||||||
|     std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> estimated_silent_custom_gcode_print_times; |  | ||||||
| #if ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR |  | ||||||
|     std::vector<std::pair<CustomGCode::Type, std::pair<std::string, std::string>>> estimated_normal_custom_gcode_print_times_str; |     std::vector<std::pair<CustomGCode::Type, std::pair<std::string, std::string>>> estimated_normal_custom_gcode_print_times_str; | ||||||
|     std::vector<std::pair<CustomGCode::Type, std::pair<std::string, std::string>>> estimated_silent_custom_gcode_print_times_str; |     std::vector<std::pair<CustomGCode::Type, std::pair<std::string, std::string>>> estimated_silent_custom_gcode_print_times_str; | ||||||
| #endif // ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR
 | #endif // ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR
 | ||||||
|     std::vector<std::pair<GCodeProcessor::EMoveType, float>> estimated_normal_moves_times; |  | ||||||
|     std::vector<std::pair<GCodeProcessor::EMoveType, float>> estimated_silent_moves_times; |  | ||||||
|     std::vector<std::pair<ExtrusionRole, float>> estimated_normal_roles_times; |  | ||||||
|     std::vector<std::pair<ExtrusionRole, float>> estimated_silent_roles_times; |  | ||||||
| #else | #else | ||||||
|     std::string                     estimated_normal_print_time; |     std::string                     estimated_normal_print_time; | ||||||
|     std::string                     estimated_silent_print_time; |     std::string                     estimated_silent_print_time; | ||||||
|  | @ -344,7 +334,6 @@ struct PrintStatistics | ||||||
| 
 | 
 | ||||||
|     void clear() { |     void clear() { | ||||||
| #if ENABLE_GCODE_VIEWER | #if ENABLE_GCODE_VIEWER | ||||||
|         clear_time_estimates(); |  | ||||||
| #if ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR | #if ENABLE_GCODE_VIEWER_USE_OLD_TIME_ESTIMATOR | ||||||
|         estimated_normal_print_time_str.clear(); |         estimated_normal_print_time_str.clear(); | ||||||
|         estimated_silent_print_time_str.clear(); |         estimated_silent_print_time_str.clear(); | ||||||
|  | @ -366,19 +355,6 @@ struct PrintStatistics | ||||||
|         total_wipe_tower_filament = 0.; |         total_wipe_tower_filament = 0.; | ||||||
|         filament_stats.clear(); |         filament_stats.clear(); | ||||||
|     } |     } | ||||||
|      |  | ||||||
| #if ENABLE_GCODE_VIEWER |  | ||||||
|     void clear_time_estimates() { |  | ||||||
|         estimated_normal_print_time = 0.0f; |  | ||||||
|         estimated_silent_print_time = 0.0f; |  | ||||||
|         estimated_normal_custom_gcode_print_times.clear(); |  | ||||||
|         estimated_silent_custom_gcode_print_times.clear(); |  | ||||||
|         estimated_normal_moves_times.clear(); |  | ||||||
|         estimated_silent_moves_times.clear(); |  | ||||||
|         estimated_normal_roles_times.clear(); |  | ||||||
|         estimated_silent_roles_times.clear(); |  | ||||||
|     } |  | ||||||
| #endif //ENABLE_GCODE_VIEWER
 |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| typedef std::vector<PrintObject*> PrintObjectPtrs; | typedef std::vector<PrintObject*> PrintObjectPtrs; | ||||||
|  |  | ||||||
|  | @ -32,12 +32,12 @@ | ||||||
| namespace Slic3r { | namespace Slic3r { | ||||||
| namespace GUI { | namespace GUI { | ||||||
| 
 | 
 | ||||||
| static unsigned char buffer_id(GCodeProcessor::EMoveType type) { | static unsigned char buffer_id(EMoveType type) { | ||||||
|     return static_cast<unsigned char>(type) - static_cast<unsigned char>(GCodeProcessor::EMoveType::Retract); |     return static_cast<unsigned char>(type) - static_cast<unsigned char>(EMoveType::Retract); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static GCodeProcessor::EMoveType buffer_type(unsigned char id) { | static EMoveType buffer_type(unsigned char id) { | ||||||
|     return static_cast<GCodeProcessor::EMoveType>(static_cast<unsigned char>(GCodeProcessor::EMoveType::Retract) + id); |     return static_cast<EMoveType>(static_cast<unsigned char>(EMoveType::Retract) + id); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::array<float, 3> decode_color(const std::string& color) { | std::array<float, 3> decode_color(const std::string& color) { | ||||||
|  | @ -92,19 +92,19 @@ bool GCodeViewer::Path::matches(const GCodeProcessor::MoveVertex& move) const | ||||||
| { | { | ||||||
|     switch (move.type) |     switch (move.type) | ||||||
|     { |     { | ||||||
|     case GCodeProcessor::EMoveType::Tool_change: |     case EMoveType::Tool_change: | ||||||
|     case GCodeProcessor::EMoveType::Color_change: |     case EMoveType::Color_change: | ||||||
|     case GCodeProcessor::EMoveType::Pause_Print: |     case EMoveType::Pause_Print: | ||||||
|     case GCodeProcessor::EMoveType::Custom_GCode: |     case EMoveType::Custom_GCode: | ||||||
|     case GCodeProcessor::EMoveType::Retract: |     case EMoveType::Retract: | ||||||
|     case GCodeProcessor::EMoveType::Unretract: |     case EMoveType::Unretract: | ||||||
|     case GCodeProcessor::EMoveType::Extrude: |     case EMoveType::Extrude: | ||||||
|     { |     { | ||||||
|         return type == move.type && role == move.extrusion_role && height == move.height && width == move.width && |         return type == move.type && role == move.extrusion_role && height == move.height && width == move.width && | ||||||
|             feedrate == move.feedrate && fan_speed == move.fan_speed && volumetric_rate == move.volumetric_rate() && |             feedrate == move.feedrate && fan_speed == move.fan_speed && volumetric_rate == move.volumetric_rate() && | ||||||
|             extruder_id == move.extruder_id && cp_color_id == move.cp_color_id; |             extruder_id == move.extruder_id && cp_color_id == move.cp_color_id; | ||||||
|     } |     } | ||||||
|     case GCodeProcessor::EMoveType::Travel: |     case EMoveType::Travel: | ||||||
|     { |     { | ||||||
|         return type == move.type && feedrate == move.feedrate && extruder_id == move.extruder_id && cp_color_id == move.cp_color_id; |         return type == move.type && feedrate == move.feedrate && extruder_id == move.extruder_id && cp_color_id == move.cp_color_id; | ||||||
|     } |     } | ||||||
|  | @ -198,9 +198,7 @@ void GCodeViewer::SequentialView::Marker::render() const | ||||||
|     ImGui::PushStyleVar(ImGuiStyleVar_WindowRounding, 0.0f); |     ImGui::PushStyleVar(ImGuiStyleVar_WindowRounding, 0.0f); | ||||||
|     ImGui::SetNextWindowBgAlpha(0.25f); |     ImGui::SetNextWindowBgAlpha(0.25f); | ||||||
|     imgui.begin(std::string("ToolPosition"), ImGuiWindowFlags_AlwaysAutoResize | ImGuiWindowFlags_NoDecoration | ImGuiWindowFlags_NoMove); |     imgui.begin(std::string("ToolPosition"), ImGuiWindowFlags_AlwaysAutoResize | ImGuiWindowFlags_NoDecoration | ImGuiWindowFlags_NoMove); | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, _u8L("Tool position") + ":"); | ||||||
|     imgui.text(_u8L("Tool position") + ":"); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(); |     ImGui::SameLine(); | ||||||
|     char buf[1024]; |     char buf[1024]; | ||||||
|     sprintf(buf, "X: %.2f, Y: %.2f, Z: %.2f", m_world_position(0), m_world_position(1), m_world_position(2)); |     sprintf(buf, "X: %.2f, Y: %.2f, Z: %.2f", m_world_position(0), m_world_position(1), m_world_position(2)); | ||||||
|  | @ -274,18 +272,18 @@ bool GCodeViewer::init() | ||||||
|         switch (buffer_type(i)) |         switch (buffer_type(i)) | ||||||
|         { |         { | ||||||
|         default: { break; } |         default: { break; } | ||||||
|         case GCodeProcessor::EMoveType::Tool_change: |         case EMoveType::Tool_change: | ||||||
|         case GCodeProcessor::EMoveType::Color_change: |         case EMoveType::Color_change: | ||||||
|         case GCodeProcessor::EMoveType::Pause_Print: |         case EMoveType::Pause_Print: | ||||||
|         case GCodeProcessor::EMoveType::Custom_GCode: |         case EMoveType::Custom_GCode: | ||||||
|         case GCodeProcessor::EMoveType::Retract: |         case EMoveType::Retract: | ||||||
|         case GCodeProcessor::EMoveType::Unretract: |         case EMoveType::Unretract: | ||||||
|         { |         { | ||||||
|             m_buffers[i].vertices.format = VBuffer::EFormat::Position; |             m_buffers[i].vertices.format = VBuffer::EFormat::Position; | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         case GCodeProcessor::EMoveType::Extrude: |         case EMoveType::Extrude: | ||||||
|         case GCodeProcessor::EMoveType::Travel: |         case EMoveType::Travel: | ||||||
|         { |         { | ||||||
|             m_buffers[i].vertices.format = VBuffer::EFormat::PositionNormal; |             m_buffers[i].vertices.format = VBuffer::EFormat::PositionNormal; | ||||||
|             break; |             break; | ||||||
|  | @ -293,7 +291,7 @@ bool GCodeViewer::init() | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Extrude, true); |     set_toolpath_move_type_visible(EMoveType::Extrude, true); | ||||||
|     m_sequential_view.marker.init(); |     m_sequential_view.marker.init(); | ||||||
|     init_shaders(); |     init_shaders(); | ||||||
| 
 | 
 | ||||||
|  | @ -340,6 +338,8 @@ void GCodeViewer::load(const GCodeProcessor::Result& gcode_result, const Print& | ||||||
|         wxGetApp().plater()->set_bed_shape(bed_shape, "", "", true); |         wxGetApp().plater()->set_bed_shape(bed_shape, "", "", true); | ||||||
|     } |     } | ||||||
| #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | ||||||
|  | 
 | ||||||
|  |     m_time_statistics = gcode_result.time_statistics; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GCodeViewer::refresh(const GCodeProcessor::Result& gcode_result, const std::vector<std::string>& str_tool_colors) | void GCodeViewer::refresh(const GCodeProcessor::Result& gcode_result, const std::vector<std::string>& str_tool_colors) | ||||||
|  | @ -371,7 +371,7 @@ void GCodeViewer::refresh(const GCodeProcessor::Result& gcode_result, const std: | ||||||
| 
 | 
 | ||||||
|         switch (curr.type) |         switch (curr.type) | ||||||
|         { |         { | ||||||
|         case GCodeProcessor::EMoveType::Extrude: |         case EMoveType::Extrude: | ||||||
|         { |         { | ||||||
|             m_extrusions.ranges.height.update_from(curr.height); |             m_extrusions.ranges.height.update_from(curr.height); | ||||||
|             m_extrusions.ranges.width.update_from(curr.width); |             m_extrusions.ranges.width.update_from(curr.width); | ||||||
|  | @ -379,7 +379,7 @@ void GCodeViewer::refresh(const GCodeProcessor::Result& gcode_result, const std: | ||||||
|             m_extrusions.ranges.volumetric_rate.update_from(curr.volumetric_rate()); |             m_extrusions.ranges.volumetric_rate.update_from(curr.volumetric_rate()); | ||||||
|             [[fallthrough]]; |             [[fallthrough]]; | ||||||
|         } |         } | ||||||
|         case GCodeProcessor::EMoveType::Travel: |         case EMoveType::Travel: | ||||||
|         { |         { | ||||||
|             if (m_buffers[buffer_id(curr.type)].visible) |             if (m_buffers[buffer_id(curr.type)].visible) | ||||||
|                 m_extrusions.ranges.feedrate.update_from(curr.feedrate); |                 m_extrusions.ranges.feedrate.update_from(curr.feedrate); | ||||||
|  | @ -415,6 +415,7 @@ void GCodeViewer::reset() | ||||||
|     m_layers_zs = std::vector<double>(); |     m_layers_zs = std::vector<double>(); | ||||||
|     m_layers_z_range = { 0.0, 0.0 }; |     m_layers_z_range = { 0.0, 0.0 }; | ||||||
|     m_roles = std::vector<ExtrusionRole>(); |     m_roles = std::vector<ExtrusionRole>(); | ||||||
|  |     m_time_statistics.reset(); | ||||||
| 
 | 
 | ||||||
| #if ENABLE_GCODE_VIEWER_STATISTICS | #if ENABLE_GCODE_VIEWER_STATISTICS | ||||||
|     m_statistics.reset_all(); |     m_statistics.reset_all(); | ||||||
|  | @ -452,13 +453,13 @@ void GCodeViewer::render() const | ||||||
| #endif // ENABLE_GCODE_VIEWER_SHADERS_EDITOR
 | #endif // ENABLE_GCODE_VIEWER_SHADERS_EDITOR
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool GCodeViewer::is_toolpath_move_type_visible(GCodeProcessor::EMoveType type) const | bool GCodeViewer::is_toolpath_move_type_visible(EMoveType type) const | ||||||
| { | { | ||||||
|     size_t id = static_cast<size_t>(buffer_id(type)); |     size_t id = static_cast<size_t>(buffer_id(type)); | ||||||
|     return (id < m_buffers.size()) ? m_buffers[id].visible : false; |     return (id < m_buffers.size()) ? m_buffers[id].visible : false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GCodeViewer::set_toolpath_move_type_visible(GCodeProcessor::EMoveType type, bool visible) | void GCodeViewer::set_toolpath_move_type_visible(EMoveType type, bool visible) | ||||||
| { | { | ||||||
|     size_t id = static_cast<size_t>(buffer_id(type)); |     size_t id = static_cast<size_t>(buffer_id(type)); | ||||||
|     if (id < m_buffers.size()) |     if (id < m_buffers.size()) | ||||||
|  | @ -472,13 +473,13 @@ unsigned int GCodeViewer::get_options_visibility_flags() const | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     unsigned int flags = 0; |     unsigned int flags = 0; | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Travel), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Travel)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Travel), is_toolpath_move_type_visible(EMoveType::Travel)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Retractions), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Retract)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Retractions), is_toolpath_move_type_visible(EMoveType::Retract)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Unretractions), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Unretract)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Unretractions), is_toolpath_move_type_visible(EMoveType::Unretract)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::ToolChanges), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Tool_change)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::ToolChanges), is_toolpath_move_type_visible(EMoveType::Tool_change)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::ColorChanges), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Color_change)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::ColorChanges), is_toolpath_move_type_visible(EMoveType::Color_change)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::PausePrints), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Pause_Print)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::PausePrints), is_toolpath_move_type_visible(EMoveType::Pause_Print)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::CustomGCodes), is_toolpath_move_type_visible(GCodeProcessor::EMoveType::Custom_GCode)); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::CustomGCodes), is_toolpath_move_type_visible(EMoveType::Custom_GCode)); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Shells), m_shells.visible); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Shells), m_shells.visible); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::ToolMarker), m_sequential_view.marker.is_visible()); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::ToolMarker), m_sequential_view.marker.is_visible()); | ||||||
|     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Legend), is_legend_enabled()); |     flags = set_flag(flags, static_cast<unsigned int>(Preview::OptionType::Legend), is_legend_enabled()); | ||||||
|  | @ -494,13 +495,13 @@ void GCodeViewer::set_options_visibility_from_flags(unsigned int flags) | ||||||
|         return (flags & (1 << flag)) != 0; |         return (flags & (1 << flag)) != 0; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Travel, is_flag_set(static_cast<unsigned int>(Preview::OptionType::Travel))); |     set_toolpath_move_type_visible(EMoveType::Travel, is_flag_set(static_cast<unsigned int>(Preview::OptionType::Travel))); | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Retract, is_flag_set(static_cast<unsigned int>(Preview::OptionType::Retractions))); |     set_toolpath_move_type_visible(EMoveType::Retract, is_flag_set(static_cast<unsigned int>(Preview::OptionType::Retractions))); | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Unretract, is_flag_set(static_cast<unsigned int>(Preview::OptionType::Unretractions))); |     set_toolpath_move_type_visible(EMoveType::Unretract, is_flag_set(static_cast<unsigned int>(Preview::OptionType::Unretractions))); | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Tool_change, is_flag_set(static_cast<unsigned int>(Preview::OptionType::ToolChanges))); |     set_toolpath_move_type_visible(EMoveType::Tool_change, is_flag_set(static_cast<unsigned int>(Preview::OptionType::ToolChanges))); | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Color_change, is_flag_set(static_cast<unsigned int>(Preview::OptionType::ColorChanges))); |     set_toolpath_move_type_visible(EMoveType::Color_change, is_flag_set(static_cast<unsigned int>(Preview::OptionType::ColorChanges))); | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Pause_Print, is_flag_set(static_cast<unsigned int>(Preview::OptionType::PausePrints))); |     set_toolpath_move_type_visible(EMoveType::Pause_Print, is_flag_set(static_cast<unsigned int>(Preview::OptionType::PausePrints))); | ||||||
|     set_toolpath_move_type_visible(GCodeProcessor::EMoveType::Custom_GCode, is_flag_set(static_cast<unsigned int>(Preview::OptionType::CustomGCodes))); |     set_toolpath_move_type_visible(EMoveType::Custom_GCode, is_flag_set(static_cast<unsigned int>(Preview::OptionType::CustomGCodes))); | ||||||
|     m_shells.visible = is_flag_set(static_cast<unsigned int>(Preview::OptionType::Shells)); |     m_shells.visible = is_flag_set(static_cast<unsigned int>(Preview::OptionType::Shells)); | ||||||
|     m_sequential_view.marker.set_visible(is_flag_set(static_cast<unsigned int>(Preview::OptionType::ToolMarker))); |     m_sequential_view.marker.set_visible(is_flag_set(static_cast<unsigned int>(Preview::OptionType::ToolMarker))); | ||||||
|     enable_legend(is_flag_set(static_cast<unsigned int>(Preview::OptionType::Legend))); |     enable_legend(is_flag_set(static_cast<unsigned int>(Preview::OptionType::Legend))); | ||||||
|  | @ -537,7 +538,7 @@ void GCodeViewer::export_toolpaths_to_obj(const char* filename) const | ||||||
|     wxBusyCursor busy; |     wxBusyCursor busy; | ||||||
| 
 | 
 | ||||||
|     // the data needed is contained into the Extrude TBuffer
 |     // the data needed is contained into the Extrude TBuffer
 | ||||||
|     const TBuffer& buffer = m_buffers[buffer_id(GCodeProcessor::EMoveType::Extrude)]; |     const TBuffer& buffer = m_buffers[buffer_id(EMoveType::Extrude)]; | ||||||
|     if (buffer.vertices.id == 0 || buffer.indices.id == 0) |     if (buffer.vertices.id == 0 || buffer.indices.id == 0) | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|  | @ -805,21 +806,21 @@ void GCodeViewer::export_toolpaths_to_obj(const char* filename) const | ||||||
| 
 | 
 | ||||||
| void GCodeViewer::init_shaders() | void GCodeViewer::init_shaders() | ||||||
| { | { | ||||||
|     unsigned char begin_id = buffer_id(GCodeProcessor::EMoveType::Retract); |     unsigned char begin_id = buffer_id(EMoveType::Retract); | ||||||
|     unsigned char end_id = buffer_id(GCodeProcessor::EMoveType::Count); |     unsigned char end_id = buffer_id(EMoveType::Count); | ||||||
| 
 | 
 | ||||||
|     bool is_glsl_120 = wxGetApp().is_glsl_version_greater_or_equal_to(1, 20); |     bool is_glsl_120 = wxGetApp().is_glsl_version_greater_or_equal_to(1, 20); | ||||||
|     for (unsigned char i = begin_id; i < end_id; ++i) { |     for (unsigned char i = begin_id; i < end_id; ++i) { | ||||||
|         switch (buffer_type(i)) |         switch (buffer_type(i)) | ||||||
|         { |         { | ||||||
|         case GCodeProcessor::EMoveType::Tool_change:  { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } |         case EMoveType::Tool_change:  { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Color_change: { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } |         case EMoveType::Color_change: { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Pause_Print:  { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } |         case EMoveType::Pause_Print:  { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Custom_GCode: { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } |         case EMoveType::Custom_GCode: { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Retract:      { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } |         case EMoveType::Retract:      { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Unretract:    { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } |         case EMoveType::Unretract:    { m_buffers[i].shader = is_glsl_120 ? "options_120_flat" : "options_110"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Extrude:      { m_buffers[i].shader = "toolpaths"; break; } |         case EMoveType::Extrude:      { m_buffers[i].shader = "toolpaths"; break; } | ||||||
|         case GCodeProcessor::EMoveType::Travel:       { m_buffers[i].shader = "toolpaths"; break; } |         case EMoveType::Travel:       { m_buffers[i].shader = "toolpaths"; break; } | ||||||
|         default: { break; } |         default: { break; } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | @ -846,14 +847,17 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
|             m_paths_bounding_box.merge(move.position.cast<double>()); |             m_paths_bounding_box.merge(move.position.cast<double>()); | ||||||
|         else { |         else { | ||||||
| #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | ||||||
|             if (move.type == GCodeProcessor::EMoveType::Extrude && move.width != 0.0f && move.height != 0.0f) |             if (move.type == EMoveType::Extrude && move.width != 0.0f && move.height != 0.0f) | ||||||
|                 m_paths_bounding_box.merge(move.position.cast<double>()); |                 m_paths_bounding_box.merge(move.position.cast<double>()); | ||||||
| #if ENABLE_GCODE_VIEWER_AS_STATE | #if ENABLE_GCODE_VIEWER_AS_STATE | ||||||
|         } |         } | ||||||
| #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // max bounding box
 |     // add origin
 | ||||||
|  |     m_paths_bounding_box.merge(Vec3d::Zero()); | ||||||
|  | 
 | ||||||
|  |     // max bounding box (account for tool marker)
 | ||||||
|     m_max_bounding_box = m_paths_bounding_box; |     m_max_bounding_box = m_paths_bounding_box; | ||||||
|     m_max_bounding_box.merge(m_paths_bounding_box.max + m_sequential_view.marker.get_bounding_box().size()[2] * Vec3d::UnitZ()); |     m_max_bounding_box.merge(m_paths_bounding_box.max + m_sequential_view.marker.get_bounding_box().size()[2] * Vec3d::UnitZ()); | ||||||
| 
 | 
 | ||||||
|  | @ -875,12 +879,12 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
| 
 | 
 | ||||||
|         switch (curr.type) |         switch (curr.type) | ||||||
|         { |         { | ||||||
|         case GCodeProcessor::EMoveType::Tool_change: |         case EMoveType::Tool_change: | ||||||
|         case GCodeProcessor::EMoveType::Color_change: |         case EMoveType::Color_change: | ||||||
|         case GCodeProcessor::EMoveType::Pause_Print: |         case EMoveType::Pause_Print: | ||||||
|         case GCodeProcessor::EMoveType::Custom_GCode: |         case EMoveType::Custom_GCode: | ||||||
|         case GCodeProcessor::EMoveType::Retract: |         case EMoveType::Retract: | ||||||
|         case GCodeProcessor::EMoveType::Unretract: |         case EMoveType::Unretract: | ||||||
|         { |         { | ||||||
|             for (int j = 0; j < 3; ++j) { |             for (int j = 0; j < 3; ++j) { | ||||||
|                 buffer_vertices.push_back(curr.position[j]); |                 buffer_vertices.push_back(curr.position[j]); | ||||||
|  | @ -889,8 +893,8 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
|             buffer_indices.push_back(static_cast<unsigned int>(buffer_indices.size())); |             buffer_indices.push_back(static_cast<unsigned int>(buffer_indices.size())); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         case GCodeProcessor::EMoveType::Extrude: |         case EMoveType::Extrude: | ||||||
|         case GCodeProcessor::EMoveType::Travel: |         case EMoveType::Travel: | ||||||
|         { |         { | ||||||
|             // x component of the normal to the current segment (the normal is parallel to the XY plane)
 |             // x component of the normal to the current segment (the normal is parallel to the XY plane)
 | ||||||
|             float normal_x = (curr.position - prev.position).normalized()[1]; |             float normal_x = (curr.position - prev.position).normalized()[1]; | ||||||
|  | @ -979,7 +983,7 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
|     // layers zs / roles / extruder ids / cp color ids -> extract from result
 |     // layers zs / roles / extruder ids / cp color ids -> extract from result
 | ||||||
|     for (size_t i = 0; i < m_vertices_count; ++i) { |     for (size_t i = 0; i < m_vertices_count; ++i) { | ||||||
|         const GCodeProcessor::MoveVertex& move = gcode_result.moves[i]; |         const GCodeProcessor::MoveVertex& move = gcode_result.moves[i]; | ||||||
|         if (move.type == GCodeProcessor::EMoveType::Extrude) |         if (move.type == EMoveType::Extrude) | ||||||
|             m_layers_zs.emplace_back(static_cast<double>(move.position[2])); |             m_layers_zs.emplace_back(static_cast<double>(move.position[2])); | ||||||
| 
 | 
 | ||||||
|         m_extruder_ids.emplace_back(move.extruder_id); |         m_extruder_ids.emplace_back(move.extruder_id); | ||||||
|  | @ -1127,14 +1131,14 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool | ||||||
| 
 | 
 | ||||||
|         for (size_t i = 0; i < buffer.paths.size(); ++i) { |         for (size_t i = 0; i < buffer.paths.size(); ++i) { | ||||||
|             const Path& path = buffer.paths[i]; |             const Path& path = buffer.paths[i]; | ||||||
|             if (path.type == GCodeProcessor::EMoveType::Travel) { |             if (path.type == EMoveType::Travel) { | ||||||
|                 if (!is_travel_in_z_range(i)) |                 if (!is_travel_in_z_range(i)) | ||||||
|                     continue; |                     continue; | ||||||
|             } |             } | ||||||
|             else if (!is_in_z_range(path)) |             else if (!is_in_z_range(path)) | ||||||
|                 continue; |                 continue; | ||||||
| 
 | 
 | ||||||
|             if (path.type == GCodeProcessor::EMoveType::Extrude && !is_visible(path)) |             if (path.type == EMoveType::Extrude && !is_visible(path)) | ||||||
|                 continue; |                 continue; | ||||||
| 
 | 
 | ||||||
|             // store valid path
 |             // store valid path
 | ||||||
|  | @ -1156,7 +1160,7 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool | ||||||
|         for (const Path& path : buffer.paths) { |         for (const Path& path : buffer.paths) { | ||||||
|             if (path.first.s_id <= m_sequential_view.current.last && m_sequential_view.current.last <= path.last.s_id) { |             if (path.first.s_id <= m_sequential_view.current.last && m_sequential_view.current.last <= path.last.s_id) { | ||||||
|                 size_t offset = m_sequential_view.current.last - path.first.s_id; |                 size_t offset = m_sequential_view.current.last - path.first.s_id; | ||||||
|                 if (offset > 0 && (path.type == GCodeProcessor::EMoveType::Travel || path.type == GCodeProcessor::EMoveType::Extrude)) |                 if (offset > 0 && (path.type == EMoveType::Travel || path.type == EMoveType::Extrude)) | ||||||
|                     offset = 1 + 2 * (offset - 1); |                     offset = 1 + 2 * (offset - 1); | ||||||
| 
 | 
 | ||||||
|                 offset += path.first.i_id; |                 offset += path.first.i_id; | ||||||
|  | @ -1182,8 +1186,8 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool | ||||||
|         Color color; |         Color color; | ||||||
|         switch (path.type) |         switch (path.type) | ||||||
|         { |         { | ||||||
|         case GCodeProcessor::EMoveType::Extrude: { color = extrusion_color(path); break; } |         case EMoveType::Extrude: { color = extrusion_color(path); break; } | ||||||
|         case GCodeProcessor::EMoveType::Travel: { color = (m_view_type == EViewType::Feedrate || m_view_type == EViewType::Tool || m_view_type == EViewType::ColorPrint) ? extrusion_color(path) : travel_color(path); break; } |         case EMoveType::Travel: { color = (m_view_type == EViewType::Feedrate || m_view_type == EViewType::Tool || m_view_type == EViewType::ColorPrint) ? extrusion_color(path) : travel_color(path); break; } | ||||||
|         default: { color = { 0.0f, 0.0f, 0.0f }; break; } |         default: { color = { 0.0f, 0.0f, 0.0f }; break; } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -1195,7 +1199,7 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         unsigned int size = std::min(m_sequential_view.current.last, path.last.s_id) - std::max(m_sequential_view.current.first, path.first.s_id) + 1; |         unsigned int size = std::min(m_sequential_view.current.last, path.last.s_id) - std::max(m_sequential_view.current.first, path.first.s_id) + 1; | ||||||
|         if (path.type == GCodeProcessor::EMoveType::Extrude || path.type == GCodeProcessor::EMoveType::Travel) |         if (path.type == EMoveType::Extrude || path.type == EMoveType::Travel) | ||||||
|             size = 2 * (size - 1); |             size = 2 * (size - 1); | ||||||
| 
 | 
 | ||||||
|         it->sizes.push_back(size); |         it->sizes.push_back(size); | ||||||
|  | @ -1278,8 +1282,8 @@ void GCodeViewer::render_toolpaths() const | ||||||
| 
 | 
 | ||||||
|     glsafe(::glLineWidth(static_cast<GLfloat>(line_width(zoom)))); |     glsafe(::glLineWidth(static_cast<GLfloat>(line_width(zoom)))); | ||||||
| 
 | 
 | ||||||
|     unsigned char begin_id = buffer_id(GCodeProcessor::EMoveType::Retract); |     unsigned char begin_id = buffer_id(EMoveType::Retract); | ||||||
|     unsigned char end_id = buffer_id(GCodeProcessor::EMoveType::Count); |     unsigned char end_id = buffer_id(EMoveType::Count); | ||||||
| 
 | 
 | ||||||
|     for (unsigned char i = begin_id; i < end_id; ++i) { |     for (unsigned char i = begin_id; i < end_id; ++i) { | ||||||
|         const TBuffer& buffer = m_buffers[i]; |         const TBuffer& buffer = m_buffers[i]; | ||||||
|  | @ -1302,14 +1306,14 @@ void GCodeViewer::render_toolpaths() const | ||||||
|             switch (buffer_type(i)) |             switch (buffer_type(i)) | ||||||
|             { |             { | ||||||
|             default: { break; } |             default: { break; } | ||||||
|             case GCodeProcessor::EMoveType::Tool_change:  { render_as_points(buffer, EOptionsColors::ToolChanges, *shader); break; } |             case EMoveType::Tool_change:  { render_as_points(buffer, EOptionsColors::ToolChanges, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Color_change: { render_as_points(buffer, EOptionsColors::ColorChanges, *shader); break; } |             case EMoveType::Color_change: { render_as_points(buffer, EOptionsColors::ColorChanges, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Pause_Print:  { render_as_points(buffer, EOptionsColors::PausePrints, *shader); break; } |             case EMoveType::Pause_Print:  { render_as_points(buffer, EOptionsColors::PausePrints, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Custom_GCode: { render_as_points(buffer, EOptionsColors::CustomGCodes, *shader); break; } |             case EMoveType::Custom_GCode: { render_as_points(buffer, EOptionsColors::CustomGCodes, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Retract:      { render_as_points(buffer, EOptionsColors::Retractions, *shader); break; } |             case EMoveType::Retract:      { render_as_points(buffer, EOptionsColors::Retractions, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Unretract:    { render_as_points(buffer, EOptionsColors::Unretractions, *shader); break; } |             case EMoveType::Unretract:    { render_as_points(buffer, EOptionsColors::Unretractions, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Extrude: |             case EMoveType::Extrude: | ||||||
|             case GCodeProcessor::EMoveType::Travel: |             case EMoveType::Travel: | ||||||
|             { |             { | ||||||
| #if ENABLE_GCODE_VIEWER_SHADERS_EDITOR | #if ENABLE_GCODE_VIEWER_SHADERS_EDITOR | ||||||
|                 std::array<float, 4> light_intensity = { |                 std::array<float, 4> light_intensity = { | ||||||
|  | @ -1406,7 +1410,7 @@ void GCodeViewer::render_legend() const | ||||||
|                 draw_list->AddCircleFilled(center, 0.5f * icon_size, ImGui::GetColorU32({ color[0], color[1], color[2], 1.0f }), 16); |                 draw_list->AddCircleFilled(center, 0.5f * icon_size, ImGui::GetColorU32({ color[0], color[1], color[2], 1.0f }), 16); | ||||||
| #else | #else | ||||||
|             ImVec2 center(0.5f * (pos.x + pos.x + icon_size), 0.5f * (pos.y + pos.y + icon_size));             |             ImVec2 center(0.5f * (pos.x + pos.x + icon_size), 0.5f * (pos.y + pos.y + icon_size));             | ||||||
|             if (m_buffers[buffer_id(GCodeProcessor::EMoveType::Retract)].shader == "options_120_flat") { |             if (m_buffers[buffer_id(EMoveType::Retract)].shader == "options_120_flat") { | ||||||
|                 draw_list->AddCircleFilled(center, 0.5f * icon_size, |                 draw_list->AddCircleFilled(center, 0.5f * icon_size, | ||||||
|                     ImGui::GetColorU32({ 0.5f * color[0], 0.5f * color[1], 0.5f * color[2], 1.0f }), 16); |                     ImGui::GetColorU32({ 0.5f * color[0], 0.5f * color[1], 0.5f * color[2], 1.0f }), 16); | ||||||
|                 float radius = 0.5f * icon_size; |                 float radius = 0.5f * icon_size; | ||||||
|  | @ -1623,7 +1627,7 @@ void GCodeViewer::render_legend() const | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // travel paths
 |     // travel paths
 | ||||||
|     if (m_buffers[buffer_id(GCodeProcessor::EMoveType::Travel)].visible) { |     if (m_buffers[buffer_id(EMoveType::Travel)].visible) { | ||||||
|         switch (m_view_type) |         switch (m_view_type) | ||||||
|         { |         { | ||||||
|         case EViewType::Feedrate: |         case EViewType::Feedrate: | ||||||
|  | @ -1649,20 +1653,20 @@ void GCodeViewer::render_legend() const | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto any_option_available = [this]() { |     auto any_option_available = [this]() { | ||||||
|         auto available = [this](GCodeProcessor::EMoveType type) { |         auto available = [this](EMoveType type) { | ||||||
|             const TBuffer& buffer = m_buffers[buffer_id(type)]; |             const TBuffer& buffer = m_buffers[buffer_id(type)]; | ||||||
|             return buffer.visible && buffer.indices.count > 0; |             return buffer.visible && buffer.indices.count > 0; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         return available(GCodeProcessor::EMoveType::Color_change) || |         return available(EMoveType::Color_change) || | ||||||
|             available(GCodeProcessor::EMoveType::Custom_GCode) || |             available(EMoveType::Custom_GCode) || | ||||||
|             available(GCodeProcessor::EMoveType::Pause_Print) || |             available(EMoveType::Pause_Print) || | ||||||
|             available(GCodeProcessor::EMoveType::Retract) || |             available(EMoveType::Retract) || | ||||||
|             available(GCodeProcessor::EMoveType::Tool_change) || |             available(EMoveType::Tool_change) || | ||||||
|             available(GCodeProcessor::EMoveType::Unretract); |             available(EMoveType::Unretract); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     auto add_option = [this, append_item](GCodeProcessor::EMoveType move_type, EOptionsColors color, const std::string& text) { |     auto add_option = [this, append_item](EMoveType move_type, EOptionsColors color, const std::string& text) { | ||||||
|         const TBuffer& buffer = m_buffers[buffer_id(move_type)]; |         const TBuffer& buffer = m_buffers[buffer_id(move_type)]; | ||||||
|         if (buffer.visible && buffer.indices.count > 0) |         if (buffer.visible && buffer.indices.count > 0) | ||||||
| #if ENABLE_GCODE_VIEWER_SHADERS_EDITOR | #if ENABLE_GCODE_VIEWER_SHADERS_EDITOR | ||||||
|  | @ -1679,12 +1683,12 @@ void GCodeViewer::render_legend() const | ||||||
|         imgui.title(_u8L("Options")); |         imgui.title(_u8L("Options")); | ||||||
| 
 | 
 | ||||||
|         // items
 |         // items
 | ||||||
|         add_option(GCodeProcessor::EMoveType::Retract, EOptionsColors::Retractions, _u8L("Retractions")); |         add_option(EMoveType::Retract, EOptionsColors::Retractions, _u8L("Retractions")); | ||||||
|         add_option(GCodeProcessor::EMoveType::Unretract, EOptionsColors::Unretractions, _u8L("Unretractions")); |         add_option(EMoveType::Unretract, EOptionsColors::Unretractions, _u8L("Unretractions")); | ||||||
|         add_option(GCodeProcessor::EMoveType::Tool_change, EOptionsColors::ToolChanges, _u8L("Tool changes")); |         add_option(EMoveType::Tool_change, EOptionsColors::ToolChanges, _u8L("Tool changes")); | ||||||
|         add_option(GCodeProcessor::EMoveType::Color_change, EOptionsColors::ColorChanges, _u8L("Color changes")); |         add_option(EMoveType::Color_change, EOptionsColors::ColorChanges, _u8L("Color changes")); | ||||||
|         add_option(GCodeProcessor::EMoveType::Pause_Print, EOptionsColors::PausePrints, _u8L("Pause prints")); |         add_option(EMoveType::Pause_Print, EOptionsColors::PausePrints, _u8L("Pause prints")); | ||||||
|         add_option(GCodeProcessor::EMoveType::Custom_GCode, EOptionsColors::CustomGCodes, _u8L("Custom GCodes")); |         add_option(EMoveType::Custom_GCode, EOptionsColors::CustomGCodes, _u8L("Custom GCodes")); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     imgui.end(); |     imgui.end(); | ||||||
|  | @ -1700,10 +1704,6 @@ void GCodeViewer::render_time_estimate() const | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const PrintStatistics& ps = wxGetApp().plater()->fff_print().print_statistics(); |  | ||||||
|     if (ps.estimated_normal_print_time <= 0.0f && ps.estimated_silent_print_time <= 0.0f) |  | ||||||
|         return; |  | ||||||
| 
 |  | ||||||
|     ImGuiWrapper& imgui = *wxGetApp().imgui(); |     ImGuiWrapper& imgui = *wxGetApp().imgui(); | ||||||
|      |      | ||||||
| #if ENABLE_GCODE_VIEWER_MODAL_TIME_ESTIMATE_DIALOG | #if ENABLE_GCODE_VIEWER_MODAL_TIME_ESTIMATE_DIALOG | ||||||
|  | @ -1737,19 +1737,17 @@ void GCodeViewer::render_time_estimate() const | ||||||
|     using PartialTimes = std::vector<PartialTime>; |     using PartialTimes = std::vector<PartialTime>; | ||||||
| 
 | 
 | ||||||
|     auto append_headers = [&imgui](const Headers& headers, const ColumnOffsets& offsets) { |     auto append_headers = [&imgui](const Headers& headers, const ColumnOffsets& offsets) { | ||||||
|         ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |         imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, headers[0]); | ||||||
|         imgui.text(headers[0]); |  | ||||||
|         ImGui::SameLine(offsets[0]); |         ImGui::SameLine(offsets[0]); | ||||||
|         imgui.text(headers[1]); |         imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, headers[1]); | ||||||
|         ImGui::SameLine(offsets[1]); |         ImGui::SameLine(offsets[1]); | ||||||
|         imgui.text(headers[2]); |         imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, headers[2]); | ||||||
|         ImGui::PopStyleColor(); |  | ||||||
|         ImGui::Separator(); |         ImGui::Separator(); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     auto append_mode = [this, &imgui, append_headers](float total_time, const PartialTimes& items, |     auto append_mode = [this, &imgui, append_headers](float total_time, const PartialTimes& items, | ||||||
|         const Headers& partial_times_headers, |         const Headers& partial_times_headers, | ||||||
|         const std::vector<std::pair<GCodeProcessor::EMoveType, float>>& moves_time, |         const std::vector<std::pair<EMoveType, float>>& moves_time, | ||||||
|         const Headers& moves_headers, |         const Headers& moves_headers, | ||||||
|         const std::vector<std::pair<ExtrusionRole, float>>& roles_time, |         const std::vector<std::pair<ExtrusionRole, float>>& roles_time, | ||||||
|         const Headers& roles_headers) { |         const Headers& roles_headers) { | ||||||
|  | @ -1775,9 +1773,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
|                 return ret; |                 return ret; | ||||||
|             }; |             }; | ||||||
|             auto append_color = [this, &imgui](const Color& color1, const Color& color2, ColumnOffsets& offsets, const Times& times) { |             auto append_color = [this, &imgui](const Color& color1, const Color& color2, ColumnOffsets& offsets, const Times& times) { | ||||||
|                 ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |                 imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, _u8L("Color change")); | ||||||
|                 imgui.text(_u8L("Color change")); |  | ||||||
|                 ImGui::PopStyleColor(); |  | ||||||
|                 ImGui::SameLine(); |                 ImGui::SameLine(); | ||||||
| 
 | 
 | ||||||
|                 float icon_size = ImGui::GetTextLineHeight(); |                 float icon_size = ImGui::GetTextLineHeight(); | ||||||
|  | @ -1805,9 +1801,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
|                 { |                 { | ||||||
|                 case PartialTime::EType::Print: |                 case PartialTime::EType::Print: | ||||||
|                 { |                 { | ||||||
|                     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |                     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, _u8L("Print")); | ||||||
|                     imgui.text(_u8L("Print")); |  | ||||||
|                     ImGui::PopStyleColor(); |  | ||||||
|                     ImGui::SameLine(offsets[0]); |                     ImGui::SameLine(offsets[0]); | ||||||
|                     imgui.text(short_time(get_time_dhms(item.times.second))); |                     imgui.text(short_time(get_time_dhms(item.times.second))); | ||||||
|                     ImGui::SameLine(offsets[1]); |                     ImGui::SameLine(offsets[1]); | ||||||
|  | @ -1816,9 +1810,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
|                 } |                 } | ||||||
|                 case PartialTime::EType::Pause: |                 case PartialTime::EType::Pause: | ||||||
|                 { |                 { | ||||||
|                     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |                     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, _u8L("Pause")); | ||||||
|                     imgui.text(_u8L("Pause")); |  | ||||||
|                     ImGui::PopStyleColor(); |  | ||||||
|                     ImGui::SameLine(offsets[0]); |                     ImGui::SameLine(offsets[0]); | ||||||
|                     imgui.text(short_time(get_time_dhms(item.times.second - item.times.first))); |                     imgui.text(short_time(get_time_dhms(item.times.second - item.times.first))); | ||||||
|                     break; |                     break; | ||||||
|  | @ -1832,26 +1824,24 @@ void GCodeViewer::render_time_estimate() const | ||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         auto move_type_label = [](GCodeProcessor::EMoveType type) { |         auto move_type_label = [](EMoveType type) { | ||||||
|             switch (type) |             switch (type) | ||||||
|             { |             { | ||||||
|             case GCodeProcessor::EMoveType::Noop:         { return _u8L("Noop"); } |             case EMoveType::Noop:         { return _u8L("Noop"); } | ||||||
|             case GCodeProcessor::EMoveType::Retract:      { return _u8L("Retraction"); } |             case EMoveType::Retract:      { return _u8L("Retraction"); } | ||||||
|             case GCodeProcessor::EMoveType::Unretract:    { return _u8L("Unretraction"); } |             case EMoveType::Unretract:    { return _u8L("Unretraction"); } | ||||||
|             case GCodeProcessor::EMoveType::Tool_change:  { return _u8L("Tool change"); } |             case EMoveType::Tool_change:  { return _u8L("Tool change"); } | ||||||
|             case GCodeProcessor::EMoveType::Color_change: { return _u8L("Color change"); } |             case EMoveType::Color_change: { return _u8L("Color change"); } | ||||||
|             case GCodeProcessor::EMoveType::Pause_Print:  { return _u8L("Pause print"); } |             case EMoveType::Pause_Print:  { return _u8L("Pause print"); } | ||||||
|             case GCodeProcessor::EMoveType::Custom_GCode: { return _u8L("Custom GCode"); } |             case EMoveType::Custom_GCode: { return _u8L("Custom GCode"); } | ||||||
|             case GCodeProcessor::EMoveType::Travel:       { return _u8L("Travel"); } |             case EMoveType::Travel:       { return _u8L("Travel"); } | ||||||
|             case GCodeProcessor::EMoveType::Extrude:      { return _u8L("Extrusion"); } |             case EMoveType::Extrude:      { return _u8L("Extrusion"); } | ||||||
|             default:                                      { return _u8L("Unknown"); } |             default:                      { return _u8L("Unknown"); } | ||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         auto append_time_item = [&imgui] (const std::string& label, float time, float percentage, const ImVec4& color, const ColumnOffsets& offsets) { |         auto append_time_item = [&imgui] (const std::string& label, float time, float percentage, const ImVec4& color, const ColumnOffsets& offsets) { | ||||||
|             ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |             imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, label); | ||||||
|             imgui.text(label); |  | ||||||
|             ImGui::PopStyleColor(); |  | ||||||
|             ImGui::SameLine(offsets[0]); |             ImGui::SameLine(offsets[0]); | ||||||
|             imgui.text(short_time(get_time_dhms(time))); |             imgui.text(short_time(get_time_dhms(time))); | ||||||
|             ImGui::SameLine(offsets[1]); |             ImGui::SameLine(offsets[1]); | ||||||
|  | @ -1868,7 +1858,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         auto append_move_times = [this, &imgui, move_type_label, append_headers, append_time_item](float total_time, |         auto append_move_times = [this, &imgui, move_type_label, append_headers, append_time_item](float total_time, | ||||||
|             const std::vector<std::pair<GCodeProcessor::EMoveType, float>>& moves_time, |             const std::vector<std::pair<EMoveType, float>>& moves_time, | ||||||
|             const Headers& headers, const ColumnOffsets& offsets) { |             const Headers& headers, const ColumnOffsets& offsets) { | ||||||
| 
 | 
 | ||||||
|             if (moves_time.empty()) |             if (moves_time.empty()) | ||||||
|  | @ -1879,7 +1869,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
| 
 | 
 | ||||||
|             append_headers(headers, offsets); |             append_headers(headers, offsets); | ||||||
| 
 | 
 | ||||||
|             std::vector<std::pair<GCodeProcessor::EMoveType, float>> sorted_moves_time(moves_time); |             std::vector<std::pair<EMoveType, float>> sorted_moves_time(moves_time); | ||||||
|             std::sort(sorted_moves_time.begin(), sorted_moves_time.end(), [](const auto& p1, const auto& p2) { return p2.second < p1.second; }); |             std::sort(sorted_moves_time.begin(), sorted_moves_time.end(), [](const auto& p1, const auto& p2) { return p2.second < p1.second; }); | ||||||
| 
 | 
 | ||||||
|             for (const auto& [type, time] : sorted_moves_time) { |             for (const auto& [type, time] : sorted_moves_time) { | ||||||
|  | @ -1909,7 +1899,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         auto calc_common_offsets = [move_type_label]( |         auto calc_common_offsets = [move_type_label]( | ||||||
|             const std::vector<std::pair<GCodeProcessor::EMoveType, float>>& moves_time, const Headers& moves_headers, |             const std::vector<std::pair<EMoveType, float>>& moves_time, const Headers& moves_headers, | ||||||
|             const std::vector<std::pair<ExtrusionRole, float>>& roles_time, const Headers& roles_headers) { |             const std::vector<std::pair<ExtrusionRole, float>>& roles_time, const Headers& roles_headers) { | ||||||
|                 ColumnOffsets ret = { std::max(ImGui::CalcTextSize(moves_headers[0].c_str()).x, ImGui::CalcTextSize(roles_headers[0].c_str()).x), |                 ColumnOffsets ret = { std::max(ImGui::CalcTextSize(moves_headers[0].c_str()).x, ImGui::CalcTextSize(roles_headers[0].c_str()).x), | ||||||
|                     std::max(ImGui::CalcTextSize(moves_headers[1].c_str()).x, ImGui::CalcTextSize(roles_headers[1].c_str()).x) }; |                     std::max(ImGui::CalcTextSize(moves_headers[1].c_str()).x, ImGui::CalcTextSize(roles_headers[1].c_str()).x) }; | ||||||
|  | @ -1930,9 +1920,7 @@ void GCodeViewer::render_time_estimate() const | ||||||
|                 return ret; |                 return ret; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |         imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, _u8L("Time") + ":"); | ||||||
|         imgui.text(_u8L("Time") + ":"); |  | ||||||
|         ImGui::PopStyleColor(); |  | ||||||
|         ImGui::SameLine(); |         ImGui::SameLine(); | ||||||
|         imgui.text(short_time(get_time_dhms(total_time))); |         imgui.text(short_time(get_time_dhms(total_time))); | ||||||
|         append_partial_times(items, partial_times_headers); |         append_partial_times(items, partial_times_headers); | ||||||
|  | @ -2032,21 +2020,23 @@ void GCodeViewer::render_time_estimate() const | ||||||
| 
 | 
 | ||||||
|         // mode tabs
 |         // mode tabs
 | ||||||
|     ImGui::BeginTabBar("mode_tabs"); |     ImGui::BeginTabBar("mode_tabs"); | ||||||
|     if (ps.estimated_normal_print_time > 0.0f) { |     const PrintEstimatedTimeStatistics::Mode& normal_mode = m_time_statistics.modes[static_cast<size_t>(PrintEstimatedTimeStatistics::ETimeMode::Normal)]; | ||||||
|  |     if (normal_mode.time > 0.0f) { | ||||||
|         if (ImGui::BeginTabItem(_u8L("Normal").c_str())) { |         if (ImGui::BeginTabItem(_u8L("Normal").c_str())) { | ||||||
|             append_mode(ps.estimated_normal_print_time, |             append_mode(normal_mode.time, | ||||||
|                 generate_partial_times(ps.estimated_normal_custom_gcode_print_times), partial_times_headers, |                 generate_partial_times(normal_mode.custom_gcode_times), partial_times_headers, | ||||||
|                 ps.estimated_normal_moves_times, moves_headers, |                 normal_mode.moves_times, moves_headers, | ||||||
|                 ps.estimated_normal_roles_times, roles_headers); |                 normal_mode.roles_times, roles_headers); | ||||||
|             ImGui::EndTabItem(); |             ImGui::EndTabItem(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     if (ps.estimated_silent_print_time > 0.0f) { |     const PrintEstimatedTimeStatistics::Mode& stealth_mode = m_time_statistics.modes[static_cast<size_t>(PrintEstimatedTimeStatistics::ETimeMode::Stealth)]; | ||||||
|  |     if (stealth_mode.time > 0.0f) { | ||||||
|         if (ImGui::BeginTabItem(_u8L("Stealth").c_str())) { |         if (ImGui::BeginTabItem(_u8L("Stealth").c_str())) { | ||||||
|             append_mode(ps.estimated_silent_print_time, |             append_mode(stealth_mode.time, | ||||||
|                 generate_partial_times(ps.estimated_silent_custom_gcode_print_times), partial_times_headers, |                 generate_partial_times(stealth_mode.custom_gcode_times), partial_times_headers, | ||||||
|                 ps.estimated_silent_moves_times, moves_headers, |                 stealth_mode.moves_times, moves_headers, | ||||||
|                 ps.estimated_silent_roles_times, roles_headers); |                 stealth_mode.roles_times, roles_headers); | ||||||
|             ImGui::EndTabItem(); |             ImGui::EndTabItem(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | @ -2082,93 +2072,67 @@ void GCodeViewer::render_statistics() const | ||||||
|     imgui.begin(std::string("GCodeViewer Statistics"), ImGuiWindowFlags_AlwaysAutoResize | ImGuiWindowFlags_NoResize); |     imgui.begin(std::string("GCodeViewer Statistics"), ImGuiWindowFlags_AlwaysAutoResize | ImGuiWindowFlags_NoResize); | ||||||
|     ImGui::BringWindowToDisplayFront(ImGui::GetCurrentWindow()); |     ImGui::BringWindowToDisplayFront(ImGui::GetCurrentWindow()); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("GCodeProcessor time:")); | ||||||
|     imgui.text(std::string("GCodeProcessor time:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.results_time) + " ms"); |     imgui.text(std::to_string(m_statistics.results_time) + " ms"); | ||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Load time:")); | ||||||
|     imgui.text(std::string("Load time:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.load_time) + " ms"); |     imgui.text(std::to_string(m_statistics.load_time) + " ms"); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Refresh time:")); | ||||||
|     imgui.text(std::string("Resfresh time:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.refresh_time) + " ms"); |     imgui.text(std::to_string(m_statistics.refresh_time) + " ms"); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Refresh paths time:")); | ||||||
|     imgui.text(std::string("Resfresh paths time:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.refresh_paths_time) + " ms"); |     imgui.text(std::to_string(m_statistics.refresh_paths_time) + " ms"); | ||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Multi GL_POINTS calls:")); | ||||||
|     imgui.text(std::string("Multi GL_POINTS calls:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.gl_multi_points_calls_count)); |     imgui.text(std::to_string(m_statistics.gl_multi_points_calls_count)); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Multi GL_LINE_STRIP calls:")); | ||||||
|     imgui.text(std::string("Multi GL_LINE_STRIP calls:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.gl_multi_line_strip_calls_count)); |     imgui.text(std::to_string(m_statistics.gl_multi_line_strip_calls_count)); | ||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("GCodeProcessor results:")); | ||||||
|     imgui.text(std::string("GCodeProcessor results:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.results_size) + " bytes"); |     imgui.text(std::to_string(m_statistics.results_size) + " bytes"); | ||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Paths CPU:")); | ||||||
|     imgui.text(std::string("Paths CPU:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.paths_size) + " bytes"); |     imgui.text(std::to_string(m_statistics.paths_size) + " bytes"); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Render paths CPU:")); | ||||||
|     imgui.text(std::string("Render paths CPU:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.render_paths_size) + " bytes"); |     imgui.text(std::to_string(m_statistics.render_paths_size) + " bytes"); | ||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Vertices GPU:")); | ||||||
|     imgui.text(std::string("Vertices GPU:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.vertices_gpu_size) + " bytes"); |     imgui.text(std::to_string(m_statistics.vertices_gpu_size) + " bytes"); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Vertices GPU:")); | ||||||
|     imgui.text(std::string("Indices GPU:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.indices_gpu_size) + " bytes"); |     imgui.text(std::to_string(m_statistics.indices_gpu_size) + " bytes"); | ||||||
| 
 | 
 | ||||||
|     ImGui::Separator(); |     ImGui::Separator(); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Vertices GPU:")); | ||||||
|     imgui.text(std::string("Travel segments:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.travel_segments_count)); |     imgui.text(std::to_string(m_statistics.travel_segments_count)); | ||||||
| 
 | 
 | ||||||
|     ImGui::PushStyleColor(ImGuiCol_Text, ImGuiWrapper::COL_ORANGE_LIGHT); |     imgui.text_colored(ImGuiWrapper::COL_ORANGE_LIGHT, std::string("Extrude segments:")); | ||||||
|     imgui.text(std::string("Extrude segments:")); |  | ||||||
|     ImGui::PopStyleColor(); |  | ||||||
|     ImGui::SameLine(offset); |     ImGui::SameLine(offset); | ||||||
|     imgui.text(std::to_string(m_statistics.extrude_segments_count)); |     imgui.text(std::to_string(m_statistics.extrude_segments_count)); | ||||||
| 
 | 
 | ||||||
|  | @ -2242,7 +2206,7 @@ void GCodeViewer::render_shaders_editor() const | ||||||
| 
 | 
 | ||||||
| bool GCodeViewer::is_travel_in_z_range(size_t id) const | bool GCodeViewer::is_travel_in_z_range(size_t id) const | ||||||
| { | { | ||||||
|     const TBuffer& buffer = m_buffers[buffer_id(GCodeProcessor::EMoveType::Travel)]; |     const TBuffer& buffer = m_buffers[buffer_id(EMoveType::Travel)]; | ||||||
|     if (id >= buffer.paths.size()) |     if (id >= buffer.paths.size()) | ||||||
|         return false; |         return false; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -88,7 +88,7 @@ class GCodeViewer | ||||||
|             Vec3f position{ Vec3f::Zero() }; |             Vec3f position{ Vec3f::Zero() }; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         GCodeProcessor::EMoveType type{ GCodeProcessor::EMoveType::Noop }; |         EMoveType type{ EMoveType::Noop }; | ||||||
|         ExtrusionRole role{ erNone }; |         ExtrusionRole role{ erNone }; | ||||||
|         Endpoint first; |         Endpoint first; | ||||||
|         Endpoint last; |         Endpoint last; | ||||||
|  | @ -326,7 +326,7 @@ public: | ||||||
| private: | private: | ||||||
|     unsigned int m_last_result_id{ 0 }; |     unsigned int m_last_result_id{ 0 }; | ||||||
|     size_t m_vertices_count{ 0 }; |     size_t m_vertices_count{ 0 }; | ||||||
|     mutable std::vector<TBuffer> m_buffers{ static_cast<size_t>(GCodeProcessor::EMoveType::Extrude) }; |     mutable std::vector<TBuffer> m_buffers{ static_cast<size_t>(EMoveType::Extrude) }; | ||||||
|     // bounding box of toolpaths
 |     // bounding box of toolpaths
 | ||||||
|     BoundingBoxf3 m_paths_bounding_box; |     BoundingBoxf3 m_paths_bounding_box; | ||||||
|     // bounding box of toolpaths + marker tools
 |     // bounding box of toolpaths + marker tools
 | ||||||
|  | @ -341,6 +341,7 @@ private: | ||||||
|     Shells m_shells; |     Shells m_shells; | ||||||
|     EViewType m_view_type{ EViewType::FeatureType }; |     EViewType m_view_type{ EViewType::FeatureType }; | ||||||
|     bool m_legend_enabled{ true }; |     bool m_legend_enabled{ true }; | ||||||
|  |     PrintEstimatedTimeStatistics m_time_statistics; | ||||||
| #if ENABLE_GCODE_VIEWER_MODAL_TIME_ESTIMATE_DIALOG | #if ENABLE_GCODE_VIEWER_MODAL_TIME_ESTIMATE_DIALOG | ||||||
|     mutable bool m_time_estimate_enabled{ false }; |     mutable bool m_time_estimate_enabled{ false }; | ||||||
|     mutable unsigned int m_time_estimate_frames_count{ 0 }; |     mutable unsigned int m_time_estimate_frames_count{ 0 }; | ||||||
|  | @ -391,8 +392,8 @@ public: | ||||||
|         m_view_type = type; |         m_view_type = type; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool is_toolpath_move_type_visible(GCodeProcessor::EMoveType type) const; |     bool is_toolpath_move_type_visible(EMoveType type) const; | ||||||
|     void set_toolpath_move_type_visible(GCodeProcessor::EMoveType type, bool visible); |     void set_toolpath_move_type_visible(EMoveType type, bool visible); | ||||||
|     unsigned int get_toolpath_role_visibility_flags() const { return m_extrusions.role_visibility_flags; } |     unsigned int get_toolpath_role_visibility_flags() const { return m_extrusions.role_visibility_flags; } | ||||||
|     void set_toolpath_role_visibility_flags(unsigned int flags) { m_extrusions.role_visibility_flags = flags; } |     void set_toolpath_role_visibility_flags(unsigned int flags) { m_extrusions.role_visibility_flags = flags; } | ||||||
|     unsigned int get_options_visibility_flags() const; |     unsigned int get_options_visibility_flags() const; | ||||||
|  |  | ||||||
|  | @ -1432,8 +1432,6 @@ void MainFrame::set_mode(EMode mode) | ||||||
|         select_tab(0); |         select_tab(0); | ||||||
| #endif // ENABLE_LAYOUT_NO_RESTART
 | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
|         m_plater->fff_print().print_statistics().clear_time_estimates(); |  | ||||||
| 
 |  | ||||||
|         m_plater->reset(); |         m_plater->reset(); | ||||||
|         m_plater->reset_gcode_toolpaths(); |         m_plater->reset_gcode_toolpaths(); | ||||||
| 
 | 
 | ||||||
|  | @ -1477,8 +1475,6 @@ void MainFrame::set_mode(EMode mode) | ||||||
|         update_layout(); |         update_layout(); | ||||||
| #endif // ENABLE_LAYOUT_NO_RESTART
 | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
|         m_plater->fff_print().print_statistics().clear_time_estimates(); |  | ||||||
| 
 |  | ||||||
|         m_plater->reset(); |         m_plater->reset(); | ||||||
|         m_plater->reset_last_loaded_gcode(); |         m_plater->reset_last_loaded_gcode(); | ||||||
|         m_plater->reset_gcode_toolpaths(); |         m_plater->reset_gcode_toolpaths(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966