Doodle3D-Slicer/src/sliceActions/generateInfills.js

87 lines
2.5 KiB
JavaScript
Raw Normal View History

import getFillTemplate from './getFillTemplate.js';
2016-04-21 22:22:59 +02:00
import Shape from 'Doodle3D/clipper-js';
2016-03-29 08:49:35 +02:00
const scale = 100;
export default function generateInfills(slices, settings) {
console.log("generating infills");
2016-03-29 08:49:35 +02:00
let {
layerHeight,
fillGridSize,
bottomThickness,
topThickness,
nozzleDiameter,
infillOverlap
} = settings.config;
fillGridSize *= scale;
nozzleDiameter *= scale;
infillOverlap *= scale;
var bottomSkinCount = Math.ceil(bottomThickness/layerHeight);
var topSkinCount = Math.ceil(topThickness/layerHeight);
var nozzleRadius = nozzleDiameter / 2;
var hightemplateSize = Math.sqrt(2 * Math.pow(nozzleDiameter, 2));
for (var layer = 0; layer < slices.length; layer ++) {
var slice = slices[layer];
if (layer - bottomSkinCount >= 0 && layer + topSkinCount < slices.length) {
var downSkin = slices[layer - bottomSkinCount].getOutline();
var upSkin = slices[layer + topSkinCount].getOutline();
var surroundingLayer = upSkin.intersect(downSkin);
}
else {
var surroundingLayer = false;
}
for (var i = 0; i < slice.parts.length; i ++) {
var part = slice.parts[i];
2016-04-21 22:14:22 +02:00
if (!part.shape.closed) {
continue;
}
var outerLine = part.outerLine;
2016-04-22 19:38:06 +02:00
if (outerLine.paths.length > 0) {
var inset = (part.innerLines.length > 0) ? part.innerLines[part.innerLines.length - 1] : outerLine;
2016-04-22 19:38:06 +02:00
const fillArea = inset.offset(-nozzleRadius);
let lowFillArea;
let highFillArea;
if (surroundingLayer) {
2016-04-22 19:38:06 +02:00
highFillArea = fillArea.difference(surroundingLayer);
if (infillOverlap > 0) {
highFillArea = highFillArea.offset(infillOverlap);
}
highFillArea = highFillArea.intersect(fillArea);
2016-04-22 19:38:06 +02:00
lowFillArea = fillArea.difference(highFillArea);
}
else {
2016-04-22 19:38:06 +02:00
highFillArea = fillArea;
}
2016-04-22 19:38:06 +02:00
if (lowFillArea && lowFillArea.paths.length > 0) {
var bounds = lowFillArea.shapeBounds();
var lowFillTemplate = getFillTemplate(bounds, fillGridSize, true, true);
part.fill.join(lowFillTemplate.intersect(lowFillArea));
}
2016-04-22 19:38:06 +02:00
if (highFillArea.paths.length > 0) {
var bounds = highFillArea.shapeBounds();
var even = (layer % 2 === 0);
var highFillTemplate = getFillTemplate(bounds, hightemplateSize, even, !even);
part.fill.join(highFillTemplate.intersect(highFillArea));
}
}
}
}
}