2017-12-19 12:38:58 +01:00
|
|
|
import 'core-js'; // polyfills
|
2016-10-13 14:22:04 +02:00
|
|
|
import slice from './sliceActions/slice.js';
|
2018-02-12 10:28:42 +01:00
|
|
|
import { stringToTypedArray } from './sliceActions/helpers/binary.js';
|
2016-08-19 14:46:02 +02:00
|
|
|
|
2017-07-18 12:26:30 +02:00
|
|
|
const onProgress = progress => {
|
|
|
|
self.postMessage({
|
|
|
|
message: 'PROGRESS',
|
2017-07-20 10:29:33 +02:00
|
|
|
data: progress
|
2017-07-18 12:26:30 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-01-17 15:27:42 +01:00
|
|
|
self.addEventListener('message', (event) => {
|
2016-08-19 14:46:02 +02:00
|
|
|
const { message, data } = event.data;
|
|
|
|
switch (message) {
|
|
|
|
case 'SLICE': {
|
2018-02-12 00:10:44 +01:00
|
|
|
const { settings, geometry, constructLinePreview, openObjectIndexes } = data;
|
2016-08-19 14:46:02 +02:00
|
|
|
|
2017-12-19 12:38:58 +01:00
|
|
|
const gcode = slice(settings, geometry, openObjectIndexes, constructLinePreview, onProgress);
|
2018-02-12 10:28:42 +01:00
|
|
|
gcode.gcode = stringToTypedArray(gcode.gcode);
|
|
|
|
|
|
|
|
const buffers = [gcode.gcode.buffer];
|
2017-11-12 11:53:45 +01:00
|
|
|
|
2018-02-11 23:28:25 +01:00
|
|
|
// if (gcode.linePreview) {
|
|
|
|
// const position = gcode.linePreview.geometry.getAttribute('position').array;
|
|
|
|
// const color = gcode.linePreview.geometry.getAttribute('color').array;
|
|
|
|
// buffers.push(position.buffer, color.buffer);
|
|
|
|
// gcode.linePreview = { position, color };
|
|
|
|
// }
|
2016-08-19 14:46:02 +02:00
|
|
|
|
|
|
|
self.postMessage({
|
|
|
|
message: 'SLICE',
|
|
|
|
data: { gcode }
|
2017-11-12 11:53:45 +01:00
|
|
|
}, buffers);
|
2016-08-19 14:46:02 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}, false);
|