mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Fixed conflicts after merge with master
This commit is contained in:
		
						commit
						b368f8ff24
					
				
					 41 changed files with 214 additions and 570 deletions
				
			
		|  | @ -1717,9 +1717,6 @@ namespace Slic3r { | |||
|                     break; | ||||
|                 } | ||||
|             } | ||||
| #if !ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|             Transform3d inv_matrix = volume_matrix_to_object.inverse(); | ||||
| #endif // !ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
| 
 | ||||
|             // splits volume out of imported geometry
 | ||||
| 			TriangleMesh triangle_mesh; | ||||
|  | @ -1739,15 +1736,7 @@ namespace Slic3r { | |||
|                 for (unsigned int v = 0; v < 3; ++v) | ||||
|                 { | ||||
|                     unsigned int tri_id = geometry.triangles[src_start_id + ii + v] * 3; | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|                     facet.vertex[v] = Vec3f(geometry.vertices[tri_id + 0], geometry.vertices[tri_id + 1], geometry.vertices[tri_id + 2]); | ||||
| #else | ||||
|                     Vec3f vertex(geometry.vertices[tri_id + 0], geometry.vertices[tri_id + 1], geometry.vertices[tri_id + 2]); | ||||
|                     facet.vertex[v] = has_transform ? | ||||
|                         // revert the vertices to the original mesh reference system
 | ||||
|                         (inv_matrix * vertex.cast<double>()).cast<float>() : | ||||
|                         vertex; | ||||
| #endif // ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|  | @ -1755,15 +1744,9 @@ namespace Slic3r { | |||
| 			triangle_mesh.repair(); | ||||
| 
 | ||||
| 			ModelVolume* volume = object.add_volume(std::move(triangle_mesh)); | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|             // stores the volume matrix taken from the metadata, if present
 | ||||
|             if (has_transform) | ||||
|                 volume->source.transform = Slic3r::Geometry::Transformation(volume_matrix_to_object); | ||||
| #else | ||||
|             // apply the volume matrix taken from the metadata, if present
 | ||||
|             if (has_transform) | ||||
|                 volume->set_transformation(Slic3r::Geometry::Transformation(volume_matrix_to_object)); | ||||
| #endif //ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|             volume->calculate_convex_hull(); | ||||
| 
 | ||||
|             // apply the remaining volume's metadata
 | ||||
|  | @ -2567,11 +2550,7 @@ namespace Slic3r { | |||
| 
 | ||||
|                             // stores volume's local matrix
 | ||||
|                             stream << "   <" << METADATA_TAG << " " << TYPE_ATTR << "=\"" << VOLUME_TYPE << "\" " << KEY_ATTR << "=\"" << MATRIX_KEY << "\" " << VALUE_ATTR << "=\""; | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|                             Transform3d matrix = volume->get_matrix() * volume->source.transform.get_matrix(); | ||||
| #else | ||||
|                             const Transform3d& matrix = volume->get_matrix(); | ||||
| #endif // ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|                             for (int r = 0; r < 4; ++r) | ||||
|                             { | ||||
|                                 for (int c = 0; c < 4; ++c) | ||||
|  |  | |||
|  | @ -585,36 +585,20 @@ void AMFParserContext::endElement(const char * /* name */) | |||
|         stl_allocate(&stl); | ||||
| 
 | ||||
|         bool has_transform = ! m_volume_transform.isApprox(Transform3d::Identity(), 1e-10); | ||||
| #if !ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|         Transform3d inv_matrix = m_volume_transform.inverse(); | ||||
| #endif // !ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|         for (size_t i = 0; i < m_volume_facets.size();) { | ||||
|             stl_facet &facet = stl.facet_start[i/3]; | ||||
|             for (unsigned int v = 0; v < 3; ++v) | ||||
|             { | ||||
|                 unsigned int tri_id = m_volume_facets[i++] * 3; | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|                 facet.vertex[v] = Vec3f(m_object_vertices[tri_id + 0], m_object_vertices[tri_id + 1], m_object_vertices[tri_id + 2]); | ||||
| #else | ||||
|                 Vec3f vertex(m_object_vertices[tri_id + 0], m_object_vertices[tri_id + 1], m_object_vertices[tri_id + 2]); | ||||
|                 facet.vertex[v] = has_transform ? | ||||
|                     // revert the vertices to the original mesh reference system
 | ||||
|                     (inv_matrix * vertex.cast<double>()).cast<float>() : | ||||
|                     vertex; | ||||
| #endif // ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|             } | ||||
|         }         | ||||
|         stl_get_size(&stl); | ||||
|         mesh.repair(); | ||||
| 		m_volume->set_mesh(std::move(mesh)); | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|         // stores the volume matrix taken from the metadata, if present
 | ||||
|         if (has_transform) | ||||
|             m_volume->source.transform = Slic3r::Geometry::Transformation(m_volume_transform); | ||||
| #else | ||||
|         if (has_transform) | ||||
|             m_volume->set_transformation(m_volume_transform); | ||||
| #endif // ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|         if (m_volume->source.input_file.empty() && (m_volume->type() == ModelVolumeType::MODEL_PART)) | ||||
|         { | ||||
|             m_volume->source.object_idx = (int)m_model.objects.size() - 1; | ||||
|  | @ -1163,11 +1147,7 @@ bool store_amf(const char *path, Model *model, const DynamicPrintConfig *config) | |||
|                 stream << "        <metadata type=\"slic3r.modifier\">1</metadata>\n"; | ||||
|             stream << "        <metadata type=\"slic3r.volume_type\">" << ModelVolume::type_to_string(volume->type()) << "</metadata>\n"; | ||||
|             stream << "        <metadata type=\"slic3r.matrix\">"; | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|             const Transform3d& matrix = volume->get_matrix() * volume->source.transform.get_matrix(); | ||||
| #else | ||||
|             const Transform3d& matrix = volume->get_matrix(); | ||||
| #endif // ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|             stream << std::setprecision(std::numeric_limits<double>::max_digits10); | ||||
|             for (int r = 0; r < 4; ++r) | ||||
|             { | ||||
|  |  | |||
|  | @ -1738,7 +1738,7 @@ namespace ProcessLayer | |||
|          | ||||
|         if (custom_gcode != nullptr) { | ||||
| 			// Extruder switches are processed by LayerTools, they should be filtered out.
 | ||||
| 			assert(custom_gcode->gcode != ExtruderChangeCode); | ||||
| 			assert(custom_gcode->gcode != ToolChangeCode); | ||||
| 
 | ||||
|             const std::string &custom_code = custom_gcode->gcode; | ||||
| 		    std::string pause_print_msg; | ||||
|  |  | |||
|  | @ -478,7 +478,7 @@ void ToolOrdering::assign_custom_gcodes(const Print &print) | |||
| 		for (unsigned int i : lt.extruders) | ||||
| 			extruder_printing_above[i] = true; | ||||
| 		// Skip all custom G-codes above this layer and skip all extruder switches.
 | ||||
| 		for (; custom_gcode_it != custom_gcode_per_print_z.gcodes.rend() && (custom_gcode_it->print_z > lt.print_z + EPSILON || custom_gcode_it->gcode == ExtruderChangeCode); ++ custom_gcode_it); | ||||
| 		for (; custom_gcode_it != custom_gcode_per_print_z.gcodes.rend() && (custom_gcode_it->print_z > lt.print_z + EPSILON || custom_gcode_it->gcode == ToolChangeCode); ++ custom_gcode_it); | ||||
| 		if (custom_gcode_it == custom_gcode_per_print_z.gcodes.rend()) | ||||
| 			// Custom G-codes were processed.
 | ||||
| 			break; | ||||
|  |  | |||
|  | @ -13,7 +13,7 @@ namespace Slic3r { | |||
| // Additional Codes which can be set by user using DoubleSlider
 | ||||
| static constexpr char ColorChangeCode[]     = "M600"; | ||||
| static constexpr char PausePrintCode[]      = "M601"; | ||||
| static constexpr char ExtruderChangeCode[]  = "tool_change"; | ||||
| static constexpr char ToolChangeCode[]  = "tool_change"; | ||||
| 
 | ||||
| class GCodeWriter { | ||||
| public: | ||||
|  |  | |||
|  | @ -1847,7 +1847,7 @@ std::vector<std::pair<double, unsigned int>> custom_tool_changes(const Model &mo | |||
| { | ||||
|     std::vector<std::pair<double, unsigned int>> custom_tool_changes; | ||||
|     for (const Model::CustomGCode &custom_gcode : model.custom_gcode_per_print_z.gcodes) | ||||
|         if (custom_gcode.gcode == ExtruderChangeCode) { | ||||
|         if (custom_gcode.gcode == ToolChangeCode) { | ||||
|             // If extruder count in PrinterSettings was changed, use default (0) extruder for extruders, more than num_extruders
 | ||||
|             custom_tool_changes.emplace_back(custom_gcode.print_z, static_cast<unsigned int>(custom_gcode.extruder > num_extruders ? 1 : custom_gcode.extruder)); | ||||
|         } | ||||
|  |  | |||
|  | @ -399,13 +399,9 @@ public: | |||
|         int object_idx{ -1 }; | ||||
|         int volume_idx{ -1 }; | ||||
|         Vec3d mesh_offset{ Vec3d::Zero() }; | ||||
| #if ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE | ||||
|         Geometry::Transformation transform; | ||||
| 
 | ||||
|         template<class Archive> void serialize(Archive& ar) { ar(input_file, object_idx, volume_idx, mesh_offset, transform); } | ||||
| #else | ||||
|         template<class Archive> void serialize(Archive& ar) { ar(input_file, object_idx, volume_idx, mesh_offset); } | ||||
| #endif // ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE
 | ||||
|     }; | ||||
|     Source              source; | ||||
| 
 | ||||
|  | @ -767,8 +763,9 @@ public: | |||
|          | ||||
|         double      print_z; | ||||
|         std::string gcode; | ||||
|         int         extruder;   // 0    - "gcode" will be applied for whole print
 | ||||
|                                 // else - "gcode" will be applied only for "extruder" print
 | ||||
|         int         extruder;   // Informative value for ColorChangeCode and ToolChangeCode
 | ||||
|                                 // "gcode" == ColorChangeCode   => M600 will be applied for "extruder" extruder
 | ||||
|                                 // "gcode" == ToolChangeCode    => for whole print tool will be switched to "extruder" extruder
 | ||||
|         std::string color;      // if gcode is equal to PausePrintCode, 
 | ||||
|                                 // this field is used for save a short message shown on Printer display 
 | ||||
|     }; | ||||
|  |  | |||
|  | @ -493,18 +493,18 @@ static bool layer_height_ranges_equal(const t_layer_config_ranges &lr1, const t_ | |||
|     return true; | ||||
| } | ||||
| 
 | ||||
| // Returns true if va == vb when all CustomGCode items that are not ExtruderChangeCode are ignored.
 | ||||
| // Returns true if va == vb when all CustomGCode items that are not ToolChangeCode are ignored.
 | ||||
| static bool custom_per_printz_gcodes_tool_changes_differ(const std::vector<Model::CustomGCode> &va, const std::vector<Model::CustomGCode> &vb) | ||||
| { | ||||
| 	auto it_a = va.begin(); | ||||
| 	auto it_b = vb.begin(); | ||||
| 	while (it_a != va.end() && it_b != vb.end()) { | ||||
| 		if (it_a != va.end() && it_a->gcode != ExtruderChangeCode) { | ||||
| 		if (it_a != va.end() && it_a->gcode != ToolChangeCode) { | ||||
| 			// Skip any CustomGCode items, which are not tool changes.
 | ||||
| 			++ it_a; | ||||
| 			continue; | ||||
| 		} | ||||
| 		if (it_b != vb.end() && it_b->gcode != ExtruderChangeCode) { | ||||
| 		if (it_b != vb.end() && it_b->gcode != ToolChangeCode) { | ||||
| 			// Skip any CustomGCode items, which are not tool changes.
 | ||||
| 			++ it_b; | ||||
| 			continue; | ||||
|  | @ -512,8 +512,8 @@ static bool custom_per_printz_gcodes_tool_changes_differ(const std::vector<Model | |||
| 		if (it_a == va.end() || it_b == vb.end()) | ||||
| 			// va or vb contains more Tool Changes than the other.
 | ||||
| 			return true; | ||||
| 		assert(it_a->gcode == ExtruderChangeCode); | ||||
| 		assert(it_b->gcode == ExtruderChangeCode); | ||||
| 		assert(it_a->gcode == ToolChangeCode); | ||||
| 		assert(it_b->gcode == ToolChangeCode); | ||||
| 		if (*it_a != *it_b) | ||||
| 			// The two Tool Changes differ.
 | ||||
| 			return true; | ||||
|  |  | |||
|  | @ -300,26 +300,14 @@ std::vector<double> layer_height_profile_adaptive(const SlicingParameters& slici | |||
|         layer_height_profile.push_back(print_z); | ||||
|         layer_height_profile.push_back(height); | ||||
|         print_z += height; | ||||
| #if !ENABLE_ADAPTIVE_LAYER_HEIGHT_PROFILE | ||||
|         layer_height_profile.push_back(print_z); | ||||
|         layer_height_profile.push_back(height); | ||||
| #endif // !ENABLE_ADAPTIVE_LAYER_HEIGHT_PROFILE
 | ||||
|     } | ||||
| 
 | ||||
| #if ENABLE_ADAPTIVE_LAYER_HEIGHT_PROFILE | ||||
|     double z_gap = slicing_params.object_print_z_height() - layer_height_profile[layer_height_profile.size() - 2]; | ||||
|     if (z_gap > 0.0) | ||||
|     { | ||||
|         layer_height_profile.push_back(slicing_params.object_print_z_height()); | ||||
|         layer_height_profile.push_back(clamp(slicing_params.min_layer_height, slicing_params.max_layer_height, z_gap)); | ||||
|     } | ||||
| #else | ||||
|     double last = std::max(slicing_params.first_object_layer_height, layer_height_profile[layer_height_profile.size() - 2]); | ||||
|     layer_height_profile.push_back(last); | ||||
|     layer_height_profile.push_back(slicing_params.first_object_layer_height); | ||||
|     layer_height_profile.push_back(slicing_params.object_print_z_height()); | ||||
|     layer_height_profile.push_back(slicing_params.first_object_layer_height); | ||||
| #endif // ENABLE_ADAPTIVE_LAYER_HEIGHT_PROFILE
 | ||||
| 
 | ||||
|     return layer_height_profile; | ||||
| } | ||||
|  |  | |||
|  | @ -41,24 +41,6 @@ | |||
| #define ENABLE_THUMBNAIL_GENERATOR (1 && ENABLE_2_2_0_ALPHA1) | ||||
| #define ENABLE_THUMBNAIL_GENERATOR_DEBUG (0 && ENABLE_THUMBNAIL_GENERATOR) | ||||
| 
 | ||||
| // Enable adaptive layer height profile
 | ||||
| #define ENABLE_ADAPTIVE_LAYER_HEIGHT_PROFILE (1 && ENABLE_2_2_0_ALPHA1) | ||||
| 
 | ||||
| // Enable grayed variant for gizmos icons in non activable state
 | ||||
| #define ENABLE_GIZMO_ICONS_NON_ACTIVABLE_STATE (1 && ENABLE_2_2_0_ALPHA1) | ||||
| 
 | ||||
| // Enable fix for view toolbar background not showing up on Mac with dark mode
 | ||||
| #define ENABLE_VIEW_TOOLBAR_BACKGROUND_FIX (1 && ENABLE_2_2_0_ALPHA1) | ||||
| 
 | ||||
| // Enable selection for missing files in reload from disk command
 | ||||
| #define ENABLE_RELOAD_FROM_DISK_MISSING_SELECTION (1 && ENABLE_2_2_0_ALPHA1) | ||||
| 
 | ||||
| // Enable closing 3Dconnextion imgui settings dialog by clicking on [X] and [Close] buttons
 | ||||
| #define ENABLE_3DCONNEXION_DEVICES_CLOSE_SETTING_DIALOG (1 && ENABLE_2_2_0_ALPHA1) | ||||
| 
 | ||||
| // Enable not applying volume transformation during 3mf and amf loading, but keeping it as a ModelVolume member
 | ||||
| #define ENABLE_KEEP_LOADED_VOLUME_TRANSFORM_AS_STAND_ALONE (1 && ENABLE_2_2_0_ALPHA1) | ||||
| 
 | ||||
| 
 | ||||
| //==================
 | ||||
| // 2.2.0.beta1 techs
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri