-
Notifications
You must be signed in to change notification settings - Fork 57
/
Copy pathpolly.html
80 lines (75 loc) · 2.64 KB
/
polly.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
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<title>Hilo3d Polly Demo</title>
<link rel="stylesheet" type="text/css" href="./example.css">
</head>
<body>
<div id="container"></div>
<script src="../build/Hilo3d.js"></script>
<script src="./js/stats.js"></script>
<script src="./js/OrbitControls.js"></script>
<script src="./js/init.js"></script>
<script src="./js/postProcess.js"></script>
<script>
initModel();
function initModel(){
var gltfURL = './models/polly/project_polly.glb';
var loadQueue = new Hilo3d.LoadQueue([{
type: 'CubeTexture',
images: [
'./image/bakedDiffuse_01.jpg',
'./image/bakedDiffuse_02.jpg',
'./image/bakedDiffuse_03.jpg',
'./image/bakedDiffuse_04.jpg',
'./image/bakedDiffuse_05.jpg',
'./image/bakedDiffuse_06.jpg'
]
}, {
type: 'CubeTexture',
right: './image/px.jpg',
left: './image/nx.jpg',
top: './image/py.jpg',
bottom: './image/ny.jpg',
front: './image/pz.jpg',
back: './image/nz.jpg',
magFilter: Hilo3d.constants.LINEAR,
minFilter: Hilo3d.constants.LINEAR_MIPMAP_LINEAR
},{
src: './image/brdfLUT.png',
type:'Texture',
wrapS: Hilo3d.constants.CLAMP_TO_EDGE,
wrapT: Hilo3d.constants.CLAMP_TO_EDGE
},{
src:gltfURL
}]).start().on('complete', function(){
var result = loadQueue.getAllContent();
var diffuseEnvMap = result[0];
var specularEnvMap = result[1];
var brdfTexture = result[2];
var model = window.model = result[3];
model.materials.forEach(function (material) {
material.brdfLUT = brdfTexture;
material.diffuseEnvMap = diffuseEnvMap;
material.specularEnvMap = specularEnvMap;
});
model.node.rotationY = 160;
stage.addChild(model.node);
stage.camera = model.cameras[1];
var skyBox = new Hilo3d.Mesh({
geometry: new Hilo3d.BoxGeometry(),
material: new Hilo3d.BasicMaterial({
lightType: 'NONE',
side: Hilo3d.constants.BACK,
diffuse: specularEnvMap
})
}).addTo(stage);
skyBox.setScale(20);
});
}
</script>
</body>
</html>