Improved Support

While testing with printer improved the support
This commit is contained in:
casperlamboo 2015-06-10 18:25:49 +02:00
parent 57179fbe20
commit a216addc3b
8 changed files with 108 additions and 90 deletions

Binary file not shown.

View File

@ -15,10 +15,10 @@
"printer.temperature": 210.0, "printer.temperature": 210.0,
"printer.topThickness": 0.8, "printer.topThickness": 0.8,
"printer.travelSpeed": 200.0, "printer.travelSpeed": 200.0,
"printer.support.minArea": 2.0, "printer.support.accaptanceSize": 1.5,
"printer.support.distanceY": 0.15, "printer.support.distanceY": 0.4,
"printer.support.use": true, "printer.support.use": true,
"printer.support.size": 3, "printer.support.gritSize": 6.0,
"printer.support.margin": 1.0, "printer.support.margin": 2.0,
"printer.support.offset": 1.0 "printer.support.plateSize": 4.0
} }

View File

@ -36,7 +36,7 @@ function init () {
var printer = new D3D.Printer().updateConfig(USER_SETTINGS).updateConfig(PRINTER_SETTINGS["ultimaker"]); var printer = new D3D.Printer().updateConfig(USER_SETTINGS).updateConfig(PRINTER_SETTINGS["ultimaker"]);
var loader = new THREE.STLLoader(); var loader = new THREE.STLLoader();
loader.load('models/robot.stl', function (geometry) { loader.load('models/support_test.stl', function (geometry) {
//var geometry = new THREE.BoxGeometry(10, 10, 10, 1, 1, 1); //var geometry = new THREE.BoxGeometry(10, 10, 10, 1, 1, 1);
//var geometry = new THREE.SphereGeometry(10, 20, 10); //var geometry = new THREE.SphereGeometry(10, 20, 10);
//var geometry = new THREE.TorusGeometry(20, 10, 30, 30); //var geometry = new THREE.TorusGeometry(20, 10, 30, 30);
@ -71,8 +71,10 @@ function init () {
mesh.rotation.x = -Math.PI/2; mesh.rotation.x = -Math.PI/2;
mesh.scale.x = mesh.scale.y = mesh.scale.z = 1; mesh.scale.x = mesh.scale.y = mesh.scale.z = 1;
mesh.position.y = -0.1; mesh.position.y = -0.1;
mesh.position.x = 100; mesh.position.x = 60;
mesh.position.z = 100; mesh.position.z = 60;
mesh.updateMatrix();
scene.add(mesh); scene.add(mesh);

View File

@ -14,7 +14,7 @@
D3D.Box = function (localIp) { D3D.Box = function (localIp) {
"use strict"; "use strict";
var self = this; var scope = this;
this.batchSize = 512; this.batchSize = 512;
this.maxBufferedLines = 4096; this.maxBufferedLines = 4096;
@ -31,13 +31,13 @@ D3D.Box = function (localIp) {
this.loaded = false; this.loaded = false;
this.getConfigAll(function (data) { this.getConfigAll(function (data) {
self.updateConfig(data); scope.updateConfig(data);
self.update(); scope.update();
self.loaded = true; scope.loaded = true;
if (self.onload !== undefined) { if (scope.onload !== undefined) {
self.onload(); scope.onload();
} }
}); });
}; };
@ -52,6 +52,7 @@ D3D.Box.prototype.updateConfig = function (config) {
}; };
D3D.Box.prototype.update = function () { D3D.Box.prototype.update = function () {
"use strict"; "use strict";
var scope = this;
//TODO //TODO
//Code is zo op gezet dat maar api call te gelijk is //Code is zo op gezet dat maar api call te gelijk is
//Bij error wordt gelijk zelfde data opnieuw gestuurd //Bij error wordt gelijk zelfde data opnieuw gestuurd
@ -62,22 +63,24 @@ D3D.Box.prototype.update = function () {
this.printBatch(); this.printBatch();
} }
else { else {
this.updateState(); setTimeout(function () {
scope.updateState();
}, 1000);
} }
}; };
D3D.Box.prototype.updateState = function () { D3D.Box.prototype.updateState = function () {
//que api calls so they don't overload the d3d box //que api calls so they don't overload the d3d box
"use strict"; "use strict";
var self = this; var scope = this;
this.getInfoStatus(function (data) { this.getInfoStatus(function (data) {
self.status = data; scope.status = data;
if (self.onupdate !== undefined) { if (scope.onupdate !== undefined) {
self.onupdate(data); scope.onupdate(data);
} }
self.update(); scope.update();
}); });
}; };
D3D.Box.prototype.print = function (gcode) { D3D.Box.prototype.print = function (gcode) {
@ -98,7 +101,7 @@ D3D.Box.prototype.print = function (gcode) {
}; };
D3D.Box.prototype.printBatch = function () { D3D.Box.prototype.printBatch = function () {
"use strict"; "use strict";
var self = this; var scope = this;
var gcode = this.printBatches.shift(); var gcode = this.printBatches.shift();
@ -108,17 +111,17 @@ D3D.Box.prototype.printBatch = function () {
"gcode": gcode.join("\n"), "gcode": gcode.join("\n"),
"last": ((this.printBatches.length === 0) ? true : false) //only for debug purposes "last": ((this.printBatches.length === 0) ? true : false) //only for debug purposes
}, function (data) { }, function (data) {
console.log("batch sent: " + self.currentBatch, data); console.log("batch sent: " + scope.currentBatch, data);
if (self.printBatches.length > 0) { if (scope.printBatches.length > 0) {
//sent new batch //sent new batch
self.currentBatch ++; scope.currentBatch ++;
} }
else { else {
//finish sending //finish sending
} }
self.updateState(); scope.updateState();
}); });
}; };
D3D.Box.prototype.stopPrint = function (printer) { D3D.Box.prototype.stopPrint = function (printer) {
@ -154,12 +157,12 @@ D3D.Box.prototype.getConfigAll = function (callback) {
}; };
D3D.Box.prototype.setConfig = function (data, callback) { D3D.Box.prototype.setConfig = function (data, callback) {
"use strict"; "use strict";
var self = this; var scope = this;
sendAPI(this.api + "config", data, function (response) { sendAPI(this.api + "config", data, function (response) {
for (var i in response.validation) { for (var i in response.validation) {
if (response.validation[i] === "ok") { if (response.validation[i] === "ok") {
self[i] = data[i]; scope[i] = data[i];
} }
} }

View File

@ -4,6 +4,8 @@
* *
* Manages the gcode * Manages the gcode
* Also handles different flavours of gcode * Also handles different flavours of gcode
* TODO
* calculate extrusion length and total time
* *
******************************************************/ ******************************************************/

View File

@ -168,7 +168,8 @@ D3D.Paths.prototype.areas = function () {
for (var i = 0; i < this.length; i ++) { for (var i = 0; i < this.length; i ++) {
var shape = this[i]; var shape = this[i];
areas.push(ClipperLib.Clipper.Area(shape)); var area = Math.abs(ClipperLib.Clipper.Area(shape));
areas.push(area);
} }
return areas; return areas;
@ -209,6 +210,16 @@ D3D.Paths.prototype.bounds = function () {
return ClipperLib.Clipper.GetBounds(this); return ClipperLib.Clipper.GetBounds(this);
}; };
D3D.Paths.prototype.boundSize = function () {
"use strict";
var bounds = this.bounds();
var width = bounds.right - bounds.left;
var height = bounds.top - bounds.bottom;
return width * height;
};
D3D.Paths.prototype.draw = function (context, color) { D3D.Paths.prototype.draw = function (context, color) {
"use strict"; "use strict";

View File

@ -237,7 +237,7 @@ D3D.Slicer.prototype.slice = function (layerHeight, height) {
//think this check is not nescesary, always higher as 0 //think this check is not nescesary, always higher as 0
if (shape.length > 0) { if (shape.length > 0) {
slice.push(new D3D.Paths([shape])); slice.push(new D3D.Paths([shape], true));
} }
} }
} }
@ -281,20 +281,21 @@ D3D.Slicer.prototype.slicesToData = function (slices, printer) {
var scale = 100; var scale = 100;
var layerHeight = printer.config["printer.layerHeight"] * scale; var layerHeight = printer.config["printer.layerHeight"];
var dimensionsZ = printer.config["printer.dimensions.z"] * scale;
var nozzleDiameter = printer.config["printer.nozzleDiameter"] * scale; var nozzleDiameter = printer.config["printer.nozzleDiameter"] * scale;
var shellThickness = printer.config["printer.shellThickness"] * scale; var shellThickness = printer.config["printer.shellThickness"] * scale;
var fillSize = printer.config["printer.fillSize"] * scale; var fillSize = printer.config["printer.fillSize"] * scale;
var brimOffset = printer.config["printer.brimOffset"] * scale; var brimOffset = printer.config["printer.brimOffset"] * scale;
var bottomThickness = printer.config["printer.bottomThickness"] * scale; var bottomThickness = printer.config["printer.bottomThickness"];
var topThickness = printer.config["printer.topThickness"] * scale; var topThickness = printer.config["printer.topThickness"];
var useSupport = printer.config["printer.support.use"]; var useSupport = printer.config["printer.support.use"];
var supportSize = printer.config["printer.support.size"] * scale; var supportGritSize = printer.config["printer.support.gritSize"] * scale;
var supportMinArea = printer.config["printer.support.minArea"] * Math.pow(scale, 2); var supportAccaptanceSize = printer.config["printer.support.accaptanceSize"] * scale;
var supportMargin = printer.config["printer.support.margin"] * scale; var supportMargin = printer.config["printer.support.margin"] * scale;
var supportOffset = printer.config["printer.support.offset"] * scale; var plateSize = printer.config["printer.support.plateSize"] * scale;
var supportDistanceY = printer.config["printer.support.distanceY"];
var supportDistanceLayers = Math.ceil(supportDistanceY / layerHeight);
var bottomSkinCount = Math.ceil(bottomThickness/layerHeight); var bottomSkinCount = Math.ceil(bottomThickness/layerHeight);
var topSkinCount = Math.ceil(topThickness/layerHeight); var topSkinCount = Math.ceil(topThickness/layerHeight);
var nozzleRadius = nozzleDiameter / 2; var nozzleRadius = nozzleDiameter / 2;
@ -395,59 +396,58 @@ D3D.Slicer.prototype.slicesToData = function (slices, printer) {
top: this.geometry.boundingBox.min.x * scale, top: this.geometry.boundingBox.min.x * scale,
right: this.geometry.boundingBox.max.z * scale, right: this.geometry.boundingBox.max.z * scale,
bottom: this.geometry.boundingBox.max.x * scale bottom: this.geometry.boundingBox.max.x * scale
}, supportSize, true, true); }, supportGritSize, true, true);
var supportAreas = new D3D.Paths([], true); var supportAreas = new D3D.Paths([], true);
for (var layer = data.length - 1; layer >= 0; layer --) { for (var layer = data.length - 1 - supportDistanceLayers; layer >= 0; layer --) {
var slice = data[layer];
if (supportAreas.length > 0) { if (supportAreas.length > 0) {
var currentSkin = new D3D.Paths([], true);
if (layer >= supportDistanceLayers) {
var sliceSkin = new D3D.Paths([], true);
var slice = data[layer - supportDistanceLayers];
for (var i = 0; i < slice.length; i ++) { for (var i = 0; i < slice.length; i ++) {
currentSkin.join(slice[i].outerLayer); sliceSkin.join(slice[i].outerLayer);
} }
currentSkin = currentSkin.offset(supportMargin); sliceSkin = sliceSkin.offset(supportMargin);
supportAreas = supportAreas.difference(currentSkin); supportAreas = supportAreas.difference(sliceSkin);
slice[0].support = supportTemplate.intersect(supportAreas);
} }
if (layer !== 0) { var currentSlice = data[layer];
if (layer === 0) {
supportAreas = supportAreas.offset(plateSize).difference(sliceSkin);
var template = this.getFillTemplate(supportAreas.bounds(), nozzleDiameter, true, false);
currentSlice[0].support = template.intersect(supportAreas);
}
else {
currentSlice[0].support = supportTemplate.intersect(supportAreas).join(supportAreas.clone());
}
}
var supportSlice = data[layer + supportDistanceLayers - 1];
var supportSkin = new D3D.Paths([], true); var supportSkin = new D3D.Paths([], true);
if (layer - 1 >= 0) { for (var i = 0; i < supportSlice.length; i ++) {
var supportLayer = data[layer - 1]; //supportSkin = supportSkin.union(supportSlice[i].outerLayer);
for (var i = 0; i < supportLayer.length; i ++) { supportSkin.join(supportSlice[i].outerLayer);
supportSkin.join(supportLayer[i].outerLayer);
}
} }
var slice = data[layer + supportDistanceLayers];
for (var i = 0; i < slice.length; i ++) { for (var i = 0; i < slice.length; i ++) {
var slicePart = slice[i]; var slicePart = slice[i];
var outerLayer = slicePart.outerLayer; var outerLayer = slicePart.outerLayer;
var overlap = supportSkin.intersect(outerLayer); var overlap = supportSkin.offset(supportAccaptanceSize).intersect(outerLayer);
var overhang = outerLayer.difference(overlap); var overhang = outerLayer.difference(overlap);
if (overlap.length === 0) { if (overlap.length === 0 || overhang.length > 0) {
var supportArea = overhang.offset(supportOffset); var supportArea = outerLayer.difference(supportSkin.intersect(outerLayer));
supportAreas = supportAreas.union(supportArea); supportAreas = supportAreas.union(supportArea);
} }
else if (overhang.length > 0) {
var areas = overhang.areas();
for (var j = 0; j < areas.length; j ++) {
var area = areas[i];
if (area > supportMinArea) {
var supportArea = new D3D.Paths([overhang[i]], false).offset(supportOffset);
supportAreas = supportAreas.union(supportArea);
}
}
}
}
} }
} }
} }
@ -546,10 +546,10 @@ D3D.Slicer.prototype.dataToGCode = function (data, printer) {
sliceToGCode(layerPart.outerLayer, false, true); sliceToGCode(layerPart.outerLayer, false, true);
sliceToGCode(layerPart.insets, false, false); sliceToGCode(layerPart.insets, false, false);
sliceToGCode(layerPart.fill, (layerPart.support === undefined), false); sliceToGCode(layerPart.fill, true, false);
if (layerPart.support !== undefined) { if (layerPart.support !== undefined) {
sliceToGCode(layerPart.support, true, false); sliceToGCode(layerPart.support, true, true);
} }
} }

View File

@ -47,19 +47,19 @@ function init () {
var scene = createScene(); var scene = createScene();
var localIp = location.hash.substring(1); var localIp = location.hash.substring(1);
//doodleBox = new D3D.Box(localIp); doodleBox = new D3D.Box(localIp);
//doodleBox.onupdate = function (data) { doodleBox.onupdate = function (data) {
// document.getElementById('state').innerHTML = data.state; document.getElementById('state').innerHTML = data.state;
// document.getElementById('bed_temp').innerHTML = data.bed; document.getElementById('bed_temp').innerHTML = data.bed;
// document.getElementById('bed_target_temp').innerHTML = data.bed_target; document.getElementById('bed_target_temp').innerHTML = data.bed_target;
// document.getElementById('nozzle_temp').innerHTML = data.hotend; document.getElementById('nozzle_temp').innerHTML = data.hotend;
// document.getElementById('nozzle_target_temp').innerHTML = data.hotend_target; document.getElementById('nozzle_target_temp').innerHTML = data.hotend_target;
// document.getElementById('current_line').innerHTML = data.current_line; document.getElementById('current_line').innerHTML = data.current_line;
// document.getElementById('buffered_lines').innerHTML = data.buffered_lines; document.getElementById('buffered_lines').innerHTML = data.buffered_lines;
// document.getElementById('total_lines').innerHTML = data.total_lines; document.getElementById('total_lines').innerHTML = data.total_lines;
// document.getElementById('print_batches').innerHTML = doodleBox.printBatches.length; document.getElementById('print_batches').innerHTML = doodleBox.printBatches.length;
//}; };
printer = new D3D.Printer().updateConfig(USER_SETTINGS).updateConfig(PRINTER_SETTINGS['ultimaker2go']); printer = new D3D.Printer().updateConfig(USER_SETTINGS).updateConfig(PRINTER_SETTINGS['ultimaker2go']);