mirror of
https://github.com/Doodle3D/Doodle3D-Slicer.git
synced 2025-01-10 19:35:09 +01:00
Add dimensions details to 3d panel
This commit is contained in:
parent
e1d833d4f3
commit
9764e0a374
@ -3,6 +3,7 @@ import React from 'react';
|
|||||||
import { Quaternion } from 'three/src/math/Quaternion.js';
|
import { Quaternion } from 'three/src/math/Quaternion.js';
|
||||||
import { Vector3 } from 'three/src/math/Vector3.js';
|
import { Vector3 } from 'three/src/math/Vector3.js';
|
||||||
import { Mesh } from 'three/src/objects/Mesh.js';
|
import { Mesh } from 'three/src/objects/Mesh.js';
|
||||||
|
import { Box3 } from 'three/src/math/Box3.js';
|
||||||
import PropTypes from 'proptypes';
|
import PropTypes from 'proptypes';
|
||||||
import { centerGeometry, placeOnGround, createScene, fetchProgress, slice, TabTemplate } from './utils.js';
|
import { centerGeometry, placeOnGround, createScene, fetchProgress, slice, TabTemplate } from './utils.js';
|
||||||
import injectSheet from 'react-jss';
|
import injectSheet from 'react-jss';
|
||||||
@ -77,6 +78,9 @@ const styles = {
|
|||||||
},
|
},
|
||||||
title: {
|
title: {
|
||||||
position: 'absolute'
|
position: 'absolute'
|
||||||
|
},
|
||||||
|
detail: {
|
||||||
|
marginBottom: '10px'
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -108,6 +112,7 @@ class Interface extends React.Component {
|
|||||||
isSlicing: false,
|
isSlicing: false,
|
||||||
isLoading: true,
|
isLoading: true,
|
||||||
error: null,
|
error: null,
|
||||||
|
objectDimensions: '0x0x0mm',
|
||||||
popover: {
|
popover: {
|
||||||
element: null,
|
element: null,
|
||||||
open: false
|
open: false
|
||||||
@ -141,6 +146,7 @@ class Interface extends React.Component {
|
|||||||
scene.mesh.geometry = mesh.geometry;
|
scene.mesh.geometry = mesh.geometry;
|
||||||
centerGeometry(scene.mesh);
|
centerGeometry(scene.mesh);
|
||||||
placeOnGround(scene.mesh);
|
placeOnGround(scene.mesh);
|
||||||
|
this.calculateDimensions();
|
||||||
scene.render();
|
scene.render();
|
||||||
|
|
||||||
this.setState({ mesh, isLoading: false });
|
this.setState({ mesh, isLoading: false });
|
||||||
@ -162,6 +168,7 @@ class Interface extends React.Component {
|
|||||||
mesh.rotation.set(0, 0, 0);
|
mesh.rotation.set(0, 0, 0);
|
||||||
mesh.updateMatrix();
|
mesh.updateMatrix();
|
||||||
placeOnGround(mesh);
|
placeOnGround(mesh);
|
||||||
|
this.calculateDimensions();
|
||||||
render();
|
render();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -175,6 +182,7 @@ class Interface extends React.Component {
|
|||||||
mesh.scale.multiplyScalar(factor);
|
mesh.scale.multiplyScalar(factor);
|
||||||
mesh.updateMatrix();
|
mesh.updateMatrix();
|
||||||
placeOnGround(mesh);
|
placeOnGround(mesh);
|
||||||
|
this.calculateDimensions();
|
||||||
render();
|
render();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -188,6 +196,7 @@ class Interface extends React.Component {
|
|||||||
if (mesh) {
|
if (mesh) {
|
||||||
mesh.rotateOnWorldAxis(axis, angle);
|
mesh.rotateOnWorldAxis(axis, angle);
|
||||||
placeOnGround(mesh);
|
placeOnGround(mesh);
|
||||||
|
this.calculateDimensions();
|
||||||
render();
|
render();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -266,9 +275,15 @@ class Interface extends React.Component {
|
|||||||
this.setState({ settings, error: null });
|
this.setState({ settings, error: null });
|
||||||
};
|
};
|
||||||
|
|
||||||
|
calculateDimensions = () => {
|
||||||
|
const { scene: { mesh } } = this.state;
|
||||||
|
const { x, y, z } = new Box3().setFromObject(mesh).getSize();
|
||||||
|
this.setState({ objectDimensions: `${Math.round(x)}x${Math.round(y)}x${Math.round(z)}mm` });
|
||||||
|
};
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { classes, onCancel } = this.props;
|
const { classes, onCancel } = this.props;
|
||||||
const { isSlicing, isLoading, progress, showFullScreen, error } = this.state;
|
const { isSlicing, isLoading, progress, showFullScreen, error, objectDimensions } = this.state;
|
||||||
|
|
||||||
const disableUI = isSlicing || isLoading;
|
const disableUI = isSlicing || isLoading;
|
||||||
const style = { ...(showFullScreen ? {} : { maxWidth: 'inherit', width: '100%', height: '100%' }) };
|
const style = { ...(showFullScreen ? {} : { maxWidth: 'inherit', width: '100%', height: '100%' }) };
|
||||||
@ -319,6 +334,9 @@ class Interface extends React.Component {
|
|||||||
<ReactResizeDetector handleWidth handleHeight onResize={this.onResize3dView} />
|
<ReactResizeDetector handleWidth handleHeight onResize={this.onResize3dView} />
|
||||||
<canvas className={classes.canvas} ref="canvas" />
|
<canvas className={classes.canvas} ref="canvas" />
|
||||||
<div className={classes.controlBar}>
|
<div className={classes.controlBar}>
|
||||||
|
<div className={classes.detail}>
|
||||||
|
<p>Dimensions: {objectDimensions}</p>
|
||||||
|
</div>
|
||||||
<RaisedButton disabled={disableUI} className={classes.controlButton} onTouchTap={this.resetMesh} label="reset" />
|
<RaisedButton disabled={disableUI} className={classes.controlButton} onTouchTap={this.resetMesh} label="reset" />
|
||||||
<RaisedButton disabled={disableUI} className={classes.controlButton} onTouchTap={this.scaleUp} label="scale down" />
|
<RaisedButton disabled={disableUI} className={classes.controlButton} onTouchTap={this.scaleUp} label="scale down" />
|
||||||
<RaisedButton disabled={disableUI} className={classes.controlButton} onTouchTap={this.scaleDown} label="scale up" />
|
<RaisedButton disabled={disableUI} className={classes.controlButton} onTouchTap={this.scaleDown} label="scale up" />
|
||||||
|
Loading…
x
Reference in New Issue
Block a user