mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Initial interface for slice index.
This commit is contained in:
		
							parent
							
								
									da0b9b9b75
								
							
						
					
					
						commit
						f76560bcc5
					
				
					 2 changed files with 109 additions and 72 deletions
				
			
		|  | @ -40,7 +40,8 @@ const std::array<unsigned, slaposCount>     OBJ_STEP_LEVELS = | ||||||
|     20,     // slaposSupportPoints,
 |     20,     // slaposSupportPoints,
 | ||||||
|     25,     // slaposSupportTree,
 |     25,     // slaposSupportTree,
 | ||||||
|     25,     // slaposBasePool,
 |     25,     // slaposBasePool,
 | ||||||
|     10      // slaposSliceSupports,
 |     5,      // slaposSliceSupports,
 | ||||||
|  |     5       // slaposIndexSlices
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const std::array<std::string, slaposCount> OBJ_STEP_LABELS = | const std::array<std::string, slaposCount> OBJ_STEP_LABELS = | ||||||
|  | @ -50,7 +51,8 @@ const std::array<std::string, slaposCount> OBJ_STEP_LABELS = | ||||||
|     L("Scanning model structure"),      // slaposSupportPoints,
 |     L("Scanning model structure"),      // slaposSupportPoints,
 | ||||||
|     L("Generating support tree"),       // slaposSupportTree,
 |     L("Generating support tree"),       // slaposSupportTree,
 | ||||||
|     L("Generating base pool"),          // slaposBasePool,
 |     L("Generating base pool"),          // slaposBasePool,
 | ||||||
|     L("Slicing supports")               // slaposSliceSupports,
 |     L("Slicing supports"),              // slaposSliceSupports,
 | ||||||
|  |     L("Slicing supports")               // slaposIndexSlices,
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // Should also add up to 100 (%)
 | // Should also add up to 100 (%)
 | ||||||
|  | @ -548,84 +550,88 @@ void SLAPrint::process() | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     // Rasterizing the model objects, and their supports
 |     using Layer = sla::ExPolygons; | ||||||
|     auto rasterize = [this, ilh, ilhd, max_objstatus]() { |     using LayerCopies = std::vector<SLAPrintObject::Instance>; | ||||||
|         using Layer = sla::ExPolygons; |     struct LayerRef { | ||||||
|         using LayerCopies = std::vector<SLAPrintObject::Instance>; |         std::reference_wrapper<const Layer> lref; | ||||||
|         struct LayerRef { |         std::reference_wrapper<const LayerCopies> copies; | ||||||
|             std::reference_wrapper<const Layer> lref; |         LayerRef(const Layer& lyr, const LayerCopies& cp) : | ||||||
|             std::reference_wrapper<const LayerCopies> copies; |             lref(std::cref(lyr)), copies(std::cref(cp)) {} | ||||||
|             LayerRef(const Layer& lyr, const LayerCopies& cp) : |     }; | ||||||
|                 lref(std::cref(lyr)), copies(std::cref(cp)) {} |  | ||||||
|         }; |  | ||||||
| 
 | 
 | ||||||
|         using LevelID = long long; |     using LevelID = long long; | ||||||
|         using LayerRefs = std::vector<LayerRef>; |     using LayerRefs = std::vector<LayerRef>; | ||||||
| 
 |     // layers according to quantized height levels
 | ||||||
|         // layers according to quantized height levels
 |     std::map<LevelID, LayerRefs> levels; | ||||||
|         std::map<LevelID, LayerRefs> levels; |  | ||||||
| 
 | 
 | ||||||
|  |     auto index_slices = [this, ilh, ilhd, &levels](SLAPrintObject& po) { | ||||||
|         auto sih = LevelID(scale_(ilh)); |         auto sih = LevelID(scale_(ilh)); | ||||||
| 
 | 
 | ||||||
|         // For all print objects, go through its initial layers and place them
 |         // For all print objects, go through its initial layers and place them
 | ||||||
|         // into the layers hash
 |         // into the layers hash
 | ||||||
|         for(SLAPrintObject *o : m_objects) { |         auto bb = po.transformed_mesh().bounding_box(); | ||||||
|             auto bb = o->transformed_mesh().bounding_box(); |         double modelgnd = bb.min(Z); | ||||||
|             double modelgnd = bb.min(Z); |         double elevation = po.get_elevation(); | ||||||
|             double elevation = o->get_elevation(); |         double lh = po.m_config.layer_height.getFloat(); | ||||||
|             double lh = o->m_config.layer_height.getFloat(); |         double minZ = modelgnd - elevation; | ||||||
|             double minZ = modelgnd - elevation; |  | ||||||
| 
 | 
 | ||||||
|             // scaled values:
 |         // scaled values:
 | ||||||
|             auto sminZ = LevelID(scale_(minZ)); |         auto sminZ = LevelID(scale_(minZ)); | ||||||
|             auto smaxZ = LevelID(scale_(bb.max(Z))); |         auto smaxZ = LevelID(scale_(bb.max(Z))); | ||||||
|             auto smodelgnd = LevelID(scale_(modelgnd)); |         auto smodelgnd = LevelID(scale_(modelgnd)); | ||||||
|             auto slh = LevelID(scale_(lh)); |         auto slh = LevelID(scale_(lh)); | ||||||
| 
 | 
 | ||||||
|             // It is important that the next levels math the levels in
 |         // It is important that the next levels math the levels in
 | ||||||
|             // model_slice method. Only difference is that here it works with
 |         // model_slice method. Only difference is that here it works with
 | ||||||
|             // scaled coordinates
 |         // scaled coordinates
 | ||||||
|             std::vector<LevelID> levelids; |         std::vector<LevelID> levelids; | ||||||
|             if(sminZ >= smodelgnd) levelids.emplace_back(sminZ); |         if(sminZ >= smodelgnd) levelids.emplace_back(sminZ); | ||||||
|             for(LevelID h = sminZ + sih; h < smaxZ; h += slh) |         for(LevelID h = sminZ + sih; h < smaxZ; h += slh) | ||||||
|                 if(h >= smodelgnd) levelids.emplace_back(h); |             if(h >= smodelgnd) levelids.emplace_back(h); | ||||||
| 
 | 
 | ||||||
|             SlicedModel & oslices = o->m_model_slices; |         SlicedModel & oslices = po.m_model_slices; | ||||||
| 
 | 
 | ||||||
|             // If everything went well this code should not run at all, but
 |         // If everything went well this code should not run at all, but
 | ||||||
|             // let's be robust...
 |         // let's be robust...
 | ||||||
|             // assert(levelids.size() == oslices.size());
 |         // assert(levelids.size() == oslices.size());
 | ||||||
|             if(levelids.size() < oslices.size()) { // extend the levels until...
 |         if(levelids.size() < oslices.size()) { // extend the levels until...
 | ||||||
| 
 | 
 | ||||||
|                 BOOST_LOG_TRIVIAL(warning) |             BOOST_LOG_TRIVIAL(warning) | ||||||
|                         << "Height level mismatch at rasterization!\n"; |                     << "Height level mismatch at rasterization!\n"; | ||||||
| 
 | 
 | ||||||
|                 LevelID lastlvl = levelids.back(); |             LevelID lastlvl = levelids.back(); | ||||||
|                 while(levelids.size() < oslices.size()) { |             while(levelids.size() < oslices.size()) { | ||||||
|                     lastlvl += slh; |                 lastlvl += slh; | ||||||
|                     levelids.emplace_back(lastlvl); |                 levelids.emplace_back(lastlvl); | ||||||
|                 } |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             for(int i = 0; i < oslices.size(); ++i) { |  | ||||||
|                 LevelID h = levelids[i]; |  | ||||||
|                 auto& lyrs = levels[h]; // this initializes a new record
 |  | ||||||
|                 lyrs.emplace_back(oslices[i], o->m_instances); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if(o->m_supportdata) { // deal with the support slices if present
 |  | ||||||
|                 auto& sslices = o->m_supportdata->support_slices; |  | ||||||
|                 for(int i = 0; i < sslices.size(); ++i) { |  | ||||||
|                     int a = i == 0 ? 0 : 1; |  | ||||||
|                     int b = i == 0 ? 0 : i - 1; |  | ||||||
|                     LevelID h = sminZ + a * sih + b * slh; |  | ||||||
| 
 |  | ||||||
|                     auto& lyrs = levels[h]; |  | ||||||
|                     lyrs.emplace_back(sslices[i], o->m_instances); |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         for(int i = 0; i < oslices.size(); ++i) { | ||||||
|  |             LevelID h = levelids[i]; | ||||||
|  |             auto& lyrs = levels[h]; // this initializes a new record
 | ||||||
|  |             lyrs.emplace_back(oslices[i], po.m_instances); | ||||||
|  |             SLAPrintObject::SliceRecord& sr = po.m_slice_index[h]; | ||||||
|  |             sr.model_slices_idx = i; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if(po.m_supportdata) { // deal with the support slices if present
 | ||||||
|  |             auto& sslices = po.m_supportdata->support_slices; | ||||||
|  |             for(int i = 0; i < sslices.size(); ++i) { | ||||||
|  |                 int a = i == 0 ? 0 : 1; | ||||||
|  |                 int b = i == 0 ? 0 : i - 1; | ||||||
|  |                 LevelID h = sminZ + a * sih + b * slh; | ||||||
|  | 
 | ||||||
|  |                 auto& lyrs = levels[h]; | ||||||
|  |                 lyrs.emplace_back(sslices[i], po.m_instances); | ||||||
|  | 
 | ||||||
|  |                 SLAPrintObject::SliceRecord& sr = po.m_slice_index[h]; | ||||||
|  |                 sr.support_slices_idx = i; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     // Rasterizing the model objects, and their supports
 | ||||||
|  |     auto rasterize = [this, ilh, ilhd, max_objstatus, &levels]() { | ||||||
|         if(canceled()) return; |         if(canceled()) return; | ||||||
| 
 | 
 | ||||||
|         // collect all the keys
 |         // collect all the keys
 | ||||||
|  | @ -719,7 +725,8 @@ void SLAPrint::process() | ||||||
|         slaposSupportPoints, |         slaposSupportPoints, | ||||||
|         slaposSupportTree, |         slaposSupportTree, | ||||||
|         slaposBasePool, |         slaposBasePool, | ||||||
|         slaposSliceSupports |         slaposSliceSupports, | ||||||
|  |         slaposIndexSlices | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     std::array<slaposFn, slaposCount> pobj_program = |     std::array<slaposFn, slaposCount> pobj_program = | ||||||
|  | @ -729,7 +736,8 @@ void SLAPrint::process() | ||||||
|         support_points, |         support_points, | ||||||
|         support_tree, |         support_tree, | ||||||
|         base_pool, |         base_pool, | ||||||
|         slice_supports |         slice_supports, | ||||||
|  |         index_slices | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     std::array<slapsFn, slapsCount> print_program = |     std::array<slapsFn, slapsCount> print_program = | ||||||
|  | @ -982,13 +990,20 @@ const TriangleMesh EMPTY_MESH; | ||||||
| 
 | 
 | ||||||
| const std::vector<ExPolygons> &SLAPrintObject::get_support_slices() const | const std::vector<ExPolygons> &SLAPrintObject::get_support_slices() const | ||||||
| { | { | ||||||
|     if(!is_step_done(slaposSliceSupports) || !m_supportdata) return EMPTY_SLICES; |     // assert(is_step_done(slaposSliceSupports));
 | ||||||
|  |     if(!!m_supportdata) return EMPTY_SLICES; | ||||||
|     return m_supportdata->support_slices; |     return m_supportdata->support_slices; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const SLAPrintObject::SliceIndex &SLAPrintObject::get_slice_index() const | ||||||
|  | { | ||||||
|  |     // assert(is_step_done(slaposIndexSlices));
 | ||||||
|  |     return m_slice_index; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const std::vector<ExPolygons> &SLAPrintObject::get_model_slices() const | const std::vector<ExPolygons> &SLAPrintObject::get_model_slices() const | ||||||
| { | { | ||||||
|     if(!is_step_done(slaposObjectSlice)) return EMPTY_SLICES; |     // assert(is_step_done(slaposObjectSlice));
 | ||||||
|     return m_model_slices; |     return m_model_slices; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,6 +23,7 @@ enum SLAPrintObjectStep : unsigned int { | ||||||
| 	slaposSupportTree, | 	slaposSupportTree, | ||||||
| 	slaposBasePool, | 	slaposBasePool, | ||||||
| 	slaposSliceSupports, | 	slaposSliceSupports, | ||||||
|  |     slaposIndexSlices, | ||||||
| 	slaposCount | 	slaposCount | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -60,7 +61,7 @@ public: | ||||||
|     // Support mesh is only valid if this->is_step_done(slaposSupportTree) is true.
 |     // Support mesh is only valid if this->is_step_done(slaposSupportTree) is true.
 | ||||||
|     const TriangleMesh&     support_mesh() const; |     const TriangleMesh&     support_mesh() const; | ||||||
|     // Get a pad mesh centered around origin in XY, and with zero rotation around Z applied.
 |     // Get a pad mesh centered around origin in XY, and with zero rotation around Z applied.
 | ||||||
|     // Support mesh is only valid if this->is_step_done(slaposPad) is true.
 |     // Support mesh is only valid if this->is_step_done(slaposBasePool) is true.
 | ||||||
|     const TriangleMesh&     pad_mesh() const; |     const TriangleMesh&     pad_mesh() const; | ||||||
| 
 | 
 | ||||||
|     // This will return the transformed mesh which is cached
 |     // This will return the transformed mesh which is cached
 | ||||||
|  | @ -79,9 +80,29 @@ public: | ||||||
|     // pad is not, then without the pad, otherwise the full value is returned.
 |     // pad is not, then without the pad, otherwise the full value is returned.
 | ||||||
|     double get_current_elevation() const; |     double get_current_elevation() const; | ||||||
| 
 | 
 | ||||||
|     // Should be obvious
 |     // These two methods should be callable on the client side (e.g. UI thread)
 | ||||||
|     const std::vector<ExPolygons>& get_support_slices() const; |     // when the appropriate steps slaposObjectSlice and slaposSliceSupports
 | ||||||
|  |     // are ready. All the print objects are processed before slapsRasterize so
 | ||||||
|  |     // it is safe to call them during and/or after slapsRasterize.
 | ||||||
|     const std::vector<ExPolygons>& get_model_slices() const; |     const std::vector<ExPolygons>& get_model_slices() const; | ||||||
|  |     const std::vector<ExPolygons>& get_support_slices() const; | ||||||
|  | 
 | ||||||
|  |     struct SliceRecord { | ||||||
|  |         using Key = long long; | ||||||
|  |         inline static float scale_back(Key h) { return float(scale_(h)); } | ||||||
|  | 
 | ||||||
|  |         using Idx = size_t; | ||||||
|  |         static const Idx NONE = ULONG_MAX; // std::numeric_limits<Idx>::max() // damn msvc 2013... ;
 | ||||||
|  | 
 | ||||||
|  |         Idx model_slices_idx = NONE; | ||||||
|  |         Idx support_slices_idx = NONE; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     using SliceIndex = std::map<SliceRecord::Key, SliceRecord>; | ||||||
|  | 
 | ||||||
|  |     // Retrieve the slice index which is readable only after slaposIndexSlices
 | ||||||
|  |     // is done.
 | ||||||
|  |     const SliceIndex& get_slice_index() const; | ||||||
| 
 | 
 | ||||||
|     // I refuse to grantee copying (Tamas)
 |     // I refuse to grantee copying (Tamas)
 | ||||||
|     SLAPrintObject(const SLAPrintObject&) = delete; |     SLAPrintObject(const SLAPrintObject&) = delete; | ||||||
|  | @ -119,6 +140,7 @@ private: | ||||||
|     // Which steps have to be performed. Implicitly: all
 |     // Which steps have to be performed. Implicitly: all
 | ||||||
|     std::vector<bool>                       m_stepmask; |     std::vector<bool>                       m_stepmask; | ||||||
|     std::vector<ExPolygons>                 m_model_slices; |     std::vector<ExPolygons>                 m_model_slices; | ||||||
|  |     SliceIndex                              m_slice_index; | ||||||
| 
 | 
 | ||||||
|     // Caching the transformed (m_trafo) raw mesh of the object
 |     // Caching the transformed (m_trafo) raw mesh of the object
 | ||||||
|     mutable CachedObject<TriangleMesh>      m_transformed_rmesh; |     mutable CachedObject<TriangleMesh>      m_transformed_rmesh; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tamasmeszaros
						tamasmeszaros