-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcar.js
83 lines (62 loc) · 2.19 KB
/
car.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import * as THREE from '/build/three.module.js';
import {OrbitControls} from '/build/OrbitControls.js';
import {OBJLoader} from '/build/OBJLoader.js';
var renderer4, scene4, camera4, car;
var ww = 500,
wh = 500;
function init(){
renderer4 = new THREE.WebGLRenderer({canvas : document.getElementById('car'),
alpha: true});
renderer4.setSize(ww,wh);
scene4 = new THREE.Scene();
camera4 = new THREE.PerspectiveCamera(80,ww/wh, 0.01, 100000 );
//camera4.position.set(175,175,175); good distance for car
camera4.position.set(120,120,120);
camera4.lookAt(new THREE.Vector3(0,0,0));
scene4.add(camera4);
//Add a light in the scene
let directionalLight = new THREE.DirectionalLight( 0xffffff, 0.8 );
directionalLight.position.set( 0, 350, 350 );
directionalLight.lookAt(new THREE.Vector3(0,0,0));
scene4.add( directionalLight );
//Load the obj file
loadOBJ();
}
var loadOBJ = function(){
//Manager from ThreeJs to track a loader and its status
var manager = new THREE.LoadingManager();
//Loader for Obj from Three.js
const loader = new OBJLoader(manager);
//Launch loading of the obj file, addcarInScene is the callback when it's ready
//loader.load( '/animations/vmu/vmu.obj', addCarInScene);
//loader.load( '/animations/shoe/grind_Car.obj', addCarInScene);
loader.load( '/animations/shoe/car-scaled.obj', addCarInScene);
};
var addCarInScene = function(object){
car = object;
//Move the plant in the scene
//Go through all children of the loaded object and search for a Mesh
object.traverse( function ( child ) {
//This allow us to check if the children is an instance of the Mesh constructor
if(child instanceof THREE.Mesh){
child.material.color = new THREE.Color(0X00FF00);
//child.material.map = texture;
//Sometimes there are some vertex normals missing in the .obj files, ThreeJs will compute them
child.geometry.computeVertexNormals();
}
});
//car.scale(new THREE.vector3(2,2,2));
//Add the 3D object in the scene
scene4.add(car);
car.position.set(0, 0, 0);
render();
};
var render = function () {
requestAnimationFrame(render);
//Turn the plant
car.rotation.z += .01;
car.rotation.y += .01;
car.rotation.x += .01;
renderer4.render(scene4, camera4);
};
init();