-
-
Notifications
You must be signed in to change notification settings - Fork 36k
Collapse file tree
Files
Search this repository
/
Copy pathwebgl_lod.html
More file actions
More file actions
Latest commit
131 lines (88 loc) · 3.2 KB
/
webgl_lod.html
File metadata and controls
131 lines (88 loc) · 3.2 KB
You must be signed in to make or propose changes
More edit options
Edit and raw actions
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
<!DOCTYPE html>
<html lang="en">
<head>
<title>three.js webgl - level of detail</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<link type="text/css" rel="stylesheet" href="main.css">
</head>
<body>
<div id="info">
<a href="https://threejs.org" target="_blank" rel="noopener">three.js</a> - level of detail
</div>
<script type="importmap">
{
"imports": {
"three": "../build/three.module.js",
"three/addons/": "./jsm/"
}
}
</script>
<script type="module">
import * as THREE from 'three';
import { FlyControls } from 'three/addons/controls/FlyControls.js';
let container;
let camera, scene, renderer, controls;
const clock = new THREE.Clock();
init();
function init() {
container = document.createElement( 'div' );
document.body.appendChild( container );
camera = new THREE.PerspectiveCamera( 45, window.innerWidth / window.innerHeight, 1, 15000 );
camera.position.z = 1000;
scene = new THREE.Scene();
scene.fog = new THREE.Fog( 0x000000, 1, 15000 );
const pointLight = new THREE.PointLight( 0xff2200, 3, 0, 0 );
pointLight.position.set( 0, 0, 0 );
scene.add( pointLight );
const dirLight = new THREE.DirectionalLight( 0xffffff, 3 );
dirLight.position.set( 0, 0, 1 ).normalize();
scene.add( dirLight );
const geometry = [
[ new THREE.IcosahedronGeometry( 100, 16 ), 50 ],
[ new THREE.IcosahedronGeometry( 100, 8 ), 300 ],
[ new THREE.IcosahedronGeometry( 100, 4 ), 1000 ],
[ new THREE.IcosahedronGeometry( 100, 2 ), 2000 ],
[ new THREE.IcosahedronGeometry( 100, 1 ), 8000 ]
];
const material = new THREE.MeshLambertMaterial( { color: 0xffffff, wireframe: true } );
for ( let j = 0; j < 1000; j ++ ) {
const lod = new THREE.LOD();
for ( let i = 0; i < geometry.length; i ++ ) {
const mesh = new THREE.Mesh( geometry[ i ][ 0 ], material );
mesh.scale.set( 1.5, 1.5, 1.5 );
mesh.updateMatrix();
mesh.matrixAutoUpdate = false;
lod.addLevel( mesh, geometry[ i ][ 1 ] );
}
lod.position.x = 10000 * ( 0.5 - Math.random() );
lod.position.y = 7500 * ( 0.5 - Math.random() );
lod.position.z = 10000 * ( 0.5 - Math.random() );
lod.updateMatrix();
lod.matrixAutoUpdate = false;
scene.add( lod );
}
renderer = new THREE.WebGLRenderer( { antialias: true } );
renderer.setPixelRatio( window.devicePixelRatio );
renderer.setSize( window.innerWidth, window.innerHeight );
renderer.setAnimationLoop( animate );
container.appendChild( renderer.domElement );
//
controls = new FlyControls( camera, renderer.domElement );
controls.movementSpeed = 1000;
controls.rollSpeed = Math.PI / 10;
//
window.addEventListener( 'resize', onWindowResize );
}
function onWindowResize() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize( window.innerWidth, window.innerHeight );
}
function animate() {
controls.update( clock.getDelta() );
renderer.render( scene, camera );
}
</script>
</body>
</html>