-
Notifications
You must be signed in to change notification settings - Fork 5
/
app.js
executable file
·108 lines (83 loc) · 2.22 KB
/
app.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
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
//@ts-check
// Detect SSR (server side rendering)
var canUseDOM = !!(
(typeof window !== 'undefined' &&
window.document && window.document.createElement)
);
var Lore = require('./src/Lore');
// By Shmiddty from stackoverflow
function Enum(a) {
let i = Object
.keys(a)
.reduce((o, k) => (o[a[k]] = k, o), {});
return Object.freeze(
Object.keys(a).reduce((o, k) => (o[k] = a[k], o), v => i[v])
);
}
Lore.Mouse = Enum({
Left: 0,
Middle: 1,
Right: 2
});
Lore.Keyboard = Enum({
Backspace: 8,
Tab: 9,
Enter: 13,
Shift: 16,
Ctrl: 17,
Alt: 18,
Esc: 27
});
Lore.init = function (canvas, options) {
this.opts = Lore.Utils.extend(true, Lore.defaults, options);
// Lore.getGrakaInfo(canvas);
var cc = Lore.Core.Color.fromHex(this.opts.clearColor);
if (!(canvas instanceof Element)) {
canvas = document.getElementById(canvas);
}
var renderer = new Lore.Core.Renderer(canvas, {
clearColor: cc,
verbose: true,
fps: document.getElementById('fps'),
center: new Lore.Math.Vector3f(125, 125, 125),
antialiasing: this.opts.antialiasing,
alphaBlending: this.opts.alphaBlending,
preserveDrawingBuffer: this.opts.preserveDrawingBuffer
});
renderer.controls.limitRotationToHorizon(this.opts.limitRotationToHorizon);
renderer.render = function (camera, geometries) {
for (var key in geometries) {
geometries[key].draw(renderer);
}
}
return renderer;
}
Lore.getGrakaInfo = function (targetId) {
let canvas = document.getElementById(targetId);
let gl = canvas.getContext('webgl') ||
canvas.getContext('experimental-webgl');
let info = {
renderer: '',
vendor: ''
};
let dbgRenderInfo = gl.getExtension('WEBGL_debug_renderer_info');
if (dbgRenderInfo != null) {
info.renderer = gl.getParameter(dbgRenderInfo.UNMASKED_RENDERER_WEBGL);
info.vendor = gl.getParameter(dbgRenderInfo.UNMASKED_VENDOR_WEBGL);
}
return info;
}
Lore.supportsHighQuality = function (targetId) {
let info = Lore.getGrakaInfo(targetId);
return false;
}
Lore.defaults = {
clearColor: '#121212',
limitRotationToHorizon: false,
antialiasing: false,
preserveDrawingBuffer: false
};
if (canUseDOM) {
window['Lore'] = Lore
}
module.exports = Lore