mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Added "Color" parameter for SLA material
This commit is contained in:
		
							parent
							
								
									ddef93e78b
								
							
						
					
					
						commit
						2fcab52f86
					
				
					 5 changed files with 60 additions and 20 deletions
				
			
		|  | @ -534,6 +534,7 @@ static std::vector<std::string> s_Preset_sla_print_options { | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static std::vector<std::string> s_Preset_sla_material_options { | static std::vector<std::string> s_Preset_sla_material_options { | ||||||
|  |     "material_colour", | ||||||
|     "material_type", |     "material_type", | ||||||
|     "initial_layer_height", |     "initial_layer_height", | ||||||
|     "bottle_cost", |     "bottle_cost", | ||||||
|  |  | ||||||
|  | @ -3163,6 +3163,13 @@ void PrintConfigDef::init_sla_params() | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     // SLA Material settings.
 |     // SLA Material settings.
 | ||||||
|  | 
 | ||||||
|  |     def = this->add("material_colour", coStrings); | ||||||
|  |     def->label = L("Color"); | ||||||
|  |     def->tooltip = L("This is only used in the Slic3r interface as a visual help."); | ||||||
|  |     def->gui_type = ConfigOptionDef::GUIType::color; | ||||||
|  |     def->set_default_value(new ConfigOptionStrings{ "#29B2B2" }); | ||||||
|  | 
 | ||||||
|     def = this->add("material_type", coString); |     def = this->add("material_type", coString); | ||||||
|     def->label = L("SLA material type"); |     def->label = L("SLA material type"); | ||||||
|     def->tooltip = L("SLA material type"); |     def->tooltip = L("SLA material type"); | ||||||
|  |  | ||||||
|  | @ -1131,29 +1131,45 @@ void GLVolumeCollection::update_colors_by_extruder(const DynamicPrintConfig* con | ||||||
|     if (config == nullptr) |     if (config == nullptr) | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|     const ConfigOptionStrings* extruders_opt = dynamic_cast<const ConfigOptionStrings*>(config->option("extruder_colour")); |  | ||||||
|     if (extruders_opt == nullptr) |  | ||||||
|         return; |  | ||||||
| 
 |  | ||||||
|     const ConfigOptionStrings* filamemts_opt = dynamic_cast<const ConfigOptionStrings*>(config->option("filament_colour")); |  | ||||||
|     if (filamemts_opt == nullptr) |  | ||||||
|         return; |  | ||||||
| 
 |  | ||||||
|     unsigned int colors_count = std::max((unsigned int)extruders_opt->values.size(), (unsigned int)filamemts_opt->values.size()); |  | ||||||
|     if (colors_count == 0) |  | ||||||
|         return; |  | ||||||
| 
 |  | ||||||
|     std::vector<Color> colors(colors_count); |  | ||||||
| 
 |  | ||||||
|     unsigned char rgb[3]; |     unsigned char rgb[3]; | ||||||
|     for (unsigned int i = 0; i < colors_count; ++i) { |     std::vector<Color> colors; | ||||||
|         const std::string& txt_color = config->opt_string("extruder_colour", i); | 
 | ||||||
|  |     if (static_cast<PrinterTechnology>(config->opt_int("printer_technology")) == ptSLA)  | ||||||
|  |     { | ||||||
|  |         const ConfigOptionStrings* resin_clr = dynamic_cast<const ConfigOptionStrings*>(config->option("material_colour")); | ||||||
|  |         if (resin_clr == nullptr) | ||||||
|  |             return; | ||||||
|  |         assert(resin_clr->values.size() == 1); | ||||||
|  |         colors.resize(1); | ||||||
|  | 
 | ||||||
|  |         const std::string& txt_color = config->opt_string("material_colour", 0); | ||||||
|         if (Slic3r::GUI::BitmapCache::parse_color(txt_color, rgb)) |         if (Slic3r::GUI::BitmapCache::parse_color(txt_color, rgb)) | ||||||
|             colors[i].set(txt_color, rgb); |             colors[0].set(txt_color, rgb); | ||||||
|         else { |     } | ||||||
|             const std::string& txt_color = config->opt_string("filament_colour", i); |     else  | ||||||
|  |     { | ||||||
|  |         const ConfigOptionStrings* extruders_opt = dynamic_cast<const ConfigOptionStrings*>(config->option("extruder_colour")); | ||||||
|  |         if (extruders_opt == nullptr) | ||||||
|  |             return; | ||||||
|  | 
 | ||||||
|  |         const ConfigOptionStrings* filamemts_opt = dynamic_cast<const ConfigOptionStrings*>(config->option("filament_colour")); | ||||||
|  |         if (filamemts_opt == nullptr) | ||||||
|  |             return; | ||||||
|  | 
 | ||||||
|  |         unsigned int colors_count = std::max((unsigned int)extruders_opt->values.size(), (unsigned int)filamemts_opt->values.size()); | ||||||
|  |         if (colors_count == 0) | ||||||
|  |             return; | ||||||
|  |         colors.resize(colors_count); | ||||||
|  | 
 | ||||||
|  |         for (unsigned int i = 0; i < colors_count; ++i) { | ||||||
|  |             const std::string& txt_color = config->opt_string("extruder_colour", i); | ||||||
|             if (Slic3r::GUI::BitmapCache::parse_color(txt_color, rgb)) |             if (Slic3r::GUI::BitmapCache::parse_color(txt_color, rgb)) | ||||||
|                 colors[i].set(txt_color, rgb); |                 colors[i].set(txt_color, rgb); | ||||||
|  |             else { | ||||||
|  |                 const std::string& txt_color = config->opt_string("filament_colour", i); | ||||||
|  |                 if (Slic3r::GUI::BitmapCache::parse_color(txt_color, rgb)) | ||||||
|  |                     colors[i].set(txt_color, rgb); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1920,7 +1920,7 @@ Plater::priv::priv(Plater *q, MainFrame *main_frame) | ||||||
|         "bed_shape", "bed_custom_texture", "bed_custom_model", "complete_objects", "duplicate_distance", "extruder_clearance_radius", "skirts", "skirt_distance", |         "bed_shape", "bed_custom_texture", "bed_custom_model", "complete_objects", "duplicate_distance", "extruder_clearance_radius", "skirts", "skirt_distance", | ||||||
|         "brim_width", "brim_separation", "brim_type", "variable_layer_height", "nozzle_diameter", "single_extruder_multi_material", |         "brim_width", "brim_separation", "brim_type", "variable_layer_height", "nozzle_diameter", "single_extruder_multi_material", | ||||||
|         "wipe_tower", "wipe_tower_x", "wipe_tower_y", "wipe_tower_width", "wipe_tower_rotation_angle", "wipe_tower_brim_width", |         "wipe_tower", "wipe_tower_x", "wipe_tower_y", "wipe_tower_width", "wipe_tower_rotation_angle", "wipe_tower_brim_width", | ||||||
|         "extruder_colour", "filament_colour", "max_print_height", "printer_model", "printer_technology", |         "extruder_colour", "filament_colour", "material_colour", "max_print_height", "printer_model", "printer_technology", | ||||||
|         // These values are necessary to construct SlicingParameters by the Canvas3D variable layer height editor.
 |         // These values are necessary to construct SlicingParameters by the Canvas3D variable layer height editor.
 | ||||||
|         "layer_height", "first_layer_height", "min_layer_height", "max_layer_height", |         "layer_height", "first_layer_height", "min_layer_height", "max_layer_height", | ||||||
|         "brim_width", "perimeters", "perimeter_extruder", "fill_density", "infill_extruder", "top_solid_layers",  |         "brim_width", "perimeters", "perimeter_extruder", "fill_density", "infill_extruder", "top_solid_layers",  | ||||||
|  | @ -6222,6 +6222,15 @@ void Plater::on_config_change(const DynamicPrintConfig &config) | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|          |          | ||||||
|  |         if (opt_key == "material_colour") { | ||||||
|  |             update_scheduled = true; // update should be scheduled (for update 3DScene)
 | ||||||
|  | 
 | ||||||
|  |             // update material color in full config
 | ||||||
|  |             std::vector<std::string> material_colors = { config.opt_string("material_colour", (unsigned)0) }; | ||||||
|  |             p->config->option<ConfigOptionStrings>("material_colour")->values = material_colors; | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |          | ||||||
|         p->config->set_key_value(opt_key, config.option(opt_key)->clone()); |         p->config->set_key_value(opt_key, config.option(opt_key)->clone()); | ||||||
|         if (opt_key == "printer_technology") { |         if (opt_key == "printer_technology") { | ||||||
|             this->set_printer_technology(config.opt_enum<PrinterTechnology>(opt_key)); |             this->set_printer_technology(config.opt_enum<PrinterTechnology>(opt_key)); | ||||||
|  |  | ||||||
|  | @ -4157,6 +4157,7 @@ void TabSLAMaterial::build() | ||||||
|     auto page = add_options_page(L("Material"), "resin"); |     auto page = add_options_page(L("Material"), "resin"); | ||||||
| 
 | 
 | ||||||
|     auto optgroup = page->new_optgroup(L("Material")); |     auto optgroup = page->new_optgroup(L("Material")); | ||||||
|  |     optgroup->append_single_option_line("material_colour"); | ||||||
|     optgroup->append_single_option_line("bottle_cost"); |     optgroup->append_single_option_line("bottle_cost"); | ||||||
|     optgroup->append_single_option_line("bottle_volume"); |     optgroup->append_single_option_line("bottle_volume"); | ||||||
|     optgroup->append_single_option_line("bottle_weight"); |     optgroup->append_single_option_line("bottle_weight"); | ||||||
|  | @ -4164,6 +4165,12 @@ void TabSLAMaterial::build() | ||||||
| 
 | 
 | ||||||
|     optgroup->m_on_change = [this, optgroup](t_config_option_key opt_key, boost::any value) |     optgroup->m_on_change = [this, optgroup](t_config_option_key opt_key, boost::any value) | ||||||
|     { |     { | ||||||
|  |         if (opt_key == "material_colour") { | ||||||
|  |             update_dirty(); | ||||||
|  |             on_value_change(opt_key, value);  | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         DynamicPrintConfig new_conf = *m_config; |         DynamicPrintConfig new_conf = *m_config; | ||||||
| 
 | 
 | ||||||
|         if (opt_key == "bottle_volume") { |         if (opt_key == "bottle_volume") { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka