|
77 | 77 | scene = new THREE.Scene(); |
78 | 78 |
|
79 | 79 | // camera |
80 | | - camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 1, 1000 ); |
81 | | - camera.position.set( - 10, 0, 23 ); |
| 80 | + camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 1, 100 ); |
| 81 | + camera.position.set( 0, 0, 12 ); |
82 | 82 |
|
83 | 83 | // controls |
84 | 84 | var controls = new THREE.OrbitControls( camera, renderer.domElement ); |
85 | 85 | controls.addEventListener( 'change', render ); |
86 | | - controls.minDistance = 10; |
87 | | - controls.maxDistance = 50; |
88 | | - controls.enablePan = false; |
| 86 | + controls.enableZoom = false; |
89 | 87 |
|
90 | | - var loader = new THREE.TextureLoader(); |
| 88 | + // manager |
| 89 | + var manager = new THREE.LoadingManager( render ); |
| 90 | + |
| 91 | + // matcap |
| 92 | + var loader = new THREE.TextureLoader( manager ); |
91 | 93 |
|
92 | 94 | var matcap = loader.load( 'textures/matcaps/matcap-porcelain-white.jpg', function( texture ) { |
93 | 95 |
|
|
98 | 100 | } ); |
99 | 101 |
|
100 | 102 | // model |
101 | | - new THREE.GLTFLoader().load( 'models/gltf/Nefertiti/Nefertiti.glb', function ( gltf ) { |
102 | | - |
103 | | - gltf.scene.traverse( function ( child ) { |
104 | | - |
105 | | - if ( child.isMesh ) { |
106 | | - |
107 | | - child.material = new THREE.MeshMatcapMaterial( { |
108 | | - |
109 | | - matcap: matcap |
110 | | - |
111 | | - } ); |
112 | | - |
113 | | - // |
114 | | - |
115 | | - child.material.side = THREE.DoubleSide; |
116 | | - |
117 | | - child.scale.multiplyScalar( 0.5 ); |
118 | | - |
119 | | - // recenter |
120 | | - |
121 | | - new THREE.Box3().setFromObject( child ).getCenter( child.position ).multiplyScalar( - 1 ); |
| 103 | + new THREE.GLTFLoader( manager ).load( 'models/gltf/LeePerrySmith/LeePerrySmith.glb', function ( gltf ) { |
122 | 104 |
|
123 | | - mesh = child; |
| 105 | + mesh = gltf.scene.children[ 0 ]; |
124 | 106 |
|
125 | | - scene.add( mesh ); |
| 107 | + mesh.material = new THREE.MeshMatcapMaterial( { |
126 | 108 |
|
127 | | - } |
| 109 | + matcap: matcap |
128 | 110 |
|
129 | 111 | } ); |
130 | 112 |
|
131 | | - render(); |
| 113 | + scene.add( mesh ); |
132 | 114 |
|
133 | 115 | } ); |
134 | 116 |
|
|
0 commit comments