diff --git a/src/OrcaSlicer.cpp b/src/OrcaSlicer.cpp index 866bb39a21..f4cf0d70cd 100644 --- a/src/OrcaSlicer.cpp +++ b/src/OrcaSlicer.cpp @@ -3166,8 +3166,22 @@ int CLI::run(int argc, char **argv) std::vector& flush_multipliers = m_print_config.option("flush_multiplier", true)->values; flush_multipliers.resize(new_extruder_count, 1.f); - std::vector& nozzle_flush_dataset = m_print_config.option("filament_flush_dataset",true)->values; - nozzle_flush_dataset.resize(new_extruder_count, 0); + std::vector nozzle_flush_dataset(new_extruder_count, 0); + { + std::vector& nozzle_flush_dataset_full = m_print_config.option("nozzle_flush_dataset",true)->values; + if (m_print_config.has("printer_extruder_variant")) { + nozzle_flush_dataset_full.resize(m_print_config.option("printer_extruder_variant")->size(), 0); + } + auto extruders = m_print_config.option("extruder_type")->values; + auto volume_types = m_print_config.option("nozzle_volume_type")->values; // get volume type from 3mf + if(m_extra_config.has("nozzle_volume_type")) // get volume type from input + volume_types = m_extra_config.option("nozzle_volume_type")->values; + + for (int eidx = 0; eidx < new_extruder_count; ++eidx) { + int index = m_print_config.get_index_for_extruder(eidx + 1, "printer_extruder_id", ExtruderType(extruders[eidx]), NozzleVolumeType(volume_types[eidx]), "printer_extruder_variant"); + nozzle_flush_dataset[eidx] = nozzle_flush_dataset_full[index]; + } + } for (size_t nozzle_id = 0; nozzle_id < new_extruder_count; ++nozzle_id) { std::vector flush_vol_mtx = get_flush_volumes_matrix(flush_vol_matrix, nozzle_id, new_extruder_count);