I have a simple (empty) scene that I want to use for displaying GLTF 3D assets.
After I’m using GLTF loader I want to position the camera so it would point to the model on my gltf.scene.
Also, I would like to limit the OrbitControls (or the PerspectiveCamera) so it wont allow the user to collapse with the asset from the gltf.scene and wont be able to move to far away from the asset.
How can I calculate the fov,near and far according to the mesh / objects on the gltf.scene?
Once you’ve loaded the glTF file and added it to the scene, it no longer matters what type of file it was — it’s just an instance of THREE.Scene, containing THREE.Object3D and THREE.Mesh instances. See docs on THREE.Object3D for the API available. You may want .lookAt() in particular.
The code works but not exactly like I’ve copied it to my project.
instead of this code:
const box = new THREE.Box3().setFromObject(object);
const size = box.getSize().length();
I’ve used this one:
var maxSize = 0;
for (var i = 0; i < scene.children.length; i++) {
var box = new THREE.Box3().setFromObject(scene.children[i]);
var size = box.getSize().length();
if (size > maxSize)
maxSize = size;
}
if (!maxSize)
maxSize = 1;