This repository is an update of 3DView.Measurements with the last threejs library (release 143)
conversion process :
* convert class to es6
* change deprecated method
Advanced JavaScript 3D models viewing control with interactive measurements
3D viewing control with interactive measurements based on Three.js.
Supports:
- All modern browsers (including mobile)
- WebGL or Canvas rendering
- all type of loader (ply and stl tested, show example html file)
- Point info and distance measurements (feel free to develop thickness, angle and radius measurements πͺ π π π₯)
- Getting information about selected point on a 3D model (coordinates, face, normal)
Author: ismail azdad / :mailbox_with_no_mail: [email protected]
Link all necessary JS files from Three.js r143 (included)
<script async src="https://unpkg.com/[email protected]/dist/es-module-shims.js"></script>
<script type="importmap">
{
"imports": {
"three": "./js/dependencies/three.module.js"
}
}
</script>
<script src="js/dependencies/ui.js"></script>
Link all necessary JS files in module :
<script type="module">
import * as THREE from 'three';
import {
PerspectiveCamera,
WebGLRenderer,
sRGBEncoding,
HemisphereLight
} from 'three';
import {OrbitControls} from './js/dependencies/OrbitControls.js';
import {TrackballControls} from './js/dependencies/TrackballControls.js';
import {STLLoader} from './js/dependencies/STLLoader.js';
import {PLYLoader} from './js/dependencies/PLYLoader.js';
import {View3D} from './js/3DView/3DView.Measurements.js';
import {MeasurementInfo} from './js/3DView/measurements/Measurement.Info.js';
import {MeasurementDistance} from './js/3DView/measurements/Measurement.Distance.js';
</script>
This code creates a renderer; loads the STL file; request the user to add a measurement and listens to measurement events.
<script>
let container, stats, camera, scene, renderer, controls;
container = document.createElement('div');
document.body.appendChild(container);
camera = new PerspectiveCamera(35, window.innerWidth / window.innerHeight, 1, 15);
camera.position.set(3, 0.15, 3);
// renderer
renderer = new WebGLRenderer({antialias: true});
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight);
renderer.outputEncoding = sRGBEncoding;
renderer.shadowMap.enabled = true;
container.appendChild(renderer.domElement);
//set controls
//you can use the type of controls you want TrackballControls,OrbitControls...
const control = new OrbitControls(camera, renderer.domElement);
control.enableDamping = true;
control.dampingFactor = 0.25;
control.enableZoom = true;
//set view
var view = new View3D(
document.getElementById( 'container' ),
renderer,
control,
camera);
//load STL file from URL
const loader = new STLLoader();
// //load STL file
// for STL object you can use addGeometry method or adding object directly
loader.load('./models/Box.stl', function (geometry) {
view.addGeometry( geometry );
});
//other method load STL file from URL
loader.load('./models/Box.stl', function (geometry) {
const material = new THREE.MeshPhongMaterial({color: 0xff5533, specular: 0x111111, shininess: 200});
const mesh = new THREE.Mesh(geometry, material);
mesh.position.set(-0.7, -0.7, -0.7);
mesh.scale.set(0.15, 0.15, 0.15);
mesh.castShadow = true;
mesh.receiveShadow = true;
view.scene.add(mesh)
});
//PLY file
var loader = new PLYLoader();
loader.load(
"./models/dolphins.ply",
function(geometry) {
geometry.computeVertexNormals();
var material = new THREE.MeshStandardMaterial({
color: 0x0055ff,
flatShading: true
});
var mesh = new THREE.Mesh(geometry, material);
mesh.position.y = -0.7;
mesh.position.z = 0.3;
mesh.rotation.x = -Math.PI / 2;
mesh.scale.multiplyScalar(0.01);
view.scene.add( mesh );
}
);
//request user to make new measurement
var element=document.getElementById("infobutton");
var listener=element.addEventListener('click',function(event){
view.addMeasurement(new MeasurementInfo());
});
var element=document.getElementById("clearbutton");
var listener=element.addEventListener('click',function(event){
view.clearMeasurements();
});
var element=document.getElementById("distancebutton");
var listener=element.addEventListener('click',function(event){
view.addMeasurement(new MeasurementDistance());
});
//.....
//events
//on measurement added
view.addEventListener( 'measurementAdded', function (event) {
//measurement is added after user picks 1st point on the 3D model
var measurement = event.object;
//....
} );
//on measurement changed
view.addEventListener( 'measurementChanged', function (event) {
//measurement has changed
var measurement = event.object;
if (measurement) {
// measurement.getType();
// measurement.getValue();
// measurement.getInfo();
}
//....
} );
//on measurement removed
view.addEventListener( 'measurementRemoved', function (event) {
//measurement is removed
var measurement = event.object;
//....
} );
</script>