mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	GCodeViewer -> Some refactoring
This commit is contained in:
		
							parent
							
								
									7e815b4727
								
							
						
					
					
						commit
						81a7b7782b
					
				
					 1 changed files with 46 additions and 103 deletions
				
			
		|  | @ -44,8 +44,7 @@ std::vector<std::array<float, 3>> decode_colors(const std::vector<std::string> & | ||||||
|     static const float INV_255 = 1.0f / 255.0f; |     static const float INV_255 = 1.0f / 255.0f; | ||||||
| 
 | 
 | ||||||
|     std::vector<std::array<float, 3>> output(colors.size(), { 0.0f, 0.0f, 0.0f }); |     std::vector<std::array<float, 3>> output(colors.size(), { 0.0f, 0.0f, 0.0f }); | ||||||
|     for (size_t i = 0; i < colors.size(); ++i) |     for (size_t i = 0; i < colors.size(); ++i) { | ||||||
|     { |  | ||||||
|         const std::string& color = colors[i]; |         const std::string& color = colors[i]; | ||||||
|         const char* c = color.data() + 1; |         const char* c = color.data() + 1; | ||||||
|         if ((color.size() == 7) && (color.front() == '#')) { |         if ((color.size() == 7) && (color.front() == '#')) { | ||||||
|  | @ -293,11 +292,10 @@ void GCodeViewer::load(const GCodeProcessor::Result& gcode_result, const Print& | ||||||
|         const double margin = 10.0; |         const double margin = 10.0; | ||||||
|         Vec2d min(m_bounding_box.min(0) - margin, m_bounding_box.min(1) - margin); |         Vec2d min(m_bounding_box.min(0) - margin, m_bounding_box.min(1) - margin); | ||||||
|         Vec2d max(m_bounding_box.max(0) + margin, m_bounding_box.max(1) + margin); |         Vec2d max(m_bounding_box.max(0) + margin, m_bounding_box.max(1) + margin); | ||||||
|         Pointfs bed_shape = { |         Pointfs bed_shape = { { min(0), min(1) }, | ||||||
|             { min(0), min(1) }, |                               { max(0), min(1) }, | ||||||
|             { max(0), min(1) }, |                               { max(0), max(1) }, | ||||||
|             { max(0), max(1) }, |                               { min(0), max(1) } }; | ||||||
|             { min(0), max(1) } }; |  | ||||||
|         wxGetApp().plater()->set_bed_shape(bed_shape, "", ""); |         wxGetApp().plater()->set_bed_shape(bed_shape, "", ""); | ||||||
|     } |     } | ||||||
| #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | #endif // ENABLE_GCODE_VIEWER_AS_STATE
 | ||||||
|  | @ -317,8 +315,7 @@ void GCodeViewer::refresh(const GCodeProcessor::Result& gcode_result, const std: | ||||||
| 
 | 
 | ||||||
|     // update ranges for coloring / legend
 |     // update ranges for coloring / legend
 | ||||||
|     m_extrusions.reset_ranges(); |     m_extrusions.reset_ranges(); | ||||||
|     for (size_t i = 0; i < m_vertices.vertices_count; ++i) |     for (size_t i = 0; i < m_vertices.vertices_count; ++i) { | ||||||
|     { |  | ||||||
|         // skip first vertex
 |         // skip first vertex
 | ||||||
|         if (i == 0) |         if (i == 0) | ||||||
|             continue; |             continue; | ||||||
|  | @ -466,8 +463,7 @@ void GCodeViewer::init_shaders() | ||||||
|     unsigned char end_id = buffer_id(GCodeProcessor::EMoveType::Count); |     unsigned char end_id = buffer_id(GCodeProcessor::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_solid" : "options_110"; break; } |         case GCodeProcessor::EMoveType::Tool_change:  { m_buffers[i].shader = is_glsl_120 ? "options_120_solid" : "options_110"; break; } | ||||||
|  | @ -530,8 +526,7 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
| 
 | 
 | ||||||
|     // indices data -> extract from result
 |     // indices data -> extract from result
 | ||||||
|     std::vector<std::vector<unsigned int>> indices(m_buffers.size()); |     std::vector<std::vector<unsigned int>> indices(m_buffers.size()); | ||||||
|     for (size_t i = 0; i < m_vertices.vertices_count; ++i) |     for (size_t i = 0; i < m_vertices.vertices_count; ++i) { | ||||||
|     { |  | ||||||
|         // skip first vertex
 |         // skip first vertex
 | ||||||
|         if (i == 0) |         if (i == 0) | ||||||
|             continue; |             continue; | ||||||
|  | @ -560,10 +555,9 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
|         case GCodeProcessor::EMoveType::Travel: |         case GCodeProcessor::EMoveType::Travel: | ||||||
|         { |         { | ||||||
|             if (prev.type != curr.type || !buffer.paths.back().matches(curr)) { |             if (prev.type != curr.type || !buffer.paths.back().matches(curr)) { | ||||||
|                 buffer.add_path(curr, static_cast<unsigned int>(buffer_indices.size()), static_cast<unsigned int>(i)); |                 buffer.add_path(curr, static_cast<unsigned int>(buffer_indices.size()), static_cast<unsigned int>(i - 1)); | ||||||
|                 Path& last_path = buffer.paths.back(); |                 Path& last_path = buffer.paths.back(); | ||||||
|                 last_path.first.position = prev.position; |                 last_path.first.position = prev.position; | ||||||
|                 last_path.first.s_id = static_cast<unsigned int>(i - 1); |  | ||||||
|                 buffer_indices.push_back(static_cast<unsigned int>(i - 1)); |                 buffer_indices.push_back(static_cast<unsigned int>(i - 1)); | ||||||
|             } |             } | ||||||
|              |              | ||||||
|  | @ -571,23 +565,18 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | ||||||
|             buffer_indices.push_back(static_cast<unsigned int>(i)); |             buffer_indices.push_back(static_cast<unsigned int>(i)); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         default: |         default: { break; } | ||||||
|         { |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| #if ENABLE_GCODE_VIEWER_STATISTICS | #if ENABLE_GCODE_VIEWER_STATISTICS | ||||||
|     for (IBuffer& buffer : m_buffers) |     for (IBuffer& buffer : m_buffers) { | ||||||
|     { |  | ||||||
|         m_statistics.paths_size += SLIC3R_STDVEC_MEMSIZE(buffer.paths, Path); |         m_statistics.paths_size += SLIC3R_STDVEC_MEMSIZE(buffer.paths, Path); | ||||||
|     } |     } | ||||||
| #endif // ENABLE_GCODE_VIEWER_STATISTICS
 | #endif // ENABLE_GCODE_VIEWER_STATISTICS
 | ||||||
| 
 | 
 | ||||||
|     // indices data -> send data to gpu
 |     // indices data -> send data to gpu
 | ||||||
|     for (size_t i = 0; i < m_buffers.size(); ++i) |     for (size_t i = 0; i < m_buffers.size(); ++i) { | ||||||
|     { |  | ||||||
|         IBuffer& buffer = m_buffers[i]; |         IBuffer& buffer = m_buffers[i]; | ||||||
|         std::vector<unsigned int>& buffer_indices = indices[i]; |         std::vector<unsigned int>& buffer_indices = indices[i]; | ||||||
|         buffer.indices_count = buffer_indices.size(); |         buffer.indices_count = buffer_indices.size(); | ||||||
|  | @ -605,8 +594,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.vertices_count; ++i) |     for (size_t i = 0; i < m_vertices.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 == GCodeProcessor::EMoveType::Extrude) | ||||||
|             m_layers_zs.emplace_back(static_cast<double>(move.position[2])); |             m_layers_zs.emplace_back(static_cast<double>(move.position[2])); | ||||||
|  | @ -655,8 +643,7 @@ void GCodeViewer::load_shells(const Print& print, bool initialized) | ||||||
| 
 | 
 | ||||||
|     // adds objects' volumes 
 |     // adds objects' volumes 
 | ||||||
|     int object_id = 0; |     int object_id = 0; | ||||||
|     for (const PrintObject* obj : print.objects()) |     for (const PrintObject* obj : print.objects()) { | ||||||
|     { |  | ||||||
|         const ModelObject* model_obj = obj->model_object(); |         const ModelObject* model_obj = obj->model_object(); | ||||||
| 
 | 
 | ||||||
|         std::vector<int> instance_ids(model_obj->instances.size()); |         std::vector<int> instance_ids(model_obj->instances.size()); | ||||||
|  | @ -690,8 +677,7 @@ void GCodeViewer::load_shells(const Print& print, bool initialized) | ||||||
|     // remove modifiers
 |     // remove modifiers
 | ||||||
|     while (true) { |     while (true) { | ||||||
|         GLVolumePtrs::iterator it = std::find_if(m_shells.volumes.volumes.begin(), m_shells.volumes.volumes.end(), [](GLVolume* volume) { return volume->is_modifier; }); |         GLVolumePtrs::iterator it = std::find_if(m_shells.volumes.volumes.begin(), m_shells.volumes.volumes.end(), [](GLVolume* volume) { return volume->is_modifier; }); | ||||||
|         if (it != m_shells.volumes.volumes.end()) |         if (it != m_shells.volumes.volumes.end()) { | ||||||
|         { |  | ||||||
|             delete (*it); |             delete (*it); | ||||||
|             m_shells.volumes.volumes.erase(it); |             m_shells.volumes.volumes.erase(it); | ||||||
|         } |         } | ||||||
|  | @ -699,8 +685,7 @@ void GCodeViewer::load_shells(const Print& print, bool initialized) | ||||||
|             break; |             break; | ||||||
|     }  |     }  | ||||||
| 
 | 
 | ||||||
|     for (GLVolume* volume : m_shells.volumes.volumes) |     for (GLVolume* volume : m_shells.volumes.volumes) { | ||||||
|     { |  | ||||||
|         volume->zoom_to_volumes = false; |         volume->zoom_to_volumes = false; | ||||||
|         volume->color[3] = 0.25f; |         volume->color[3] = 0.25f; | ||||||
|         volume->force_native_color = true; |         volume->force_native_color = true; | ||||||
|  | @ -841,8 +826,8 @@ void GCodeViewer::render_toolpaths() const | ||||||
| 
 | 
 | ||||||
|     Transform3d inv_proj = camera.get_projection_matrix().inverse(); |     Transform3d inv_proj = camera.get_projection_matrix().inverse(); | ||||||
| 
 | 
 | ||||||
|     auto render_options = [this, zoom, inv_proj, viewport, point_size, near_plane_height](const IBuffer& buffer, EOptionsColors colors_id, GLShaderProgram& shader) { |     auto render_as_points = [this, zoom, inv_proj, viewport, point_size, near_plane_height](const IBuffer& buffer, EOptionsColors color_id, GLShaderProgram& shader) { | ||||||
|         shader.set_uniform("uniform_color", Options_Colors[static_cast<unsigned int>(colors_id)]); |         shader.set_uniform("uniform_color", Options_Colors[static_cast<unsigned int>(color_id)]); | ||||||
|         shader.set_uniform("zoom", zoom); |         shader.set_uniform("zoom", zoom); | ||||||
| #if ENABLE_GCODE_VIEWER_SHADERS_EDITOR | #if ENABLE_GCODE_VIEWER_SHADERS_EDITOR | ||||||
|         shader.set_uniform("percent_outline_radius", 0.01f * static_cast<float>(m_shaders_editor.percent_outline)); |         shader.set_uniform("percent_outline_radius", 0.01f * static_cast<float>(m_shaders_editor.percent_outline)); | ||||||
|  | @ -870,6 +855,18 @@ void GCodeViewer::render_toolpaths() const | ||||||
|         glsafe(::glDisable(GL_VERTEX_PROGRAM_POINT_SIZE)); |         glsafe(::glDisable(GL_VERTEX_PROGRAM_POINT_SIZE)); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|  |     auto render_as_lines = [this](const IBuffer& buffer, GLShaderProgram& shader) { | ||||||
|  |         for (const RenderPath& path : buffer.render_paths) | ||||||
|  |         { | ||||||
|  |             shader.set_uniform("uniform_color", path.color); | ||||||
|  | //            glsafe(::glMultiDrawElements(GL_LINES, (const GLsizei*)path.sizes.data(), GL_UNSIGNED_INT, (const void* const*)path.offsets.data(), (GLsizei)path.sizes.size()));
 | ||||||
|  |             glsafe(::glMultiDrawElements(GL_LINE_STRIP, (const GLsizei*)path.sizes.data(), GL_UNSIGNED_INT, (const void* const*)path.offsets.data(), (GLsizei)path.sizes.size())); | ||||||
|  | #if ENABLE_GCODE_VIEWER_STATISTICS | ||||||
|  |             ++m_statistics.gl_multi_line_strip_calls_count; | ||||||
|  | #endif // ENABLE_GCODE_VIEWER_STATISTICS
 | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|     auto line_width = [zoom]() { |     auto line_width = [zoom]() { | ||||||
|         return (zoom < 5.0) ? 1.0 : (1.0 + 5.0 * (zoom - 5.0) / (100.0 - 5.0));             |         return (zoom < 5.0) ? 1.0 : (1.0 + 5.0 * (zoom - 5.0) / (100.0 - 5.0));             | ||||||
|     }; |     }; | ||||||
|  | @ -902,62 +899,14 @@ void GCodeViewer::render_toolpaths() const | ||||||
| 
 | 
 | ||||||
|             switch (type) |             switch (type) | ||||||
|             { |             { | ||||||
|             case GCodeProcessor::EMoveType::Tool_change: |             case GCodeProcessor::EMoveType::Tool_change:  { render_as_points(buffer, EOptionsColors::ToolChanges, *shader); break; } | ||||||
|             { |             case GCodeProcessor::EMoveType::Color_change: { render_as_points(buffer, EOptionsColors::ColorChanges, *shader); break; } | ||||||
|                 render_options(buffer, EOptionsColors::ToolChanges, *shader); |             case GCodeProcessor::EMoveType::Pause_Print:  { render_as_points(buffer, EOptionsColors::PausePrints, *shader); break; } | ||||||
|                 break; |             case GCodeProcessor::EMoveType::Custom_GCode: { render_as_points(buffer, EOptionsColors::CustomGCodes, *shader); break; } | ||||||
|             } |             case GCodeProcessor::EMoveType::Retract:      { render_as_points(buffer, EOptionsColors::Retractions, *shader); break; } | ||||||
|             case GCodeProcessor::EMoveType::Color_change: |             case GCodeProcessor::EMoveType::Unretract:    { render_as_points(buffer, EOptionsColors::Unretractions, *shader); break; } | ||||||
|             { |  | ||||||
|                 render_options(buffer, EOptionsColors::ColorChanges, *shader); |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             case GCodeProcessor::EMoveType::Pause_Print: |  | ||||||
|             { |  | ||||||
|                 render_options(buffer, EOptionsColors::PausePrints, *shader); |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             case GCodeProcessor::EMoveType::Custom_GCode: |  | ||||||
|             { |  | ||||||
|                 render_options(buffer, EOptionsColors::CustomGCodes, *shader); |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             case GCodeProcessor::EMoveType::Retract: |  | ||||||
|             { |  | ||||||
|                 render_options(buffer, EOptionsColors::Retractions, *shader); |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             case GCodeProcessor::EMoveType::Unretract: |  | ||||||
|             { |  | ||||||
|                 render_options(buffer, EOptionsColors::Unretractions, *shader); |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             case GCodeProcessor::EMoveType::Extrude: |             case GCodeProcessor::EMoveType::Extrude: | ||||||
|             { |             case GCodeProcessor::EMoveType::Travel:       { render_as_lines(buffer, *shader); break; } | ||||||
|                 for (const RenderPath& path : buffer.render_paths) |  | ||||||
|                 { |  | ||||||
|                     shader->set_uniform("uniform_color", path.color); |  | ||||||
|                     glsafe(::glMultiDrawElements(GL_LINE_STRIP, (const GLsizei*)path.sizes.data(), GL_UNSIGNED_INT, (const void* const*)path.offsets.data(), (GLsizei)path.sizes.size())); |  | ||||||
| #if ENABLE_GCODE_VIEWER_STATISTICS |  | ||||||
|                     ++m_statistics.gl_multi_line_strip_calls_count; |  | ||||||
| #endif // ENABLE_GCODE_VIEWER_STATISTICS
 |  | ||||||
| 
 |  | ||||||
|                 } |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             case GCodeProcessor::EMoveType::Travel: |  | ||||||
|             { |  | ||||||
|                 for (const RenderPath& path : buffer.render_paths) |  | ||||||
|                 { |  | ||||||
|                     shader->set_uniform("uniform_color", path.color); |  | ||||||
|                     glsafe(::glMultiDrawElements(GL_LINE_STRIP, (const GLsizei*)path.sizes.data(), GL_UNSIGNED_INT, (const void* const*)path.offsets.data(), (GLsizei)path.sizes.size())); |  | ||||||
| #if ENABLE_GCODE_VIEWER_STATISTICS |  | ||||||
|                     ++m_statistics.gl_multi_line_strip_calls_count; |  | ||||||
| #endif // ENABLE_GCODE_VIEWER_STATISTICS
 |  | ||||||
| 
 |  | ||||||
|                 } |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             glsafe(::glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0)); |             glsafe(::glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0)); | ||||||
|  | @ -1090,8 +1039,7 @@ void GCodeViewer::render_legend() const | ||||||
|         // draw text
 |         // draw text
 | ||||||
|         ImGui::Dummy({ icon_size, icon_size }); |         ImGui::Dummy({ icon_size, icon_size }); | ||||||
|         ImGui::SameLine(); |         ImGui::SameLine(); | ||||||
|         if (callback != nullptr) |         if (callback != nullptr) { | ||||||
|         { |  | ||||||
|             if (ImGui::MenuItem(label.c_str())) |             if (ImGui::MenuItem(label.c_str())) | ||||||
|                 callback(); |                 callback(); | ||||||
|         } |         } | ||||||
|  | @ -1114,8 +1062,7 @@ void GCodeViewer::render_legend() const | ||||||
|         if (step_size == 0.0f) |         if (step_size == 0.0f) | ||||||
|             // single item use case
 |             // single item use case
 | ||||||
|             add_range_item(0, range.min, decimals); |             add_range_item(0, range.min, decimals); | ||||||
|         else |         else { | ||||||
|         { |  | ||||||
|             for (int i = static_cast<int>(Range_Colors.size()) - 1; i >= 0; --i) { |             for (int i = static_cast<int>(Range_Colors.size()) - 1; i >= 0; --i) { | ||||||
|                 add_range_item(i, range.min + static_cast<float>(i) * step_size, decimals); |                 add_range_item(i, range.min + static_cast<float>(i) * step_size, decimals); | ||||||
|             } |             } | ||||||
|  | @ -1297,8 +1244,7 @@ void GCodeViewer::render_legend() const | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // travel paths
 |     // travel paths
 | ||||||
|     if (m_buffers[buffer_id(GCodeProcessor::EMoveType::Travel)].visible) |     if (m_buffers[buffer_id(GCodeProcessor::EMoveType::Travel)].visible) { | ||||||
|     { |  | ||||||
|         switch (m_view_type) |         switch (m_view_type) | ||||||
|         { |         { | ||||||
|         case EViewType::Feedrate: |         case EViewType::Feedrate: | ||||||
|  | @ -1347,8 +1293,7 @@ void GCodeViewer::render_legend() const | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     // options
 |     // options
 | ||||||
|     if (any_option_visible()) |     if (any_option_visible()) { | ||||||
|     { |  | ||||||
|         // title
 |         // title
 | ||||||
|         ImGui::Spacing(); |         ImGui::Spacing(); | ||||||
|         ImGui::Spacing(); |         ImGui::Spacing(); | ||||||
|  | @ -1386,19 +1331,19 @@ void GCodeViewer::render_statistics() const | ||||||
|     imgui.text(std::string("Load time:")); |     imgui.text(std::string("Load time:")); | ||||||
|     ImGui::PopStyleColor(); |     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, ORANGE); |     ImGui::PushStyleColor(ImGuiCol_Text, ORANGE); | ||||||
|     imgui.text(std::string("Resfresh time:")); |     imgui.text(std::string("Resfresh time:")); | ||||||
|     ImGui::PopStyleColor(); |     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, ORANGE); |     ImGui::PushStyleColor(ImGuiCol_Text, ORANGE); | ||||||
|     imgui.text(std::string("Resfresh paths time:")); |     imgui.text(std::string("Resfresh paths time:")); | ||||||
|     ImGui::PopStyleColor(); |     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(); | ||||||
| 
 | 
 | ||||||
|  | @ -1496,11 +1441,9 @@ void GCodeViewer::render_shaders_editor() const | ||||||
|     case 2: { set_shader("options_120_solid"); break; } |     case 2: { set_shader("options_120_solid"); break; } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (ImGui::CollapsingHeader("Options", ImGuiTreeNodeFlags_DefaultOpen)) |     if (ImGui::CollapsingHeader("Options", ImGuiTreeNodeFlags_DefaultOpen)) { | ||||||
|     { |  | ||||||
|         ImGui::SliderFloat("point size", &m_shaders_editor.point_size, 0.5f, 3.0f, "%.1f"); |         ImGui::SliderFloat("point size", &m_shaders_editor.point_size, 0.5f, 3.0f, "%.1f"); | ||||||
|         if (m_shaders_editor.shader_version == 1) |         if (m_shaders_editor.shader_version == 1) { | ||||||
|         { |  | ||||||
|             ImGui::SliderInt("percent outline", &m_shaders_editor.percent_outline, 0, 50); |             ImGui::SliderInt("percent outline", &m_shaders_editor.percent_outline, 0, 50); | ||||||
|             ImGui::SliderInt("percent center", &m_shaders_editor.percent_center, 0, 50); |             ImGui::SliderInt("percent center", &m_shaders_editor.percent_center, 0, 50); | ||||||
|         } |         } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966