2017-12-06 11:54:09 +01:00
|
|
|
import { VertexColors } from 'three/src/constants.js';
|
|
|
|
import { BufferAttribute } from 'three/src/core/BufferAttribute.js';
|
|
|
|
import { LineBasicMaterial } from 'three/src/materials/LineBasicMaterial.js';
|
|
|
|
import { LineSegments } from 'three/src/objects/LineSegments.js';
|
2017-12-18 16:37:03 +01:00
|
|
|
import _slice from './sliceActions/slice.js';
|
2017-07-20 11:54:49 +02:00
|
|
|
import SlicerWorker from './slicer.worker.js';
|
2017-12-18 16:37:03 +01:00
|
|
|
import sketchDataToJSON from 'doodle3d-core/shape/sketchDataToJSON';
|
2015-07-26 15:32:10 +02:00
|
|
|
|
2017-12-18 16:37:03 +01:00
|
|
|
export function slice(settings, sketch, matrix, sync = false, constructLinePreview = false, onProgress) {
|
2017-07-20 10:29:33 +02:00
|
|
|
if (sync) {
|
2017-12-18 16:37:03 +01:00
|
|
|
return sliceSync(settings, sketch, matrix, constructLinePreview, onProgress);
|
2017-07-20 10:29:33 +02:00
|
|
|
} else {
|
2017-12-18 16:37:03 +01:00
|
|
|
return sliceAsync(settings, sketch, matrix, constructLinePreview, onProgress);
|
2017-05-13 14:48:48 +02:00
|
|
|
}
|
2017-07-20 10:29:33 +02:00
|
|
|
}
|
|
|
|
|
2017-12-18 16:37:03 +01:00
|
|
|
export function sliceSync(settings, sketch, matrix, constructLinePreview, onProgress) {
|
|
|
|
return _slice(settings, sketch, matrix, constructLinePreview, onProgress);
|
2017-07-20 10:29:33 +02:00
|
|
|
}
|
2017-05-13 14:48:48 +02:00
|
|
|
|
2017-12-18 16:37:03 +01:00
|
|
|
export function sliceAsync(settings, sketch, matrix, constructLinePreview, onProgress) {
|
2017-07-20 10:29:33 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
// create the slicer worker
|
|
|
|
const slicerWorker = new SlicerWorker();
|
2017-07-24 15:40:54 +02:00
|
|
|
|
|
|
|
slicerWorker.onerror = error => {
|
|
|
|
slicerWorker.terminate();
|
|
|
|
reject(error);
|
|
|
|
};
|
2017-05-13 14:48:48 +02:00
|
|
|
|
2017-07-20 10:29:33 +02:00
|
|
|
// listen to messages send from worker
|
|
|
|
slicerWorker.addEventListener('message', (event) => {
|
|
|
|
const { message, data } = event.data;
|
|
|
|
switch (message) {
|
|
|
|
case 'SLICE': {
|
|
|
|
slicerWorker.terminate();
|
2017-11-12 11:53:45 +01:00
|
|
|
|
|
|
|
if (data.gcode.linePreview) {
|
2017-12-06 11:54:09 +01:00
|
|
|
const geometry = new BufferGeometry();
|
2017-11-12 11:53:45 +01:00
|
|
|
|
|
|
|
const { position, color } = data.gcode.linePreview;
|
2017-12-06 11:54:09 +01:00
|
|
|
geometry.addAttribute('position', new BufferAttribute(new Float32Array(position), 3));
|
|
|
|
geometry.addAttribute('color', new BufferAttribute(new Float32Array(color), 3));
|
2017-11-12 11:53:45 +01:00
|
|
|
|
2017-12-06 11:54:09 +01:00
|
|
|
const material = new LineBasicMaterial({ vertexColors: VertexColors });
|
|
|
|
const linePreview = new LineSegments(geometry, material);
|
2017-11-12 11:53:45 +01:00
|
|
|
|
|
|
|
data.gcode.linePreview = linePreview;
|
|
|
|
}
|
|
|
|
|
2017-07-20 10:29:33 +02:00
|
|
|
resolve(data.gcode);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case 'PROGRESS': {
|
|
|
|
if (typeof onProgress !== 'undefined') {
|
|
|
|
onProgress(data);
|
2017-07-04 14:19:07 +02:00
|
|
|
}
|
2017-07-20 10:29:33 +02:00
|
|
|
break;
|
2017-05-13 14:48:48 +02:00
|
|
|
}
|
2017-07-20 10:29:33 +02:00
|
|
|
}
|
|
|
|
});
|
2017-05-13 14:48:48 +02:00
|
|
|
|
2017-07-20 10:29:33 +02:00
|
|
|
// send geometry and settings to worker to start the slicing progress
|
2017-12-18 16:37:03 +01:00
|
|
|
matrix = matrix.toArray();
|
|
|
|
sketch = sketchDataToJSON(sketch);
|
2017-07-20 10:29:33 +02:00
|
|
|
slicerWorker.postMessage({
|
|
|
|
message: 'SLICE',
|
2017-12-18 16:37:03 +01:00
|
|
|
data: { settings, sketch, matrix, constructLinePreview }
|
2017-05-13 14:48:48 +02:00
|
|
|
});
|
2017-07-20 10:29:33 +02:00
|
|
|
});
|
2015-07-26 15:32:10 +02:00
|
|
|
}
|