mirror of
https://github.com/Doodle3D/Doodle3D-Slicer.git
synced 2024-11-22 13:37:58 +01:00
move line preview to slice
This commit is contained in:
parent
4654858c3e
commit
849f3f893a
@ -84,19 +84,19 @@ class Interface extends React.Component {
|
|||||||
|
|
||||||
const geometry = mesh.geometry.clone();
|
const geometry = mesh.geometry.clone();
|
||||||
mesh.updateMatrix();
|
mesh.updateMatrix();
|
||||||
geometry.applyMatrix(new THREE.Matrix4().makeTranslation(centerY, 0, centerX).multiply(mesh.matrix));
|
|
||||||
|
|
||||||
const { gcode } = await sliceGeometry(settings, geometry, null, true, (process) => {
|
const matrix = new THREE.Matrix4().makeTranslation(centerY, 0, centerX).multiply(mesh.matrix);
|
||||||
|
const { gcode, linePreview } = await sliceGeometry(settings, geometry, matrix, true, true, (process) => {
|
||||||
console.log('process: ', process);
|
console.log('process: ', process);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// can't disable control so remove it
|
||||||
control.dispose();
|
control.dispose();
|
||||||
scene.remove(control, mesh);
|
scene.remove(control, mesh);
|
||||||
|
|
||||||
const line = createGcodeGeometry(gcode);
|
linePreview.position.x = -centerY;
|
||||||
line.position.x = -centerY;
|
linePreview.position.z = -centerX;
|
||||||
line.position.z = -centerX;
|
scene.add(linePreview);
|
||||||
scene.add(line);
|
|
||||||
|
|
||||||
render();
|
render();
|
||||||
this.setState({ sliced: true });
|
this.setState({ sliced: true });
|
||||||
|
@ -2,8 +2,6 @@ import * as THREE from 'three';
|
|||||||
import 'three/examples/js/controls/EditorControls';
|
import 'three/examples/js/controls/EditorControls';
|
||||||
import 'three/examples/js/controls/TransformControls';
|
import 'three/examples/js/controls/TransformControls';
|
||||||
|
|
||||||
const MAX_SPEED = 100 * 60;
|
|
||||||
|
|
||||||
export function placeOnGround(mesh) {
|
export function placeOnGround(mesh) {
|
||||||
const boundingBox = new THREE.Box3();
|
const boundingBox = new THREE.Box3();
|
||||||
const vertices = mesh.geometry.vertices.map(vertex => vertex.clone().applyMatrix4(mesh.matrix));
|
const vertices = mesh.geometry.vertices.map(vertex => vertex.clone().applyMatrix4(mesh.matrix));
|
||||||
@ -85,37 +83,3 @@ export function createScene(canvas, props, state) {
|
|||||||
|
|
||||||
return { control, editorControls, scene, mesh, camera, renderer, render };
|
return { control, editorControls, scene, mesh, camera, renderer, render };
|
||||||
}
|
}
|
||||||
|
|
||||||
export function createGcodeGeometry(gcode) {
|
|
||||||
const geometry = new THREE.Geometry();
|
|
||||||
|
|
||||||
let lastPoint
|
|
||||||
for (let i = 0; i < gcode.length; i ++) {
|
|
||||||
const { G, F, X, Y, Z } = gcode[i];
|
|
||||||
|
|
||||||
if (X || Y || Z) {
|
|
||||||
const point = new THREE.Vector3(Y, Z, X);
|
|
||||||
|
|
||||||
let color;
|
|
||||||
if (G === 0) {
|
|
||||||
color = new THREE.Color(0x00ff00);
|
|
||||||
} else if (G === 1) {
|
|
||||||
color = new THREE.Color().setHSL(F / MAX_SPEED, 0.5, 0.5);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (G === 1) {
|
|
||||||
if (lastPoint) geometry.vertices.push(lastPoint);
|
|
||||||
geometry.vertices.push(new THREE.Vector3(Y, Z, X));
|
|
||||||
geometry.colors.push(color);
|
|
||||||
geometry.colors.push(color);
|
|
||||||
}
|
|
||||||
|
|
||||||
lastPoint = point;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const material = new THREE.LineBasicMaterial({ vertexColors: THREE.VertexColors });
|
|
||||||
const line = new THREE.LineSegments(geometry, material);
|
|
||||||
|
|
||||||
return line;
|
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import * as THREE from 'three';
|
|||||||
import slice from './sliceActions/slice.js';
|
import slice from './sliceActions/slice.js';
|
||||||
import SlicerWorker from './slicer.worker.js';
|
import SlicerWorker from './slicer.worker.js';
|
||||||
|
|
||||||
export function sliceMesh(settings, mesh, sync = false, onProgress) {
|
export function sliceMesh(settings, mesh, sync = false, constructLinePreview = false, onProgress) {
|
||||||
if (!mesh || !mesh.isMesh) {
|
if (!mesh || !mesh.isMesh) {
|
||||||
throw new Error('Provided mesh is not intance of THREE.Mesh');
|
throw new Error('Provided mesh is not intance of THREE.Mesh');
|
||||||
}
|
}
|
||||||
@ -12,7 +12,7 @@ export function sliceMesh(settings, mesh, sync = false, onProgress) {
|
|||||||
return sliceGeometry(settings, geometry, matrix, sync, onProgress);
|
return sliceGeometry(settings, geometry, matrix, sync, onProgress);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function sliceGeometry(settings, geometry, matrix, sync = false, onProgress) {
|
export async function sliceGeometry(settings, geometry, matrix, sync = false, constructLinePreview = false, onProgress) {
|
||||||
if (!geometry) {
|
if (!geometry) {
|
||||||
throw new Error('Missing required geometry argument');
|
throw new Error('Missing required geometry argument');
|
||||||
} else if (geometry.isBufferGeometry) {
|
} else if (geometry.isBufferGeometry) {
|
||||||
@ -31,11 +31,17 @@ export function sliceGeometry(settings, geometry, matrix, sync = false, onProgre
|
|||||||
geometry.applyMatrix(matrix);
|
geometry.applyMatrix(matrix);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let gcode;
|
||||||
if (sync) {
|
if (sync) {
|
||||||
return sliceSync(settings, geometry, onProgress);
|
gcode = sliceSync(settings, geometry, onProgress);
|
||||||
} else {
|
} else {
|
||||||
return sliceAsync(settings, geometry, onProgress);
|
gcode = await sliceAsync(settings, geometry, onProgress);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (constructLinePreview) gcode.linePreview = createGcodeGeometry(gcode.gcode);
|
||||||
|
|
||||||
|
gcode.gcode = gcodeToString(gcode.gcode);
|
||||||
|
return gcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
function sliceSync(settings, geometry, onProgress) {
|
function sliceSync(settings, geometry, onProgress) {
|
||||||
@ -81,3 +87,57 @@ function sliceAsync(settings, geometry, onProgress) {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function gcodeToString(gcode) {
|
||||||
|
const currentValues = {};
|
||||||
|
return gcode.reduce((string, command) => {
|
||||||
|
let first = true;
|
||||||
|
for (const action in command) {
|
||||||
|
const value = command[action];
|
||||||
|
const currentValue = currentValues[action];
|
||||||
|
if (first) {
|
||||||
|
string = action + value;
|
||||||
|
first = false;
|
||||||
|
} else if (currentValue !== value) {
|
||||||
|
string += ` ${action}${value}`;
|
||||||
|
currentValues[action] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
string += '\n';
|
||||||
|
}, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
const MAX_SPEED = 100 * 60;
|
||||||
|
function createGcodeGeometry(gcode) {
|
||||||
|
const geometry = new THREE.Geometry();
|
||||||
|
|
||||||
|
let lastPoint
|
||||||
|
for (let i = 0; i < gcode.length; i ++) {
|
||||||
|
const { G, F, X, Y, Z } = gcode[i];
|
||||||
|
|
||||||
|
if (X || Y || Z) {
|
||||||
|
const point = new THREE.Vector3(Y, Z, X);
|
||||||
|
|
||||||
|
let color;
|
||||||
|
if (G === 0) {
|
||||||
|
color = new THREE.Color(0x00ff00);
|
||||||
|
} else if (G === 1) {
|
||||||
|
color = new THREE.Color().setHSL(F / MAX_SPEED, 0.5, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (G === 1) {
|
||||||
|
if (lastPoint) geometry.vertices.push(lastPoint);
|
||||||
|
geometry.vertices.push(new THREE.Vector3(Y, Z, X));
|
||||||
|
geometry.colors.push(color);
|
||||||
|
geometry.colors.push(color);
|
||||||
|
}
|
||||||
|
|
||||||
|
lastPoint = point;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const material = new THREE.LineBasicMaterial({ vertexColors: THREE.VertexColors });
|
||||||
|
const line = new THREE.LineSegments(geometry, material);
|
||||||
|
|
||||||
|
return line;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user