forked from peterqliu/threebox
-
Notifications
You must be signed in to change notification settings - Fork 150
/
10-stylechange.html
136 lines (118 loc) · 3.8 KB
/
10-stylechange.html
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
132
133
134
135
136
<!doctype html>
<html>
<head>
<title>Threebox change map style for Eiffel Tower</title>
<link href="https://api.mapbox.com/mapbox-gl-js/v2.2.0/mapbox-gl.css" rel="stylesheet">
<script src="https://api.mapbox.com/mapbox-gl-js/v2.2.0/mapbox-gl.js"></script>
<script src="../dist/threebox.js" type="text/javascript"></script>
<link href="../dist/threebox.css" rel="stylesheet" />
<script src="config.js"></script>
<style>
body {
margin: 0;
padding: 0;
}
html, body, #map {
height: 100%;
}
#menu {
position: absolute;
background: #fff;
padding: 10px;
font-family: 'Open Sans', sans-serif;
}
</style>
</head>
<body>
<div id='map' class='map'></div>
<div id="menu" style="margin-left:120px">
<input id="streets-v11" type="radio" name="rtoggle" value="streets" checked="checked" />
<label for="streets-v11">streets</label>
<input id="light-v10" type="radio" name="rtoggle" value="light" />
<label for="light-v10">light</label>
<input id="dark-v10" type="radio" name="rtoggle" value="dark" />
<label for="dark-v10">dark</label>
<input id="outdoors-v11" type="radio" name="rtoggle" value="outdoors" />
<label for="outdoors-v11">outdoors</label>
<input id="satellite-v9" type="radio" name="rtoggle" value="outdoors" />
<label for="satellite-v9">satellite</label>
</div>
<script type="module">
// This example downloads a tower model from an external OBJ/MTL file, adds it to the map, and drives it around via paths fetched from the Mapbox Directions API
if (!config) console.error("Config not set! Make a copy of 'config_template.js', add in your access token, and save the file as 'config.js'.");
mapboxgl.accessToken = config.accessToken;
let mapConfig = {
PAR: { origin: [2.294514, 48.857475, 0], center: [2.294625, 48.861085, 0], zoom: 15.95, pitch: 60, bearing: 0, scale: { x: 5621.06, y: 6480.4, z: 5621.06 }, timezone: 'Europe/Paris' },
names: {
customLayer: "custom-layer"
}
}
let map = window.map = new mapboxgl.Map({
container: 'map',
zoom: mapConfig.PAR.zoom,
pitch: mapConfig.PAR.pitch,
bearing: mapConfig.PAR.bearing,
center: mapConfig.PAR.center,
style: 'mapbox://styles/mapbox/streets-v11',
antialias: true,
hash: true
});
window.tb = new Threebox(
map,
map.getCanvas().getContext('webgl'),
{
defaultLights: true
}
);
let layerId = "streets-v11";
function switchLayer(layer) {
if (layerId != layer.target.id) {
layerId = layer.target.id;
tb.setStyle('mapbox://styles/mapbox/' + layerId);
}
}
let styleList = document.getElementById('menu');
let inputs = styleList.getElementsByTagName('input');
for (let i = 0; i < inputs.length; i++) {
inputs[i].onclick = switchLayer;
}
let stats;
import Stats from 'https://threejs.org/examples/jsm/libs/stats.module.js';
function animate() {
requestAnimationFrame(animate);
stats.update();
}
map.on('style.load', () => {
// stats
stats = new Stats();
map.getContainer().appendChild(stats.dom);
animate();
map.addLayer({
id: mapConfig.names.customLayer,
type: 'custom',
renderingMode: '3d',
onAdd: function (map, mbxContext) {
// Creative Commons License attribution: Eiffel Tower model by https://www.cgtrader.com/lefabshop
// https://www.cgtrader.com/items/108594/download-page
let options = {
obj: './models/landmarks/eiffel.glb',
type: 'gltf',
scale: mapConfig.PAR.scale,
units: 'meters',
rotation: { x: 90, y: 0, z: 0 }, //default rotation
}
tb.loadObj(options, function (model) {
model.setCoords(mapConfig.PAR.origin);
model.setRotation({ x: 0, y: 0, z: 45.7 });
model.addTooltip("Eiffel Tower", true);
tb.add(model);
})
},
render: function (gl, matrix) {
tb.update();
}
});
});
</script>
</body>
</html>