Solving issue with first empty layer.

This commit is contained in:
tamasmeszaros 2019-01-15 14:25:28 +01:00
parent 519f5e5ea7
commit 831de96a81
3 changed files with 10 additions and 4 deletions

View file

@ -1746,7 +1746,7 @@ SlicedSupports SLASupportTree::slice(float layerh, float init_layerh) const
const Pad& pad = m_impl->pad(); const Pad& pad = m_impl->pad();
if(!pad.empty()) gndlvl -= float(get_pad_elevation(pad.cfg)); if(!pad.empty()) gndlvl -= float(get_pad_elevation(pad.cfg));
std::vector<float> heights = {gndlvl}; std::vector<float> heights;
heights.reserve(size_t(modelh/layerh) + 1); heights.reserve(size_t(modelh/layerh) + 1);
for(float h = gndlvl + init_layerh; h < gndlvl + modelh; h += layerh) { for(float h = gndlvl + init_layerh; h < gndlvl + modelh; h += layerh) {

View file

@ -732,9 +732,7 @@ void SLAPrint::process()
po.m_supportdata->level_ids.reserve(sslices.size()); po.m_supportdata->level_ids.reserve(sslices.size());
for(int i = 0; i < int(sslices.size()); ++i) { for(int i = 0; i < int(sslices.size()); ++i) {
int a = i == 0 ? 0 : 1; LevelID h = sminZ + sih + i * slh;
int b = i == 0 ? 0 : i - 1;
LevelID h = sminZ + a * sih + b * slh;
po.m_supportdata->level_ids.emplace_back(h); po.m_supportdata->level_ids.emplace_back(h);
float fh = float(double(h) * SCALING_FACTOR); float fh = float(double(h) * SCALING_FACTOR);

View file

@ -148,8 +148,16 @@ 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;
// Individual 2d slice polygons from lower z to higher z levels
std::vector<ExPolygons> m_model_slices; std::vector<ExPolygons> m_model_slices;
// Exact (float) height levels mapped to the slices. Each record contains
// the index to the model and the support slice vectors.
SliceIndex m_slice_index; SliceIndex m_slice_index;
// The height levels corrected and scaled up in integer values. This will
// be used at rasterization.
std::vector<LevelID> m_level_ids; std::vector<LevelID> m_level_ids;
// Caching the transformed (m_trafo) raw mesh of the object // Caching the transformed (m_trafo) raw mesh of the object