mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	New legend for color print.
Some improvements for coloration multimaterial print indicator
This commit is contained in:
		
							parent
							
								
									d5f7956a55
								
							
						
					
					
						commit
						6ed9adaeff
					
				
					 6 changed files with 270 additions and 48 deletions
				
			
		|  | @ -379,7 +379,10 @@ std::string GCodePreviewData::get_legend_title() const | ||||||
|     return ""; |     return ""; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std::vector<float>& tool_colors, const std::vector</*double*/std::pair<double, double>>& cp_values) const | // #ys_FIXME_COLOR
 | ||||||
|  | // GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std::vector<float>& tool_colors, const std::vector</*double*/std::pair<double, double>>& cp_values) const
 | ||||||
|  | GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std::vector<float>& tool_colors,  | ||||||
|  |                                                     const std::vector<std::string>& cp_items, bool is_single_material_print) const | ||||||
| { | { | ||||||
|     struct Helper |     struct Helper | ||||||
|     { |     { | ||||||
|  | @ -452,11 +455,17 @@ GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std:: | ||||||
| 
 | 
 | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     case Extrusion::ColorPrint: |     // #ys_FIXME_COLOR
 | ||||||
|  |     /*case Extrusion::ColorPrint:
 | ||||||
|         { |         { | ||||||
|             const int color_cnt = (int)tool_colors.size()/4; |             const int color_cnt = (int)tool_colors.size()/4; | ||||||
| 
 |  | ||||||
|             const auto color_print_cnt = (int)cp_values.size(); |             const auto color_print_cnt = (int)cp_values.size(); | ||||||
|  |             if (color_print_cnt > 0) { | ||||||
|  |                 GCodePreviewData::Color color; | ||||||
|  |                 ::memcpy((void*)color.rgba, (const void*)(tool_colors.data() + (color_cnt-1) * 4), 4 * sizeof(float)); | ||||||
|  |                 items.emplace_back(Slic3r::I18N::translate(L("Pause print or custom G-code")), color); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|             for (int i = color_print_cnt; i >= 0 ; --i) |             for (int i = color_print_cnt; i >= 0 ; --i) | ||||||
|             { |             { | ||||||
|                 GCodePreviewData::Color color; |                 GCodePreviewData::Color color; | ||||||
|  | @ -482,6 +491,33 @@ GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std:: | ||||||
|                 items.emplace_back(id_str + (boost::format(Slic3r::I18N::translate(L("%.2f - %.2f mm"))) % cp_values[i - 1].second% cp_values[i].first).str(), color); |                 items.emplace_back(id_str + (boost::format(Slic3r::I18N::translate(L("%.2f - %.2f mm"))) % cp_values[i - 1].second% cp_values[i].first).str(), color); | ||||||
|             } |             } | ||||||
|             break; |             break; | ||||||
|  |         }*/ | ||||||
|  |     case Extrusion::ColorPrint: | ||||||
|  |         { | ||||||
|  |             const int color_cnt = (int)tool_colors.size()/4; | ||||||
|  |             const auto color_print_cnt = (int)cp_items.size(); | ||||||
|  |             if (color_print_cnt == 1) // means "Default print color"
 | ||||||
|  |             { | ||||||
|  |                 Color color; | ||||||
|  |                 ::memcpy((void*)color.rgba, (const void*)(tool_colors.data()), 4 * sizeof(float)); | ||||||
|  | 
 | ||||||
|  |                 items.emplace_back(cp_items[0], color); | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (color_cnt != color_print_cnt) | ||||||
|  |                 break; | ||||||
|  | 
 | ||||||
|  |             for (int i = is_single_material_print ? color_print_cnt-1 : 0 ;  | ||||||
|  |                      is_single_material_print ? i >= 0 : i < color_print_cnt; | ||||||
|  |                      is_single_material_print ? --i : ++i) | ||||||
|  |             { | ||||||
|  |                 Color color; | ||||||
|  |                 ::memcpy((void*)color.rgba, (const void*)(tool_colors.data() + (i % color_cnt) * 4), 4 * sizeof(float)); | ||||||
|  |                  | ||||||
|  |                 items.emplace_back(cp_items[i], color); | ||||||
|  |             } | ||||||
|  |             break; | ||||||
|         } |         } | ||||||
|     case Extrusion::Num_View_Types: |     case Extrusion::Num_View_Types: | ||||||
|         break; // just to supress warning about non-handled value
 |         break; // just to supress warning about non-handled value
 | ||||||
|  |  | ||||||
|  | @ -237,7 +237,9 @@ public: | ||||||
|     void set_extrusion_paths_colors(const std::vector<std::string>& colors); |     void set_extrusion_paths_colors(const std::vector<std::string>& colors); | ||||||
| 
 | 
 | ||||||
|     std::string get_legend_title() const; |     std::string get_legend_title() const; | ||||||
|     LegendItemsList get_legend_items(const std::vector<float>& tool_colors, const std::vector</*double*/std::pair<double, double>>& cp_values) const; |     // #ys_FIXME_COLOR
 | ||||||
|  |     // LegendItemsList get_legend_items(const std::vector<float>& tool_colors, const std::vector</*double*/std::pair<double, double>>& cp_values) const;
 | ||||||
|  |     LegendItemsList get_legend_items(const std::vector<float>& tool_colors, const std::vector<std::string>& cp_items, bool is_single_material_print) const; | ||||||
| 
 | 
 | ||||||
|     // Return an estimate of the memory consumed by the time estimator.
 |     // Return an estimate of the memory consumed by the time estimator.
 | ||||||
|     size_t memory_used() const; |     size_t memory_used() const; | ||||||
|  |  | ||||||
|  | @ -886,6 +886,74 @@ void GLCanvas3D::LegendTexture::fill_color_print_legend_values(const GCodePrevie | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void GLCanvas3D::LegendTexture::fill_color_print_legend_items(const GCodePreviewData& preview_data, const GLCanvas3D& canvas, | ||||||
|  |                                                               std::vector<std::string>& cp_legend_items) | ||||||
|  | { | ||||||
|  |     if (preview_data.extrusion.view_type != GCodePreviewData::Extrusion::ColorPrint ) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     std::vector<Model::CustomGCode> custom_gcode_per_height = wxGetApp().plater()->model().custom_gcode_per_height; | ||||||
|  |     if (custom_gcode_per_height.empty()) { | ||||||
|  |         cp_legend_items.push_back(I18N::translate_utf8(L("Default print color"))); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     const int extruders_cnt = wxGetApp().extruders_edited_cnt(); | ||||||
|  | 
 | ||||||
|  |     if (extruders_cnt == 1)  | ||||||
|  |     { | ||||||
|  |         std::vector<std::pair<double, double>> cp_values; | ||||||
|  |          | ||||||
|  |         std::vector<double> print_zs = canvas.get_current_print_zs(true); | ||||||
|  |         for (auto custom_code : custom_gcode_per_height) | ||||||
|  |         { | ||||||
|  |             if (custom_code.gcode != "M600") | ||||||
|  |                 continue; | ||||||
|  |             auto lower_b = std::lower_bound(print_zs.begin(), print_zs.end(), custom_code.height - DoubleSlider::epsilon()); | ||||||
|  | 
 | ||||||
|  |             if (lower_b == print_zs.end()) | ||||||
|  |                 continue; | ||||||
|  | 
 | ||||||
|  |             double current_z = *lower_b; | ||||||
|  |             double previous_z = lower_b == print_zs.begin() ? 0.0 : *(--lower_b); | ||||||
|  | 
 | ||||||
|  |             // to avoid duplicate values, check adding values
 | ||||||
|  |             if (cp_values.empty() || | ||||||
|  |                 !(cp_values.back().first == previous_z && cp_values.back().second == current_z)) | ||||||
|  |                 cp_values.push_back(std::pair<double, double>(previous_z, current_z)); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         const auto items_cnt = (int)cp_values.size(); | ||||||
|  | 
 | ||||||
|  |         for (int i = 0; items_cnt > 0 && i <= items_cnt; ++i) | ||||||
|  |         { | ||||||
|  |             std::string id_str = std::to_string(i + 1) + ": "; | ||||||
|  | 
 | ||||||
|  |             if (i == 0) { | ||||||
|  |                 cp_legend_items.push_back(id_str + (boost::format(I18N::translate_utf8(L("up to %.2f mm"))) % cp_values[0].first).str()); | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             if (i == items_cnt) { | ||||||
|  |                 cp_legend_items.push_back(id_str + (boost::format(I18N::translate_utf8(L("above %.2f mm"))) % cp_values[i - 1].second).str()); | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             cp_legend_items.push_back(id_str + (boost::format(I18N::translate_utf8(L("%.2f - %.2f mm"))) % cp_values[i - 1].second % cp_values[i].first).str()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         for (unsigned int i = 0; i < extruders_cnt; ++i) | ||||||
|  |             cp_legend_items.push_back((boost::format(I18N::translate_utf8(L("Extruder %d"))) % (i + 1)).str()); | ||||||
|  |          | ||||||
|  |         for (auto custom_code : custom_gcode_per_height) | ||||||
|  |             if (custom_code.gcode == "M600") | ||||||
|  |                 cp_legend_items.push_back((boost::format(I18N::translate_utf8(L("Color change for Extruder %d at %.2f mm"))) % custom_code.extruder % custom_code.height).str()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     cp_legend_items.push_back(I18N::translate_utf8(L("Pause print or custom G-code"))); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool GLCanvas3D::LegendTexture::generate(const GCodePreviewData& preview_data, const std::vector<float>& tool_colors, const GLCanvas3D& canvas, bool compress) | bool GLCanvas3D::LegendTexture::generate(const GCodePreviewData& preview_data, const std::vector<float>& tool_colors, const GLCanvas3D& canvas, bool compress) | ||||||
| { | { | ||||||
|     reset(); |     reset(); | ||||||
|  | @ -893,10 +961,17 @@ bool GLCanvas3D::LegendTexture::generate(const GCodePreviewData& preview_data, c | ||||||
|     // collects items to render
 |     // collects items to render
 | ||||||
|     auto title = _(preview_data.get_legend_title()); |     auto title = _(preview_data.get_legend_title()); | ||||||
| 
 | 
 | ||||||
|     std::vector<std::pair<double, double>> cp_legend_values; |     // #ys_FIXME_COLOR
 | ||||||
|     fill_color_print_legend_values(preview_data, canvas, cp_legend_values); |     // std::vector<std::pair<double, double>> cp_legend_values;
 | ||||||
|  |     // fill_color_print_legend_values(preview_data, canvas, cp_legend_values);
 | ||||||
| 
 | 
 | ||||||
|     const GCodePreviewData::LegendItemsList& items = preview_data.get_legend_items(tool_colors, cp_legend_values); |     // const GCodePreviewData::LegendItemsList& items = preview_data.get_legend_items(tool_colors, cp_legend_values);
 | ||||||
|  | 
 | ||||||
|  |     std::vector<std::string> cp_legend_items; | ||||||
|  |     cp_legend_items.reserve(tool_colors.size()); | ||||||
|  |     fill_color_print_legend_items(preview_data, canvas, cp_legend_items); | ||||||
|  | 
 | ||||||
|  |     const GCodePreviewData::LegendItemsList& items = preview_data.get_legend_items(tool_colors, cp_legend_items, wxGetApp().extruders_edited_cnt() == 1); | ||||||
| 
 | 
 | ||||||
|     unsigned int items_count = (unsigned int)items.size(); |     unsigned int items_count = (unsigned int)items.size(); | ||||||
|     if (items_count == 0) |     if (items_count == 0) | ||||||
|  | @ -4729,13 +4804,38 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|                 const std::string& code = it->gcode; |                 const std::string& code = it->gcode; | ||||||
|                 // pause print or custom Gcode
 |                 // pause print or custom Gcode
 | ||||||
|                 if (code == "M601" || (code != "M600" && code != "tool_change")) |                 if (code == "M601" || (code != "M600" && code != "tool_change")) | ||||||
|                     return number_tools(); |                     return number_tools()-1; // last color item is a gray color for pause print or custom G-code 
 | ||||||
| 
 | 
 | ||||||
|                 // change tool (extruder) 
 |                 // change tool (extruder) 
 | ||||||
|                 if (code == "tool_change") |                 if (code == "tool_change") { | ||||||
|  |                     if (number_tools() == extruders_cnt+1) | ||||||
|                         return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); |                         return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); | ||||||
|  | 
 | ||||||
|  |                     auto it_n = it; | ||||||
|  |                     bool apply_color_change = false; | ||||||
|  |                     while (it_n != color_print_values->begin()) { | ||||||
|  |                         --it_n; | ||||||
|  |                         if (it_n->gcode == "M600" && it_n->extruder == it->extruder) { | ||||||
|  |                             apply_color_change = true; | ||||||
|  |                             break; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     if (apply_color_change) | ||||||
|  |                     { | ||||||
|  |                         int shift = 0; | ||||||
|  |                         while (it_n != color_print_values->begin()) { | ||||||
|  |                             --it_n; | ||||||
|  |                             if (it_n->gcode == "M600") | ||||||
|  |                                 shift++; | ||||||
|  |                         } | ||||||
|  |                         return extruders_cnt + shift; | ||||||
|  |                     } | ||||||
|  |                      | ||||||
|  |                     return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); | ||||||
|  |                 } | ||||||
|                 // change color for current extruder
 |                 // change color for current extruder
 | ||||||
|                 if (code == "M600" && it->extruder == extruder) { |                 if (code == "M600") { | ||||||
|  |                     if (it->extruder == extruder) { | ||||||
|                         int shift = 0; |                         int shift = 0; | ||||||
|                         while (it != color_print_values->begin()) { |                         while (it != color_print_values->begin()) { | ||||||
|                             --it; |                             --it; | ||||||
|  | @ -4744,6 +4844,32 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|                         } |                         } | ||||||
|                         return extruders_cnt + shift; |                         return extruders_cnt + shift; | ||||||
|                     } |                     } | ||||||
|  |                      | ||||||
|  |                     if (is_single_material_print) | ||||||
|  |                     { | ||||||
|  |                         auto it_n = it; | ||||||
|  |                         bool apply_color_change = false; | ||||||
|  |                         while (it_n != color_print_values->begin()) { | ||||||
|  |                             --it_n; | ||||||
|  |                             if (it_n->gcode == "tool_change") { | ||||||
|  |                                 if (it_n->extruder == it->extruder) | ||||||
|  |                                     apply_color_change = true; | ||||||
|  |                                 break; | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  | 
 | ||||||
|  |                         if (apply_color_change) | ||||||
|  |                         { | ||||||
|  |                             int shift = 0; | ||||||
|  |                             while (it != color_print_values->begin()) { | ||||||
|  |                                 --it; | ||||||
|  |                                 if (it->gcode == "M600") | ||||||
|  |                                     shift++; | ||||||
|  |                             } | ||||||
|  |                             return extruders_cnt + shift; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             const Model::CustomGCode value(print_z + EPSILON, "", 0, ""); |             const Model::CustomGCode value(print_z + EPSILON, "", 0, ""); | ||||||
|  | @ -4753,8 +4879,60 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|                 --it; |                 --it; | ||||||
|                 const std::string& code = it->gcode; |                 const std::string& code = it->gcode; | ||||||
|                 // change color for current extruder
 |                 // change color for current extruder
 | ||||||
|                 if (code == "M600" && it->extruder == extruder) { |                 if (code == "M600") | ||||||
|  |                 { | ||||||
|  |                     if (it->extruder == extruder) { | ||||||
|  |                         int shift = 0; | ||||||
|  |                         while (it != color_print_values->begin()) { | ||||||
|  |                             --it; | ||||||
|  |                             if (it->gcode == "M600") | ||||||
|  |                                 shift++; | ||||||
|  |                         } | ||||||
|  |                         return extruders_cnt + shift; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     if (is_single_material_print) | ||||||
|  |                     { | ||||||
|                         auto it_n = it; |                         auto it_n = it; | ||||||
|  |                         bool apply_color_change = false; | ||||||
|  |                         while (it_n != color_print_values->begin()) { | ||||||
|  |                             --it_n; | ||||||
|  |                             if (it_n->gcode == "tool_change") { | ||||||
|  |                                 if (it_n->extruder == it->extruder) | ||||||
|  |                                     apply_color_change = true; | ||||||
|  |                                 break; | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  | 
 | ||||||
|  |                         if (apply_color_change) | ||||||
|  |                         { | ||||||
|  |                             int shift = 0; | ||||||
|  |                             while (it != color_print_values->begin()) { | ||||||
|  |                                 --it; | ||||||
|  |                                 if (it->gcode == "M600") | ||||||
|  |                                     shift++; | ||||||
|  |                             } | ||||||
|  |                             return extruders_cnt + shift; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 // change tool (extruder) 
 | ||||||
|  |                 if (code == "tool_change") | ||||||
|  |                 { | ||||||
|  |                     if (number_tools() == extruders_cnt + 1) | ||||||
|  |                         return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); | ||||||
|  | 
 | ||||||
|  |                     auto it_n = it; | ||||||
|  |                     bool apply_color_change = false; | ||||||
|  |                     while (it_n != color_print_values->begin()) { | ||||||
|  |                         --it_n; | ||||||
|  |                         if (it_n->gcode == "M600" && it_n->extruder == it->extruder) { | ||||||
|  |                             apply_color_change = true; | ||||||
|  |                             break; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     if (apply_color_change) | ||||||
|  |                     { | ||||||
|                         int shift = 0; |                         int shift = 0; | ||||||
|                         while (it_n != color_print_values->begin()) { |                         while (it_n != color_print_values->begin()) { | ||||||
|                             --it_n; |                             --it_n; | ||||||
|  | @ -4763,10 +4941,10 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|                         } |                         } | ||||||
|                         return extruders_cnt + shift; |                         return extruders_cnt + shift; | ||||||
|                     } |                     } | ||||||
|                 // change tool (extruder) 
 | 
 | ||||||
|                 if (code == "tool_change") |  | ||||||
|                     return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); |                     return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             return std::min<int>(extruders_cnt - 1, std::max<int>(extruder - 1, 0));; |             return std::min<int>(extruders_cnt - 1, std::max<int>(extruder - 1, 0));; | ||||||
|         } |         } | ||||||
|  | @ -4827,14 +5005,14 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|         auto                volume = [&ctxt, &vols, &color_print_layer_to_glvolume, &range](size_t layer_idx, int extruder, int feature) -> GLVolume& {             |         auto                volume = [&ctxt, &vols, &color_print_layer_to_glvolume, &range](size_t layer_idx, int extruder, int feature) -> GLVolume& {             | ||||||
|             return *vols[ctxt.color_by_color_print()? |             return *vols[ctxt.color_by_color_print()? | ||||||
|             	//color_print_layer_to_glvolume[layer_idx - range.begin()] :
 |             	//color_print_layer_to_glvolume[layer_idx - range.begin()] :
 | ||||||
|                 ctxt.color_print_color_idx_by_layer_idx_and_extruder(layer_idx/* - range.begin()*/, extruder) : |                 ctxt.color_print_color_idx_by_layer_idx_and_extruder(layer_idx, extruder) : | ||||||
| 				ctxt.color_by_tool() ?  | 				ctxt.color_by_tool() ?  | ||||||
| 					std::min<int>(ctxt.number_tools() - 1, std::max<int>(extruder - 1, 0)) :  | 					std::min<int>(ctxt.number_tools() - 1, std::max<int>(extruder - 1, 0)) :  | ||||||
| 					feature | 					feature | ||||||
| 				]; | 				]; | ||||||
|         }; |         }; | ||||||
|         if (ctxt.color_by_color_print()) { |         /*if (ctxt.color_by_color_print()) {
 | ||||||
|         /*	// Create a map from the layer index to a GLVolume, which is initialized with the correct layer span color.
 |         	// Create a map from the layer index to a GLVolume, which is initialized with the correct layer span color.
 | ||||||
|         	std::vector<int> color_print_tool_to_glvolume(ctxt.number_tools(), -1); |         	std::vector<int> color_print_tool_to_glvolume(ctxt.number_tools(), -1); | ||||||
|         	color_print_layer_to_glvolume.reserve(range.end() - range.begin()); |         	color_print_layer_to_glvolume.reserve(range.end() - range.begin()); | ||||||
|         	vols.reserve(ctxt.number_tools()); |         	vols.reserve(ctxt.number_tools()); | ||||||
|  | @ -4847,12 +5025,12 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
| 	        	color_print_layer_to_glvolume.emplace_back(color_print_tool_to_glvolume[idx_tool]); | 	        	color_print_layer_to_glvolume.emplace_back(color_print_tool_to_glvolume[idx_tool]); | ||||||
| 	        } | 	        } | ||||||
|             vols.emplace_back(new_volume(ctxt.color_pause_or_custom_code())); |             vols.emplace_back(new_volume(ctxt.color_pause_or_custom_code())); | ||||||
|         }*/ |         } | ||||||
|             for (size_t i = 0; i < ctxt.number_tools(); ++i) |             for (size_t i = 0; i < ctxt.number_tools(); ++i) | ||||||
|                 vols.emplace_back(new_volume(ctxt.color_tool(i))); |                 vols.emplace_back(new_volume(ctxt.color_tool(i))); | ||||||
|             vols.emplace_back(new_volume(ctxt.color_pause_or_custom_code())); |             vols.emplace_back(new_volume(ctxt.color_pause_or_custom_code())); | ||||||
|         } |         } | ||||||
|         else if (ctxt.color_by_tool()) { |         else */if (ctxt.color_by_color_print() || ctxt.color_by_tool()) { | ||||||
|             for (size_t i = 0; i < ctxt.number_tools(); ++i) |             for (size_t i = 0; i < ctxt.number_tools(); ++i) | ||||||
|                 vols.emplace_back(new_volume(ctxt.color_tool(i))); |                 vols.emplace_back(new_volume(ctxt.color_tool(i))); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -348,6 +348,9 @@ private: | ||||||
|         void fill_color_print_legend_values(const GCodePreviewData& preview_data, const GLCanvas3D& canvas, |         void fill_color_print_legend_values(const GCodePreviewData& preview_data, const GLCanvas3D& canvas, | ||||||
|                                      std::vector<std::pair<double, double>>& cp_legend_values); |                                      std::vector<std::pair<double, double>>& cp_legend_values); | ||||||
| 
 | 
 | ||||||
|  |         void fill_color_print_legend_items(const GCodePreviewData& preview_data, const GLCanvas3D& canvas, | ||||||
|  |                                      std::vector<std::string>& cp_legend_items); | ||||||
|  | 
 | ||||||
|         bool generate(const GCodePreviewData& preview_data, const std::vector<float>& tool_colors, const GLCanvas3D& canvas, bool compress); |         bool generate(const GCodePreviewData& preview_data, const std::vector<float>& tool_colors, const GLCanvas3D& canvas, bool compress); | ||||||
| 
 | 
 | ||||||
|         void render(const GLCanvas3D& canvas) const; |         void render(const GLCanvas3D& canvas) const; | ||||||
|  |  | ||||||
|  | @ -892,6 +892,7 @@ void Preview::load_print_as_fff(bool keep_z_range) | ||||||
|         for (const Model::CustomGCode& code : color_print_values) |         for (const Model::CustomGCode& code : color_print_values) | ||||||
|             if (code.gcode == "M600") |             if (code.gcode == "M600") | ||||||
|                 colors.push_back(code.color); |                 colors.push_back(code.color); | ||||||
|  |         colors.push_back("#808080"); // gray color for pause print or custom G-code 
 | ||||||
| 
 | 
 | ||||||
|         if (gcode_preview_data_valid) |         if (gcode_preview_data_valid) | ||||||
|             color_print_values.clear(); |             color_print_values.clear(); | ||||||
|  |  | ||||||
|  | @ -3306,23 +3306,6 @@ void DoubleSlider::move_current_thumb(const bool condition) | ||||||
|     ProcessWindowEvent(e); |     ProcessWindowEvent(e); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static std::string get_new_color(const std::string& color) |  | ||||||
| { |  | ||||||
|     wxColour clr(color); |  | ||||||
|     if (!clr.IsOk()) |  | ||||||
|         clr = wxColour(0, 0, 0); // Don't set alfa to transparence
 |  | ||||||
| 
 |  | ||||||
|     auto data = new wxColourData(); |  | ||||||
|     data->SetChooseFull(1); |  | ||||||
|     data->SetColour(clr); |  | ||||||
| 
 |  | ||||||
|     wxColourDialog dialog(nullptr, data); |  | ||||||
|     dialog.CenterOnParent(); |  | ||||||
|     if (dialog.ShowModal() == wxID_OK) |  | ||||||
|         return dialog.GetColourData().GetColour().GetAsString(wxC2S_HTML_SYNTAX).ToStdString(); |  | ||||||
|     return color; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void DoubleSlider::action_tick(const TicksAction action) | void DoubleSlider::action_tick(const TicksAction action) | ||||||
| { | { | ||||||
|     if (m_selection == ssUndef) |     if (m_selection == ssUndef) | ||||||
|  | @ -3558,6 +3541,23 @@ void DoubleSlider::OnRightUp(wxMouseEvent& event) | ||||||
|     event.Skip(); |     event.Skip(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static std::string get_new_color(const std::string& color) | ||||||
|  | { | ||||||
|  |     wxColour clr(color); | ||||||
|  |     if (!clr.IsOk()) | ||||||
|  |         clr = wxColour(0, 0, 0); // Don't set alfa to transparence
 | ||||||
|  | 
 | ||||||
|  |     auto data = new wxColourData(); | ||||||
|  |     data->SetChooseFull(1); | ||||||
|  |     data->SetColour(clr); | ||||||
|  | 
 | ||||||
|  |     wxColourDialog dialog(nullptr, data); | ||||||
|  |     dialog.CenterOnParent(); | ||||||
|  |     if (dialog.ShowModal() == wxID_OK) | ||||||
|  |         return dialog.GetColourData().GetColour().GetAsString(wxC2S_HTML_SYNTAX).ToStdString(); | ||||||
|  |     return ""; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void DoubleSlider::add_code(std::string code, int selected_extruder/* = -1*/) | void DoubleSlider::add_code(std::string code, int selected_extruder/* = -1*/) | ||||||
| { | { | ||||||
|     const int tick = m_selection == ssLower ? m_lower_value : m_higher_value; |     const int tick = m_selection == ssLower ? m_lower_value : m_higher_value; | ||||||
|  | @ -3570,6 +3570,8 @@ void DoubleSlider::add_code(std::string code, int selected_extruder/* = -1*/) | ||||||
|         { |         { | ||||||
|             std::vector<std::string> colors = Slic3r::GUI::wxGetApp().plater()->get_extruder_colors_from_plater_config(); |             std::vector<std::string> colors = Slic3r::GUI::wxGetApp().plater()->get_extruder_colors_from_plater_config(); | ||||||
|             color = get_new_color(colors[selected_extruder > 0 ? selected_extruder-1 : 0]); |             color = get_new_color(colors[selected_extruder > 0 ? selected_extruder-1 : 0]); | ||||||
|  |             if (color.empty()) | ||||||
|  |                 return; | ||||||
|         } |         } | ||||||
|         else if (code.empty()) |         else if (code.empty()) | ||||||
|         { |         { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka