mirror of
https://github.com/Doodle3D/Doodle3D-Slicer.git
synced 2025-06-07 16:19:52 +02:00
39 lines
1.1 KiB
JavaScript
39 lines
1.1 KiB
JavaScript
import 'core-js'; // polyfills
|
|
import slice from './sliceActions/slice.js';
|
|
import * as THREE from 'three';
|
|
|
|
const onProgress = progress => {
|
|
self.postMessage({
|
|
message: 'PROGRESS',
|
|
data: progress
|
|
});
|
|
}
|
|
|
|
const loader = new THREE.JSONLoader();
|
|
|
|
self.addEventListener('message', (event) => {
|
|
const { message, data } = event.data;
|
|
switch (message) {
|
|
case 'SLICE': {
|
|
const { settings, geometry: JSONGeometry, constructLinePreview, openObjectIndexes } = data;
|
|
const { geometry } = loader.parse(JSONGeometry.data);
|
|
|
|
const gcode = slice(settings, geometry, openObjectIndexes, constructLinePreview, onProgress);
|
|
|
|
const buffers = [];
|
|
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 };
|
|
}
|
|
|
|
self.postMessage({
|
|
message: 'SLICE',
|
|
data: { gcode }
|
|
}, buffers);
|
|
break;
|
|
}
|
|
}
|
|
}, false);
|