@macrostrat/cesium-martini 1.2.3 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +1 -6
- package/.env.example +1 -0
- package/.npmrc +1 -0
- package/README.md +60 -12
- package/dist/index.cjs +1099 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.js +787 -2149
- package/dist/index.js.map +1 -1
- package/package.json +26 -31
- package/rollup.config.js +13 -6
- package/tsconfig.json +3 -3
- package/typings/worker-loader.d.ts +10 -0
- package/webpack.config.js +7 -1
- package/.gitmodules +0 -3
package/dist/index.cjs
ADDED
|
@@ -0,0 +1,1099 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var cesium = require('cesium');
|
|
6
|
+
|
|
7
|
+
function _assertThisInitialized(e) {
|
|
8
|
+
if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
|
|
9
|
+
return e;
|
|
10
|
+
}
|
|
11
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) {
|
|
12
|
+
try {
|
|
13
|
+
var i = n[a](c),
|
|
14
|
+
u = i.value;
|
|
15
|
+
} catch (n) {
|
|
16
|
+
return void e(n);
|
|
17
|
+
}
|
|
18
|
+
i.done ? t(u) : Promise.resolve(u).then(r, o);
|
|
19
|
+
}
|
|
20
|
+
function _asyncToGenerator(n) {
|
|
21
|
+
return function () {
|
|
22
|
+
var t = this,
|
|
23
|
+
e = arguments;
|
|
24
|
+
return new Promise(function (r, o) {
|
|
25
|
+
var a = n.apply(t, e);
|
|
26
|
+
function _next(n) {
|
|
27
|
+
asyncGeneratorStep(a, r, o, _next, _throw, "next", n);
|
|
28
|
+
}
|
|
29
|
+
function _throw(n) {
|
|
30
|
+
asyncGeneratorStep(a, r, o, _next, _throw, "throw", n);
|
|
31
|
+
}
|
|
32
|
+
_next(void 0);
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function _callSuper(t, o, e) {
|
|
37
|
+
return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e));
|
|
38
|
+
}
|
|
39
|
+
function _classCallCheck(a, n) {
|
|
40
|
+
if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function");
|
|
41
|
+
}
|
|
42
|
+
function _defineProperties(e, r) {
|
|
43
|
+
for (var t = 0; t < r.length; t++) {
|
|
44
|
+
var o = r[t];
|
|
45
|
+
o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
function _createClass(e, r, t) {
|
|
49
|
+
return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", {
|
|
50
|
+
writable: !1
|
|
51
|
+
}), e;
|
|
52
|
+
}
|
|
53
|
+
function _defineProperty(e, r, t) {
|
|
54
|
+
return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, {
|
|
55
|
+
value: t,
|
|
56
|
+
enumerable: !0,
|
|
57
|
+
configurable: !0,
|
|
58
|
+
writable: !0
|
|
59
|
+
}) : e[r] = t, e;
|
|
60
|
+
}
|
|
61
|
+
function _get() {
|
|
62
|
+
return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) {
|
|
63
|
+
var p = _superPropBase(e, t);
|
|
64
|
+
if (p) {
|
|
65
|
+
var n = Object.getOwnPropertyDescriptor(p, t);
|
|
66
|
+
return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value;
|
|
67
|
+
}
|
|
68
|
+
}, _get.apply(null, arguments);
|
|
69
|
+
}
|
|
70
|
+
function _getPrototypeOf(t) {
|
|
71
|
+
return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) {
|
|
72
|
+
return t.__proto__ || Object.getPrototypeOf(t);
|
|
73
|
+
}, _getPrototypeOf(t);
|
|
74
|
+
}
|
|
75
|
+
function _inherits(t, e) {
|
|
76
|
+
if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function");
|
|
77
|
+
t.prototype = Object.create(e && e.prototype, {
|
|
78
|
+
constructor: {
|
|
79
|
+
value: t,
|
|
80
|
+
writable: !0,
|
|
81
|
+
configurable: !0
|
|
82
|
+
}
|
|
83
|
+
}), Object.defineProperty(t, "prototype", {
|
|
84
|
+
writable: !1
|
|
85
|
+
}), e && _setPrototypeOf(t, e);
|
|
86
|
+
}
|
|
87
|
+
function _isNativeReflectConstruct() {
|
|
88
|
+
try {
|
|
89
|
+
var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));
|
|
90
|
+
} catch (t) {}
|
|
91
|
+
return (_isNativeReflectConstruct = function () {
|
|
92
|
+
return !!t;
|
|
93
|
+
})();
|
|
94
|
+
}
|
|
95
|
+
function ownKeys(e, r) {
|
|
96
|
+
var t = Object.keys(e);
|
|
97
|
+
if (Object.getOwnPropertySymbols) {
|
|
98
|
+
var o = Object.getOwnPropertySymbols(e);
|
|
99
|
+
r && (o = o.filter(function (r) {
|
|
100
|
+
return Object.getOwnPropertyDescriptor(e, r).enumerable;
|
|
101
|
+
})), t.push.apply(t, o);
|
|
102
|
+
}
|
|
103
|
+
return t;
|
|
104
|
+
}
|
|
105
|
+
function _objectSpread2(e) {
|
|
106
|
+
for (var r = 1; r < arguments.length; r++) {
|
|
107
|
+
var t = null != arguments[r] ? arguments[r] : {};
|
|
108
|
+
r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {
|
|
109
|
+
_defineProperty(e, r, t[r]);
|
|
110
|
+
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {
|
|
111
|
+
Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
return e;
|
|
115
|
+
}
|
|
116
|
+
function _possibleConstructorReturn(t, e) {
|
|
117
|
+
if (e && ("object" == typeof e || "function" == typeof e)) return e;
|
|
118
|
+
if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined");
|
|
119
|
+
return _assertThisInitialized(t);
|
|
120
|
+
}
|
|
121
|
+
function _regeneratorRuntime() {
|
|
122
|
+
_regeneratorRuntime = function () {
|
|
123
|
+
return e;
|
|
124
|
+
};
|
|
125
|
+
var t,
|
|
126
|
+
e = {},
|
|
127
|
+
r = Object.prototype,
|
|
128
|
+
n = r.hasOwnProperty,
|
|
129
|
+
o = Object.defineProperty || function (t, e, r) {
|
|
130
|
+
t[e] = r.value;
|
|
131
|
+
},
|
|
132
|
+
i = "function" == typeof Symbol ? Symbol : {},
|
|
133
|
+
a = i.iterator || "@@iterator",
|
|
134
|
+
c = i.asyncIterator || "@@asyncIterator",
|
|
135
|
+
u = i.toStringTag || "@@toStringTag";
|
|
136
|
+
function define(t, e, r) {
|
|
137
|
+
return Object.defineProperty(t, e, {
|
|
138
|
+
value: r,
|
|
139
|
+
enumerable: !0,
|
|
140
|
+
configurable: !0,
|
|
141
|
+
writable: !0
|
|
142
|
+
}), t[e];
|
|
143
|
+
}
|
|
144
|
+
try {
|
|
145
|
+
define({}, "");
|
|
146
|
+
} catch (t) {
|
|
147
|
+
define = function (t, e, r) {
|
|
148
|
+
return t[e] = r;
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
function wrap(t, e, r, n) {
|
|
152
|
+
var i = e && e.prototype instanceof Generator ? e : Generator,
|
|
153
|
+
a = Object.create(i.prototype),
|
|
154
|
+
c = new Context(n || []);
|
|
155
|
+
return o(a, "_invoke", {
|
|
156
|
+
value: makeInvokeMethod(t, r, c)
|
|
157
|
+
}), a;
|
|
158
|
+
}
|
|
159
|
+
function tryCatch(t, e, r) {
|
|
160
|
+
try {
|
|
161
|
+
return {
|
|
162
|
+
type: "normal",
|
|
163
|
+
arg: t.call(e, r)
|
|
164
|
+
};
|
|
165
|
+
} catch (t) {
|
|
166
|
+
return {
|
|
167
|
+
type: "throw",
|
|
168
|
+
arg: t
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
e.wrap = wrap;
|
|
173
|
+
var h = "suspendedStart",
|
|
174
|
+
l = "suspendedYield",
|
|
175
|
+
f = "executing",
|
|
176
|
+
s = "completed",
|
|
177
|
+
y = {};
|
|
178
|
+
function Generator() {}
|
|
179
|
+
function GeneratorFunction() {}
|
|
180
|
+
function GeneratorFunctionPrototype() {}
|
|
181
|
+
var p = {};
|
|
182
|
+
define(p, a, function () {
|
|
183
|
+
return this;
|
|
184
|
+
});
|
|
185
|
+
var d = Object.getPrototypeOf,
|
|
186
|
+
v = d && d(d(values([])));
|
|
187
|
+
v && v !== r && n.call(v, a) && (p = v);
|
|
188
|
+
var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
|
|
189
|
+
function defineIteratorMethods(t) {
|
|
190
|
+
["next", "throw", "return"].forEach(function (e) {
|
|
191
|
+
define(t, e, function (t) {
|
|
192
|
+
return this._invoke(e, t);
|
|
193
|
+
});
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
function AsyncIterator(t, e) {
|
|
197
|
+
function invoke(r, o, i, a) {
|
|
198
|
+
var c = tryCatch(t[r], t, o);
|
|
199
|
+
if ("throw" !== c.type) {
|
|
200
|
+
var u = c.arg,
|
|
201
|
+
h = u.value;
|
|
202
|
+
return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
|
|
203
|
+
invoke("next", t, i, a);
|
|
204
|
+
}, function (t) {
|
|
205
|
+
invoke("throw", t, i, a);
|
|
206
|
+
}) : e.resolve(h).then(function (t) {
|
|
207
|
+
u.value = t, i(u);
|
|
208
|
+
}, function (t) {
|
|
209
|
+
return invoke("throw", t, i, a);
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
a(c.arg);
|
|
213
|
+
}
|
|
214
|
+
var r;
|
|
215
|
+
o(this, "_invoke", {
|
|
216
|
+
value: function (t, n) {
|
|
217
|
+
function callInvokeWithMethodAndArg() {
|
|
218
|
+
return new e(function (e, r) {
|
|
219
|
+
invoke(t, n, e, r);
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
function makeInvokeMethod(e, r, n) {
|
|
227
|
+
var o = h;
|
|
228
|
+
return function (i, a) {
|
|
229
|
+
if (o === f) throw Error("Generator is already running");
|
|
230
|
+
if (o === s) {
|
|
231
|
+
if ("throw" === i) throw a;
|
|
232
|
+
return {
|
|
233
|
+
value: t,
|
|
234
|
+
done: !0
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
for (n.method = i, n.arg = a;;) {
|
|
238
|
+
var c = n.delegate;
|
|
239
|
+
if (c) {
|
|
240
|
+
var u = maybeInvokeDelegate(c, n);
|
|
241
|
+
if (u) {
|
|
242
|
+
if (u === y) continue;
|
|
243
|
+
return u;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
|
|
247
|
+
if (o === h) throw o = s, n.arg;
|
|
248
|
+
n.dispatchException(n.arg);
|
|
249
|
+
} else "return" === n.method && n.abrupt("return", n.arg);
|
|
250
|
+
o = f;
|
|
251
|
+
var p = tryCatch(e, r, n);
|
|
252
|
+
if ("normal" === p.type) {
|
|
253
|
+
if (o = n.done ? s : l, p.arg === y) continue;
|
|
254
|
+
return {
|
|
255
|
+
value: p.arg,
|
|
256
|
+
done: n.done
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
"throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
|
|
260
|
+
}
|
|
261
|
+
};
|
|
262
|
+
}
|
|
263
|
+
function maybeInvokeDelegate(e, r) {
|
|
264
|
+
var n = r.method,
|
|
265
|
+
o = e.iterator[n];
|
|
266
|
+
if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
|
|
267
|
+
var i = tryCatch(o, e.iterator, r.arg);
|
|
268
|
+
if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
|
|
269
|
+
var a = i.arg;
|
|
270
|
+
return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
|
|
271
|
+
}
|
|
272
|
+
function pushTryEntry(t) {
|
|
273
|
+
var e = {
|
|
274
|
+
tryLoc: t[0]
|
|
275
|
+
};
|
|
276
|
+
1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
|
|
277
|
+
}
|
|
278
|
+
function resetTryEntry(t) {
|
|
279
|
+
var e = t.completion || {};
|
|
280
|
+
e.type = "normal", delete e.arg, t.completion = e;
|
|
281
|
+
}
|
|
282
|
+
function Context(t) {
|
|
283
|
+
this.tryEntries = [{
|
|
284
|
+
tryLoc: "root"
|
|
285
|
+
}], t.forEach(pushTryEntry, this), this.reset(!0);
|
|
286
|
+
}
|
|
287
|
+
function values(e) {
|
|
288
|
+
if (e || "" === e) {
|
|
289
|
+
var r = e[a];
|
|
290
|
+
if (r) return r.call(e);
|
|
291
|
+
if ("function" == typeof e.next) return e;
|
|
292
|
+
if (!isNaN(e.length)) {
|
|
293
|
+
var o = -1,
|
|
294
|
+
i = function next() {
|
|
295
|
+
for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
|
|
296
|
+
return next.value = t, next.done = !0, next;
|
|
297
|
+
};
|
|
298
|
+
return i.next = i;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
throw new TypeError(typeof e + " is not iterable");
|
|
302
|
+
}
|
|
303
|
+
return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
|
|
304
|
+
value: GeneratorFunctionPrototype,
|
|
305
|
+
configurable: !0
|
|
306
|
+
}), o(GeneratorFunctionPrototype, "constructor", {
|
|
307
|
+
value: GeneratorFunction,
|
|
308
|
+
configurable: !0
|
|
309
|
+
}), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
|
|
310
|
+
var e = "function" == typeof t && t.constructor;
|
|
311
|
+
return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
|
|
312
|
+
}, e.mark = function (t) {
|
|
313
|
+
return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
|
|
314
|
+
}, e.awrap = function (t) {
|
|
315
|
+
return {
|
|
316
|
+
__await: t
|
|
317
|
+
};
|
|
318
|
+
}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
|
|
319
|
+
return this;
|
|
320
|
+
}), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
|
|
321
|
+
void 0 === i && (i = Promise);
|
|
322
|
+
var a = new AsyncIterator(wrap(t, r, n, o), i);
|
|
323
|
+
return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
|
|
324
|
+
return t.done ? t.value : a.next();
|
|
325
|
+
});
|
|
326
|
+
}, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
|
|
327
|
+
return this;
|
|
328
|
+
}), define(g, "toString", function () {
|
|
329
|
+
return "[object Generator]";
|
|
330
|
+
}), e.keys = function (t) {
|
|
331
|
+
var e = Object(t),
|
|
332
|
+
r = [];
|
|
333
|
+
for (var n in e) r.push(n);
|
|
334
|
+
return r.reverse(), function next() {
|
|
335
|
+
for (; r.length;) {
|
|
336
|
+
var t = r.pop();
|
|
337
|
+
if (t in e) return next.value = t, next.done = !1, next;
|
|
338
|
+
}
|
|
339
|
+
return next.done = !0, next;
|
|
340
|
+
};
|
|
341
|
+
}, e.values = values, Context.prototype = {
|
|
342
|
+
constructor: Context,
|
|
343
|
+
reset: function (e) {
|
|
344
|
+
if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t);
|
|
345
|
+
},
|
|
346
|
+
stop: function () {
|
|
347
|
+
this.done = !0;
|
|
348
|
+
var t = this.tryEntries[0].completion;
|
|
349
|
+
if ("throw" === t.type) throw t.arg;
|
|
350
|
+
return this.rval;
|
|
351
|
+
},
|
|
352
|
+
dispatchException: function (e) {
|
|
353
|
+
if (this.done) throw e;
|
|
354
|
+
var r = this;
|
|
355
|
+
function handle(n, o) {
|
|
356
|
+
return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
|
|
357
|
+
}
|
|
358
|
+
for (var o = this.tryEntries.length - 1; o >= 0; --o) {
|
|
359
|
+
var i = this.tryEntries[o],
|
|
360
|
+
a = i.completion;
|
|
361
|
+
if ("root" === i.tryLoc) return handle("end");
|
|
362
|
+
if (i.tryLoc <= this.prev) {
|
|
363
|
+
var c = n.call(i, "catchLoc"),
|
|
364
|
+
u = n.call(i, "finallyLoc");
|
|
365
|
+
if (c && u) {
|
|
366
|
+
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
367
|
+
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
368
|
+
} else if (c) {
|
|
369
|
+
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
370
|
+
} else {
|
|
371
|
+
if (!u) throw Error("try statement without catch or finally");
|
|
372
|
+
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
},
|
|
377
|
+
abrupt: function (t, e) {
|
|
378
|
+
for (var r = this.tryEntries.length - 1; r >= 0; --r) {
|
|
379
|
+
var o = this.tryEntries[r];
|
|
380
|
+
if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
|
|
381
|
+
var i = o;
|
|
382
|
+
break;
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
|
|
386
|
+
var a = i ? i.completion : {};
|
|
387
|
+
return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
|
|
388
|
+
},
|
|
389
|
+
complete: function (t, e) {
|
|
390
|
+
if ("throw" === t.type) throw t.arg;
|
|
391
|
+
return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
|
|
392
|
+
},
|
|
393
|
+
finish: function (t) {
|
|
394
|
+
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
395
|
+
var r = this.tryEntries[e];
|
|
396
|
+
if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
|
|
397
|
+
}
|
|
398
|
+
},
|
|
399
|
+
catch: function (t) {
|
|
400
|
+
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
401
|
+
var r = this.tryEntries[e];
|
|
402
|
+
if (r.tryLoc === t) {
|
|
403
|
+
var n = r.completion;
|
|
404
|
+
if ("throw" === n.type) {
|
|
405
|
+
var o = n.arg;
|
|
406
|
+
resetTryEntry(r);
|
|
407
|
+
}
|
|
408
|
+
return o;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
throw Error("illegal catch attempt");
|
|
412
|
+
},
|
|
413
|
+
delegateYield: function (e, r, n) {
|
|
414
|
+
return this.delegate = {
|
|
415
|
+
iterator: values(e),
|
|
416
|
+
resultName: r,
|
|
417
|
+
nextLoc: n
|
|
418
|
+
}, "next" === this.method && (this.arg = t), y;
|
|
419
|
+
}
|
|
420
|
+
}, e;
|
|
421
|
+
}
|
|
422
|
+
function _setPrototypeOf(t, e) {
|
|
423
|
+
return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {
|
|
424
|
+
return t.__proto__ = e, t;
|
|
425
|
+
}, _setPrototypeOf(t, e);
|
|
426
|
+
}
|
|
427
|
+
function _superPropBase(t, o) {
|
|
428
|
+
for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t)););
|
|
429
|
+
return t;
|
|
430
|
+
}
|
|
431
|
+
function _superPropGet(t, o, e, r) {
|
|
432
|
+
var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e);
|
|
433
|
+
return 2 & r && "function" == typeof p ? function (t) {
|
|
434
|
+
return p.apply(e, t);
|
|
435
|
+
} : p;
|
|
436
|
+
}
|
|
437
|
+
function _toPrimitive(t, r) {
|
|
438
|
+
if ("object" != typeof t || !t) return t;
|
|
439
|
+
var e = t[Symbol.toPrimitive];
|
|
440
|
+
if (void 0 !== e) {
|
|
441
|
+
var i = e.call(t, r || "default");
|
|
442
|
+
if ("object" != typeof i) return i;
|
|
443
|
+
throw new TypeError("@@toPrimitive must return a primitive value.");
|
|
444
|
+
}
|
|
445
|
+
return ("string" === r ? String : Number)(t);
|
|
446
|
+
}
|
|
447
|
+
function _toPropertyKey(t) {
|
|
448
|
+
var i = _toPrimitive(t, "string");
|
|
449
|
+
return "symbol" == typeof i ? i : i + "";
|
|
450
|
+
}
|
|
451
|
+
|
|
452
|
+
var loadImage = function loadImage(url) {
|
|
453
|
+
return new Promise(function (resolve, reject) {
|
|
454
|
+
var img = new Image();
|
|
455
|
+
img.addEventListener("load", function () {
|
|
456
|
+
return resolve(img);
|
|
457
|
+
});
|
|
458
|
+
img.addEventListener("error", function (err) {
|
|
459
|
+
return reject(err);
|
|
460
|
+
});
|
|
461
|
+
img.crossOrigin = "anonymous";
|
|
462
|
+
img.src = url;
|
|
463
|
+
});
|
|
464
|
+
};
|
|
465
|
+
var DefaultHeightmapResource = /*#__PURE__*/function () {
|
|
466
|
+
function DefaultHeightmapResource() {
|
|
467
|
+
var _this = this,
|
|
468
|
+
_opts$skipOddLevels,
|
|
469
|
+
_opts$tileSize,
|
|
470
|
+
_opts$maxZoom;
|
|
471
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
472
|
+
_classCallCheck(this, DefaultHeightmapResource);
|
|
473
|
+
_defineProperty(this, "resource", null);
|
|
474
|
+
_defineProperty(this, "tileSize", 256);
|
|
475
|
+
_defineProperty(this, "skipOddLevels", false);
|
|
476
|
+
_defineProperty(this, "getTilePixels", /*#__PURE__*/function () {
|
|
477
|
+
var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(coords) {
|
|
478
|
+
var url, img;
|
|
479
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
480
|
+
while (1) switch (_context.prev = _context.next) {
|
|
481
|
+
case 0:
|
|
482
|
+
url = _this.buildTileURL(coords);
|
|
483
|
+
_context.next = 3;
|
|
484
|
+
return loadImage(url);
|
|
485
|
+
case 3:
|
|
486
|
+
img = _context.sent;
|
|
487
|
+
return _context.abrupt("return", _this.getPixels(img));
|
|
488
|
+
case 5:
|
|
489
|
+
case "end":
|
|
490
|
+
return _context.stop();
|
|
491
|
+
}
|
|
492
|
+
}, _callee);
|
|
493
|
+
}));
|
|
494
|
+
return function (_x) {
|
|
495
|
+
return _ref.apply(this, arguments);
|
|
496
|
+
};
|
|
497
|
+
}());
|
|
498
|
+
if (opts.url) {
|
|
499
|
+
this.resource = cesium.Resource.createIfNeeded(opts.url);
|
|
500
|
+
}
|
|
501
|
+
this.skipOddLevels = (_opts$skipOddLevels = opts.skipOddLevels) !== null && _opts$skipOddLevels !== void 0 ? _opts$skipOddLevels : false;
|
|
502
|
+
this.tileSize = (_opts$tileSize = opts.tileSize) !== null && _opts$tileSize !== void 0 ? _opts$tileSize : 256;
|
|
503
|
+
this.maxZoom = (_opts$maxZoom = opts.maxZoom) !== null && _opts$maxZoom !== void 0 ? _opts$maxZoom : 15;
|
|
504
|
+
this.contextQueue = [];
|
|
505
|
+
}
|
|
506
|
+
return _createClass(DefaultHeightmapResource, [{
|
|
507
|
+
key: "getCanvas",
|
|
508
|
+
value: function getCanvas() {
|
|
509
|
+
var ctx = this.contextQueue.pop();
|
|
510
|
+
if (ctx == null) {
|
|
511
|
+
var canvas = document.createElement("canvas");
|
|
512
|
+
canvas.width = this.tileSize;
|
|
513
|
+
canvas.height = this.tileSize;
|
|
514
|
+
var context = canvas.getContext("2d");
|
|
515
|
+
ctx = {
|
|
516
|
+
canvas: canvas,
|
|
517
|
+
context: context
|
|
518
|
+
};
|
|
519
|
+
}
|
|
520
|
+
return ctx;
|
|
521
|
+
}
|
|
522
|
+
}, {
|
|
523
|
+
key: "getPixels",
|
|
524
|
+
value: function getPixels(img) {
|
|
525
|
+
var canvasRef = this.getCanvas();
|
|
526
|
+
var context = canvasRef.context;
|
|
527
|
+
//context.scale(1, -1);
|
|
528
|
+
// Chrome appears to vertically flip the image for reasons that are unclear
|
|
529
|
+
// We can make it work in Chrome by drawing the image upside-down at this step.
|
|
530
|
+
context.drawImage(img, 0, 0, this.tileSize, this.tileSize);
|
|
531
|
+
var pixels = context.getImageData(0, 0, this.tileSize, this.tileSize);
|
|
532
|
+
context.clearRect(0, 0, this.tileSize, this.tileSize);
|
|
533
|
+
this.contextQueue.push(canvasRef);
|
|
534
|
+
return pixels;
|
|
535
|
+
}
|
|
536
|
+
}, {
|
|
537
|
+
key: "buildTileURL",
|
|
538
|
+
value: function buildTileURL(tileCoords) {
|
|
539
|
+
var _this$resource;
|
|
540
|
+
// reverseY for TMS tiling (https://gist.github.com/tmcw/4954720)
|
|
541
|
+
// See tiling schemes here: https://www.maptiler.com/google-maps-coordinates-tile-bounds-projection/
|
|
542
|
+
var z = tileCoords.z,
|
|
543
|
+
y = tileCoords.y;
|
|
544
|
+
return (_this$resource = this.resource) === null || _this$resource === void 0 ? void 0 : _this$resource.getDerivedResource({
|
|
545
|
+
templateValues: _objectSpread2(_objectSpread2({}, tileCoords), {}, {
|
|
546
|
+
reverseY: Math.pow(2, z) - y - 1
|
|
547
|
+
}),
|
|
548
|
+
preserveQueryParameters: true
|
|
549
|
+
}).getUrlComponent(true);
|
|
550
|
+
}
|
|
551
|
+
}, {
|
|
552
|
+
key: "getTileDataAvailable",
|
|
553
|
+
value: function getTileDataAvailable(_ref2) {
|
|
554
|
+
var z = _ref2.z;
|
|
555
|
+
if (z == this.maxZoom) return true;
|
|
556
|
+
if (z % 2 == 1 && this.skipOddLevels) return false;
|
|
557
|
+
if (z > this.maxZoom) return false;
|
|
558
|
+
return true;
|
|
559
|
+
}
|
|
560
|
+
}]);
|
|
561
|
+
}();
|
|
562
|
+
|
|
563
|
+
var ImageFormat = /*#__PURE__*/function (ImageFormat) {
|
|
564
|
+
ImageFormat["WEBP"] = "webp";
|
|
565
|
+
ImageFormat["PNG"] = "png";
|
|
566
|
+
ImageFormat["PNGRAW"] = "pngraw";
|
|
567
|
+
return ImageFormat;
|
|
568
|
+
}({});
|
|
569
|
+
var MapboxTerrainResource = /*#__PURE__*/function (_DefaultHeightmapReso) {
|
|
570
|
+
function MapboxTerrainResource() {
|
|
571
|
+
var _opts$highResolution, _opts$imageFormat;
|
|
572
|
+
var _this;
|
|
573
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
574
|
+
_classCallCheck(this, MapboxTerrainResource);
|
|
575
|
+
_this = _callSuper(this, MapboxTerrainResource, [opts]);
|
|
576
|
+
_defineProperty(_this, "resource", null);
|
|
577
|
+
_defineProperty(_this, "credit", new cesium.Credit("Mapbox"));
|
|
578
|
+
var highResolution = (_opts$highResolution = opts.highResolution) !== null && _opts$highResolution !== void 0 ? _opts$highResolution : false;
|
|
579
|
+
var format = (_opts$imageFormat = opts.imageFormat) !== null && _opts$imageFormat !== void 0 ? _opts$imageFormat : ImageFormat.WEBP;
|
|
580
|
+
|
|
581
|
+
// overrides based on highResolution flag
|
|
582
|
+
if (highResolution) {
|
|
583
|
+
if (opts.maxZoom === undefined) {
|
|
584
|
+
_this.maxZoom = 14;
|
|
585
|
+
}
|
|
586
|
+
if (opts.tileSize === undefined) {
|
|
587
|
+
_this.tileSize = 512;
|
|
588
|
+
}
|
|
589
|
+
}
|
|
590
|
+
_this.resource = cesium.Resource.createIfNeeded("https://api.mapbox.com/v4/mapbox.terrain-rgb/{z}/{x}/{y}".concat(highResolution ? "@2x" : "", ".").concat(format));
|
|
591
|
+
if (opts.accessToken) {
|
|
592
|
+
_this.resource.setQueryParameters({
|
|
593
|
+
access_token: opts.accessToken
|
|
594
|
+
});
|
|
595
|
+
}
|
|
596
|
+
return _this;
|
|
597
|
+
}
|
|
598
|
+
_inherits(MapboxTerrainResource, _DefaultHeightmapReso);
|
|
599
|
+
return _createClass(MapboxTerrainResource);
|
|
600
|
+
}(DefaultHeightmapResource);
|
|
601
|
+
|
|
602
|
+
function _emptyMesh(n) {
|
|
603
|
+
n = Math.max(n, 2);
|
|
604
|
+
var nTriangles = Math.pow(n - 1, 2) * 2;
|
|
605
|
+
var nVertices = Math.pow(n, 2);
|
|
606
|
+
var quantizedVertices = new Uint16Array(nVertices * 3);
|
|
607
|
+
var indices = new Uint16Array(nTriangles * 3);
|
|
608
|
+
var westIndices = [];
|
|
609
|
+
var southIndices = [];
|
|
610
|
+
var eastIndices = [];
|
|
611
|
+
var northIndices = [];
|
|
612
|
+
var tix = 0;
|
|
613
|
+
for (var i = 0; i < nVertices; i++) {
|
|
614
|
+
var rx = i % n; //* 32767) / (n - 1);
|
|
615
|
+
var ry = Math.floor(i / n); //* 32767) / (n - 1);
|
|
616
|
+
var ix = n * rx + ry;
|
|
617
|
+
quantizedVertices[ix] = rx * 32768 / (n - 1);
|
|
618
|
+
quantizedVertices[nVertices + ix] = ry * 32768 / (n - 1);
|
|
619
|
+
quantizedVertices[2 * nVertices + ix] = 0;
|
|
620
|
+
if (ry == 0) westIndices.push(ix);
|
|
621
|
+
if (rx == 0) southIndices.push(ix);
|
|
622
|
+
if (rx == n - 1) eastIndices.push(ix);
|
|
623
|
+
if (ry == n - 1) northIndices.push(ix);
|
|
624
|
+
|
|
625
|
+
// Add triangles
|
|
626
|
+
var rix = i - ry * n;
|
|
627
|
+
if (rix != n - 1) {
|
|
628
|
+
indices[tix * 3] = i;
|
|
629
|
+
indices[tix * 3 + 1] = i + n + 1;
|
|
630
|
+
indices[tix * 3 + 2] = i + 1;
|
|
631
|
+
tix++;
|
|
632
|
+
}
|
|
633
|
+
if (rix != 0) {
|
|
634
|
+
indices[tix * 3] = i - 1;
|
|
635
|
+
indices[tix * 3 + 1] = i + n - 1;
|
|
636
|
+
indices[tix * 3 + 2] = i + n;
|
|
637
|
+
tix++;
|
|
638
|
+
}
|
|
639
|
+
}
|
|
640
|
+
return {
|
|
641
|
+
minimumHeight: 0,
|
|
642
|
+
maximumHeight: 0,
|
|
643
|
+
quantizedVertices: quantizedVertices,
|
|
644
|
+
indices: indices,
|
|
645
|
+
westIndices: westIndices,
|
|
646
|
+
southIndices: southIndices,
|
|
647
|
+
eastIndices: eastIndices,
|
|
648
|
+
northIndices: northIndices
|
|
649
|
+
};
|
|
650
|
+
}
|
|
651
|
+
var _meshCache = [];
|
|
652
|
+
function emptyMesh(n) {
|
|
653
|
+
// A memoized function to return empty meshes
|
|
654
|
+
if (n in _meshCache) {
|
|
655
|
+
return _meshCache[n];
|
|
656
|
+
} else {
|
|
657
|
+
var result = _emptyMesh(n);
|
|
658
|
+
_meshCache[n] = result;
|
|
659
|
+
return result;
|
|
660
|
+
}
|
|
661
|
+
}
|
|
662
|
+
|
|
663
|
+
var resolves = {};
|
|
664
|
+
var rejects = {};
|
|
665
|
+
var globalMsgId = 0; // Activate calculation in the worker, returning a promise
|
|
666
|
+
function sendMessage(_x, _x2, _x3) {
|
|
667
|
+
return _sendMessage.apply(this, arguments);
|
|
668
|
+
} // Handle incoming calculation result
|
|
669
|
+
function _sendMessage() {
|
|
670
|
+
_sendMessage = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee2(worker, payload, transferableObjects) {
|
|
671
|
+
var msgId, msg;
|
|
672
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
673
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
674
|
+
case 0:
|
|
675
|
+
msgId = globalMsgId++;
|
|
676
|
+
msg = {
|
|
677
|
+
id: msgId,
|
|
678
|
+
payload: payload
|
|
679
|
+
};
|
|
680
|
+
return _context2.abrupt("return", new Promise(function (resolve, reject) {
|
|
681
|
+
// save callbacks for later
|
|
682
|
+
resolves[msgId] = resolve;
|
|
683
|
+
rejects[msgId] = reject;
|
|
684
|
+
worker.postMessage(msg, transferableObjects);
|
|
685
|
+
}));
|
|
686
|
+
case 3:
|
|
687
|
+
case "end":
|
|
688
|
+
return _context2.stop();
|
|
689
|
+
}
|
|
690
|
+
}, _callee2);
|
|
691
|
+
}));
|
|
692
|
+
return _sendMessage.apply(this, arguments);
|
|
693
|
+
}
|
|
694
|
+
function handleMessage(msg) {
|
|
695
|
+
var _msg$data = msg.data,
|
|
696
|
+
id = _msg$data.id,
|
|
697
|
+
err = _msg$data.err,
|
|
698
|
+
payload = _msg$data.payload;
|
|
699
|
+
if (payload) {
|
|
700
|
+
var resolve = resolves[id];
|
|
701
|
+
if (resolve) {
|
|
702
|
+
resolve(payload);
|
|
703
|
+
}
|
|
704
|
+
} else {
|
|
705
|
+
// error condition
|
|
706
|
+
var reject = rejects[id];
|
|
707
|
+
if (reject) {
|
|
708
|
+
if (err) {
|
|
709
|
+
reject(err);
|
|
710
|
+
} else {
|
|
711
|
+
reject("Got nothing");
|
|
712
|
+
}
|
|
713
|
+
}
|
|
714
|
+
}
|
|
715
|
+
|
|
716
|
+
// purge used callbacks
|
|
717
|
+
delete resolves[id];
|
|
718
|
+
delete rejects[id];
|
|
719
|
+
}
|
|
720
|
+
var WorkerFarm = /*#__PURE__*/function () {
|
|
721
|
+
function WorkerFarm(opts) {
|
|
722
|
+
_classCallCheck(this, WorkerFarm);
|
|
723
|
+
this.worker = opts.worker;
|
|
724
|
+
this.worker.onmessage = handleMessage;
|
|
725
|
+
}
|
|
726
|
+
return _createClass(WorkerFarm, [{
|
|
727
|
+
key: "scheduleTask",
|
|
728
|
+
value: function () {
|
|
729
|
+
var _scheduleTask = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(params, transferableObjects) {
|
|
730
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
731
|
+
while (1) switch (_context.prev = _context.next) {
|
|
732
|
+
case 0:
|
|
733
|
+
_context.next = 2;
|
|
734
|
+
return sendMessage(this.worker, params, transferableObjects);
|
|
735
|
+
case 2:
|
|
736
|
+
return _context.abrupt("return", _context.sent);
|
|
737
|
+
case 3:
|
|
738
|
+
case "end":
|
|
739
|
+
return _context.stop();
|
|
740
|
+
}
|
|
741
|
+
}, _callee, this);
|
|
742
|
+
}));
|
|
743
|
+
function scheduleTask(_x4, _x5) {
|
|
744
|
+
return _scheduleTask.apply(this, arguments);
|
|
745
|
+
}
|
|
746
|
+
return scheduleTask;
|
|
747
|
+
}()
|
|
748
|
+
}]);
|
|
749
|
+
}();
|
|
750
|
+
|
|
751
|
+
var DefaultTerrainDecoder = /*#__PURE__*/function () {
|
|
752
|
+
function DefaultTerrainDecoder() {
|
|
753
|
+
_classCallCheck(this, DefaultTerrainDecoder);
|
|
754
|
+
_defineProperty(this, "inProgress", 0);
|
|
755
|
+
_defineProperty(this, "maxRequests", 2);
|
|
756
|
+
}
|
|
757
|
+
return _createClass(DefaultTerrainDecoder, [{
|
|
758
|
+
key: "requestTileGeometry",
|
|
759
|
+
value: function requestTileGeometry(coords, processFunction) {
|
|
760
|
+
var _this = this;
|
|
761
|
+
if (this.inProgress > this.maxRequests) return undefined;
|
|
762
|
+
this.inProgress += 1;
|
|
763
|
+
return processFunction(coords)["finally"](function () {
|
|
764
|
+
_this.inProgress -= 1;
|
|
765
|
+
});
|
|
766
|
+
}
|
|
767
|
+
}, {
|
|
768
|
+
key: "decodeTerrain",
|
|
769
|
+
value: function decodeTerrain(params, data) {
|
|
770
|
+
return Promise.resolve(null);
|
|
771
|
+
}
|
|
772
|
+
}]);
|
|
773
|
+
}();
|
|
774
|
+
var WorkerFarmTerrainDecoder = /*#__PURE__*/function (_DefaultTerrainDecode) {
|
|
775
|
+
function WorkerFarmTerrainDecoder(opts) {
|
|
776
|
+
var _opts$maxWorkers;
|
|
777
|
+
var _this2;
|
|
778
|
+
_classCallCheck(this, WorkerFarmTerrainDecoder);
|
|
779
|
+
_this2 = _callSuper(this, WorkerFarmTerrainDecoder);
|
|
780
|
+
_this2.farm = new WorkerFarm({
|
|
781
|
+
worker: opts.worker
|
|
782
|
+
});
|
|
783
|
+
_this2.maxRequests = (_opts$maxWorkers = opts.maxWorkers) !== null && _opts$maxWorkers !== void 0 ? _opts$maxWorkers : 5;
|
|
784
|
+
return _this2;
|
|
785
|
+
}
|
|
786
|
+
_inherits(WorkerFarmTerrainDecoder, _DefaultTerrainDecode);
|
|
787
|
+
return _createClass(WorkerFarmTerrainDecoder, [{
|
|
788
|
+
key: "decodeTerrain",
|
|
789
|
+
value: function decodeTerrain(params, data) {
|
|
790
|
+
return this.farm.scheduleTask(params, [data]);
|
|
791
|
+
}
|
|
792
|
+
}]);
|
|
793
|
+
}(DefaultTerrainDecoder);
|
|
794
|
+
|
|
795
|
+
// https://github.com/CesiumGS/cesium/blob/1.68/Source/Scene/MapboxImageryProvider.js#L42
|
|
796
|
+
var StretchedTilingScheme = /*#__PURE__*/function (_WebMercatorTilingSch) {
|
|
797
|
+
function StretchedTilingScheme() {
|
|
798
|
+
_classCallCheck(this, StretchedTilingScheme);
|
|
799
|
+
return _callSuper(this, StretchedTilingScheme, arguments);
|
|
800
|
+
}
|
|
801
|
+
_inherits(StretchedTilingScheme, _WebMercatorTilingSch);
|
|
802
|
+
return _createClass(StretchedTilingScheme, [{
|
|
803
|
+
key: "tileXYToRectangle",
|
|
804
|
+
value: function tileXYToRectangle(x, y, level, res) {
|
|
805
|
+
var result = _superPropGet(StretchedTilingScheme, "tileXYToRectangle", this, 3)([x, y, level]);
|
|
806
|
+
if (y == 0) {
|
|
807
|
+
//console.log("Top row", res, y, level);
|
|
808
|
+
result.north = Math.PI / 2;
|
|
809
|
+
}
|
|
810
|
+
if (y + 1 == Math.pow(2, level)) {
|
|
811
|
+
result.south = -Math.PI / 2;
|
|
812
|
+
}
|
|
813
|
+
return result;
|
|
814
|
+
}
|
|
815
|
+
}]);
|
|
816
|
+
}(cesium.WebMercatorTilingScheme);
|
|
817
|
+
var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
818
|
+
// @ts-ignore
|
|
819
|
+
function MartiniTerrainProvider() {
|
|
820
|
+
var _this$resource$credit, _opts$minZoomLevel, _opts$fillPoles, _opts$detailScalar, _opts$minimumErrorLev, _opts$ellipsoid;
|
|
821
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
822
|
+
_classCallCheck(this, MartiniTerrainProvider);
|
|
823
|
+
_defineProperty(this, "hasWaterMask", false);
|
|
824
|
+
_defineProperty(this, "hasVertexNormals", false);
|
|
825
|
+
_defineProperty(this, "credit", new cesium.Credit("Mapbox"));
|
|
826
|
+
_defineProperty(this, "availability", null);
|
|
827
|
+
_defineProperty(this, "errorEvent", new cesium.Event());
|
|
828
|
+
_defineProperty(this, "levelOfDetailScalar", null);
|
|
829
|
+
_defineProperty(this, "minError", 0.1);
|
|
830
|
+
_defineProperty(this, "fillPoles", true);
|
|
831
|
+
_defineProperty(this, "_errorAtMinZoom", 1000);
|
|
832
|
+
_defineProperty(this, "resource", null);
|
|
833
|
+
_defineProperty(this, "decoder", null);
|
|
834
|
+
_defineProperty(this, "RADIUS_SCALAR", 1.0);
|
|
835
|
+
//this.martini = new Martini(257);
|
|
836
|
+
this.resource = opts.resource;
|
|
837
|
+
this.credit = (_this$resource$credit = this.resource.credit) !== null && _this$resource$credit !== void 0 ? _this$resource$credit : new cesium.Credit("Mapbox");
|
|
838
|
+
this.decoder = opts.decoder;
|
|
839
|
+
if (!this.decoder) {
|
|
840
|
+
var _opts$maxWorkers;
|
|
841
|
+
var maxWorkers = (_opts$maxWorkers = opts.maxWorkers) !== null && _opts$maxWorkers !== void 0 ? _opts$maxWorkers : 5;
|
|
842
|
+
if (maxWorkers > 0) {
|
|
843
|
+
this.decoder = new WorkerFarmTerrainDecoder({
|
|
844
|
+
maxWorkers: maxWorkers
|
|
845
|
+
});
|
|
846
|
+
} else {
|
|
847
|
+
this.decoder = new DefaultTerrainDecoder();
|
|
848
|
+
}
|
|
849
|
+
}
|
|
850
|
+
this.minZoomLevel = (_opts$minZoomLevel = opts.minZoomLevel) !== null && _opts$minZoomLevel !== void 0 ? _opts$minZoomLevel : 3;
|
|
851
|
+
this.fillPoles = (_opts$fillPoles = opts.fillPoles) !== null && _opts$fillPoles !== void 0 ? _opts$fillPoles : true;
|
|
852
|
+
this.levelOfDetailScalar = ((_opts$detailScalar = opts.detailScalar) !== null && _opts$detailScalar !== void 0 ? _opts$detailScalar : 4.0) + cesium.Math.EPSILON5;
|
|
853
|
+
this.ready = true;
|
|
854
|
+
this.readyPromise = Promise.resolve(true);
|
|
855
|
+
this.minError = (_opts$minimumErrorLev = opts.minimumErrorLevel) !== null && _opts$minimumErrorLev !== void 0 ? _opts$minimumErrorLev : 0.1;
|
|
856
|
+
this.errorEvent.addEventListener(console.log, this);
|
|
857
|
+
this.ellipsoid = (_opts$ellipsoid = opts.ellipsoid) !== null && _opts$ellipsoid !== void 0 ? _opts$ellipsoid : cesium.Ellipsoid.WGS84;
|
|
858
|
+
var scheme = cesium.WebMercatorTilingScheme;
|
|
859
|
+
if (this.fillPoles) {
|
|
860
|
+
scheme = StretchedTilingScheme;
|
|
861
|
+
}
|
|
862
|
+
this.tilingScheme = new scheme({
|
|
863
|
+
numberOfLevelZeroTilesX: 1,
|
|
864
|
+
numberOfLevelZeroTilesY: 1,
|
|
865
|
+
ellipsoid: this.ellipsoid
|
|
866
|
+
});
|
|
867
|
+
this._errorAtMinZoom = this.errorAtZoom(this.minZoomLevel);
|
|
868
|
+
}
|
|
869
|
+
return _createClass(MartiniTerrainProvider, [{
|
|
870
|
+
key: "requestTileGeometry",
|
|
871
|
+
value: function requestTileGeometry(x, y, z, request) {
|
|
872
|
+
// Look for tiles both below the zoom level and below the error threshold for the zoom level at the equator...
|
|
873
|
+
if (z < this.minZoomLevel || this.scaledErrorForTile(x, y, z) > this._errorAtMinZoom) {
|
|
874
|
+
// If we are below the minimum zoom level, we return empty heightmaps
|
|
875
|
+
// to avoid unnecessary requests for low-resolution data.
|
|
876
|
+
return Promise.resolve(this.emptyMesh(x, y, z));
|
|
877
|
+
}
|
|
878
|
+
// Note: we still load a TON of tiles near the poles. We might need to do some overzooming here...
|
|
879
|
+
return this.decoder.requestTileGeometry({
|
|
880
|
+
x: x,
|
|
881
|
+
y: y,
|
|
882
|
+
z: z
|
|
883
|
+
}, this.processTile.bind(this));
|
|
884
|
+
}
|
|
885
|
+
}, {
|
|
886
|
+
key: "processTile",
|
|
887
|
+
value: function () {
|
|
888
|
+
var _processTile = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(_ref) {
|
|
889
|
+
var x, y, z, _this$resource, tileSize, getTilePixels, px, pixelData, tileRect, err, maxLength, params, res;
|
|
890
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
891
|
+
while (1) switch (_context.prev = _context.next) {
|
|
892
|
+
case 0:
|
|
893
|
+
x = _ref.x, y = _ref.y, z = _ref.z;
|
|
894
|
+
_context.prev = 1;
|
|
895
|
+
_this$resource = this.resource, tileSize = _this$resource.tileSize, getTilePixels = _this$resource.getTilePixels;
|
|
896
|
+
_context.next = 5;
|
|
897
|
+
return getTilePixels({
|
|
898
|
+
x: x,
|
|
899
|
+
y: y,
|
|
900
|
+
z: z
|
|
901
|
+
});
|
|
902
|
+
case 5:
|
|
903
|
+
px = _context.sent;
|
|
904
|
+
pixelData = px.data;
|
|
905
|
+
tileRect = this.tilingScheme.tileXYToRectangle(x, y, z); ///const center = Rectangle.center(tileRect);
|
|
906
|
+
err = this.errorAtZoom(z);
|
|
907
|
+
maxLength = this.maxVertexDistance(tileRect);
|
|
908
|
+
params = {
|
|
909
|
+
imageData: pixelData,
|
|
910
|
+
maxLength: maxLength,
|
|
911
|
+
x: x,
|
|
912
|
+
y: y,
|
|
913
|
+
z: z,
|
|
914
|
+
errorLevel: err,
|
|
915
|
+
ellipsoidRadius: this.ellipsoid.maximumRadius,
|
|
916
|
+
tileSize: tileSize
|
|
917
|
+
};
|
|
918
|
+
_context.next = 13;
|
|
919
|
+
return this.decoder.decodeTerrain(params, pixelData.buffer);
|
|
920
|
+
case 13:
|
|
921
|
+
res = _context.sent;
|
|
922
|
+
pixelData = undefined;
|
|
923
|
+
px = undefined;
|
|
924
|
+
return _context.abrupt("return", this.createQuantizedMeshData(tileRect, err, res));
|
|
925
|
+
case 19:
|
|
926
|
+
_context.prev = 19;
|
|
927
|
+
_context.t0 = _context["catch"](1);
|
|
928
|
+
console.log(_context.t0);
|
|
929
|
+
return _context.abrupt("return", this.emptyMesh(x, y, z));
|
|
930
|
+
case 23:
|
|
931
|
+
case "end":
|
|
932
|
+
return _context.stop();
|
|
933
|
+
}
|
|
934
|
+
}, _callee, this, [[1, 19]]);
|
|
935
|
+
}));
|
|
936
|
+
function processTile(_x) {
|
|
937
|
+
return _processTile.apply(this, arguments);
|
|
938
|
+
}
|
|
939
|
+
return processTile;
|
|
940
|
+
}()
|
|
941
|
+
}, {
|
|
942
|
+
key: "errorAtZoom",
|
|
943
|
+
value: function errorAtZoom(zoom) {
|
|
944
|
+
return Math.max(this.getLevelMaximumGeometricError(zoom) / this.levelOfDetailScalar, this.minError);
|
|
945
|
+
}
|
|
946
|
+
}, {
|
|
947
|
+
key: "scaledErrorForTile",
|
|
948
|
+
value: function scaledErrorForTile(x, y, z) {
|
|
949
|
+
var tileRect = this.tilingScheme.tileXYToRectangle(x, y, z);
|
|
950
|
+
var center = cesium.Rectangle.center(tileRect);
|
|
951
|
+
return this.errorAtZoom(z) / Math.pow(1 - Math.sin(center.latitude), 2);
|
|
952
|
+
}
|
|
953
|
+
}, {
|
|
954
|
+
key: "maxVertexDistance",
|
|
955
|
+
value: function maxVertexDistance(tileRect) {
|
|
956
|
+
return Math.ceil(2 / tileRect.height);
|
|
957
|
+
}
|
|
958
|
+
}, {
|
|
959
|
+
key: "emptyMesh",
|
|
960
|
+
value: function emptyMesh$1(x, y, z) {
|
|
961
|
+
var tileRect = this.tilingScheme.tileXYToRectangle(x, y, z);
|
|
962
|
+
var center = cesium.Rectangle.center(tileRect);
|
|
963
|
+
var latScalar = Math.min(Math.abs(Math.sin(center.latitude)), 0.995);
|
|
964
|
+
var v = Math.max(Math.ceil(200 / (z + 1) * Math.pow(1 - latScalar, 0.25)), 4);
|
|
965
|
+
var output = emptyMesh(v);
|
|
966
|
+
var err = this.errorAtZoom(z);
|
|
967
|
+
return this.createQuantizedMeshData(tileRect, err, output);
|
|
968
|
+
}
|
|
969
|
+
}, {
|
|
970
|
+
key: "createQuantizedMeshData",
|
|
971
|
+
value: function createQuantizedMeshData(tileRect, errorLevel, workerOutput) {
|
|
972
|
+
var minimumHeight = workerOutput.minimumHeight,
|
|
973
|
+
maximumHeight = workerOutput.maximumHeight,
|
|
974
|
+
quantizedVertices = workerOutput.quantizedVertices,
|
|
975
|
+
indices = workerOutput.indices,
|
|
976
|
+
westIndices = workerOutput.westIndices,
|
|
977
|
+
southIndices = workerOutput.southIndices,
|
|
978
|
+
eastIndices = workerOutput.eastIndices,
|
|
979
|
+
northIndices = workerOutput.northIndices;
|
|
980
|
+
var err = errorLevel;
|
|
981
|
+
var skirtHeight = err * 20;
|
|
982
|
+
var center = cesium.Rectangle.center(tileRect);
|
|
983
|
+
|
|
984
|
+
// Calculating occlusion height is kind of messy currently, but it definitely works
|
|
985
|
+
var halfAngle = tileRect.width / 2;
|
|
986
|
+
var dr = Math.cos(halfAngle); // half tile width since our ref point is at the center
|
|
987
|
+
|
|
988
|
+
var occlusionHeight = dr * this.ellipsoid.maximumRadius + maximumHeight;
|
|
989
|
+
if (halfAngle > Math.PI / 4) {
|
|
990
|
+
occlusionHeight = (1 + halfAngle) * this.ellipsoid.maximumRadius;
|
|
991
|
+
}
|
|
992
|
+
var occlusionPoint = new cesium.Cartographic(center.longitude, center.latitude, occlusionHeight
|
|
993
|
+
// Scaling factor of two just to be sure.
|
|
994
|
+
);
|
|
995
|
+
var horizonOcclusionPoint = this.ellipsoid.transformPositionToScaledSpace(cesium.Cartographic.toCartesian(occlusionPoint));
|
|
996
|
+
var orientedBoundingBox = cesium.OrientedBoundingBox.fromRectangle(tileRect, minimumHeight, maximumHeight, this.tilingScheme.ellipsoid);
|
|
997
|
+
var boundingSphere = cesium.BoundingSphere.fromOrientedBoundingBox(orientedBoundingBox);
|
|
998
|
+
|
|
999
|
+
// SE NW NE
|
|
1000
|
+
// NE NW SE
|
|
1001
|
+
|
|
1002
|
+
var result = new cesium.QuantizedMeshTerrainData({
|
|
1003
|
+
minimumHeight: minimumHeight,
|
|
1004
|
+
maximumHeight: maximumHeight,
|
|
1005
|
+
quantizedVertices: quantizedVertices,
|
|
1006
|
+
indices: indices,
|
|
1007
|
+
boundingSphere: boundingSphere,
|
|
1008
|
+
orientedBoundingBox: orientedBoundingBox,
|
|
1009
|
+
horizonOcclusionPoint: horizonOcclusionPoint,
|
|
1010
|
+
westIndices: westIndices,
|
|
1011
|
+
southIndices: southIndices,
|
|
1012
|
+
eastIndices: eastIndices,
|
|
1013
|
+
northIndices: northIndices,
|
|
1014
|
+
westSkirtHeight: skirtHeight,
|
|
1015
|
+
southSkirtHeight: skirtHeight,
|
|
1016
|
+
eastSkirtHeight: skirtHeight,
|
|
1017
|
+
northSkirtHeight: skirtHeight,
|
|
1018
|
+
childTileMask: 15
|
|
1019
|
+
});
|
|
1020
|
+
return result;
|
|
1021
|
+
}
|
|
1022
|
+
}, {
|
|
1023
|
+
key: "getLevelMaximumGeometricError",
|
|
1024
|
+
value: function getLevelMaximumGeometricError(level) {
|
|
1025
|
+
var levelZeroMaximumGeometricError = cesium.TerrainProvider.getEstimatedLevelZeroGeometricErrorForAHeightmap(this.tilingScheme.ellipsoid, 65, this.tilingScheme.getNumberOfXTilesAtLevel(0));
|
|
1026
|
+
|
|
1027
|
+
// Scalar to control overzooming
|
|
1028
|
+
// also seems to control zooming for imagery layers
|
|
1029
|
+
var scalar = this.resource.tileSize / 256;
|
|
1030
|
+
return levelZeroMaximumGeometricError / scalar / (1 << level);
|
|
1031
|
+
}
|
|
1032
|
+
}, {
|
|
1033
|
+
key: "getTileDataAvailable",
|
|
1034
|
+
value: function getTileDataAvailable(x, y, z) {
|
|
1035
|
+
return this.resource.getTileDataAvailable({
|
|
1036
|
+
x: x,
|
|
1037
|
+
y: y,
|
|
1038
|
+
z: z
|
|
1039
|
+
});
|
|
1040
|
+
}
|
|
1041
|
+
}]);
|
|
1042
|
+
}();
|
|
1043
|
+
|
|
1044
|
+
function decodeBase64(base64, enableUnicode) {
|
|
1045
|
+
var binaryString = atob(base64);
|
|
1046
|
+
if (enableUnicode) {
|
|
1047
|
+
var binaryView = new Uint8Array(binaryString.length);
|
|
1048
|
+
for (var i = 0, n = binaryString.length; i < n; ++i) {
|
|
1049
|
+
binaryView[i] = binaryString.charCodeAt(i);
|
|
1050
|
+
}
|
|
1051
|
+
const decoder = new TextDecoder("utf-16le");
|
|
1052
|
+
return decoder.decode(new Uint16Array(binaryView.buffer));
|
|
1053
|
+
}
|
|
1054
|
+
return binaryString;
|
|
1055
|
+
}
|
|
1056
|
+
|
|
1057
|
+
function createURL(base64, sourcemapArg, enableUnicodeArg) {
|
|
1058
|
+
var sourcemap = sourcemapArg === undefined ? null : sourcemapArg;
|
|
1059
|
+
var enableUnicode = enableUnicodeArg === undefined ? false : enableUnicodeArg;
|
|
1060
|
+
var source = decodeBase64(base64, enableUnicode);
|
|
1061
|
+
var start = source.indexOf('\n', 10) + 1;
|
|
1062
|
+
var body = source.substring(start) + (sourcemap ? '\/\/# sourceMappingURL=' + sourcemap : '');
|
|
1063
|
+
var blob = new Blob([body], { type: 'application/javascript' });
|
|
1064
|
+
return URL.createObjectURL(blob);
|
|
1065
|
+
}
|
|
1066
|
+
|
|
1067
|
+
function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
|
|
1068
|
+
var url;
|
|
1069
|
+
return function WorkerFactory(options) {
|
|
1070
|
+
url = url || createURL(base64, sourcemapArg, enableUnicodeArg);
|
|
1071
|
+
return new Worker(url, options);
|
|
1072
|
+
};
|
|
1073
|
+
}
|
|
1074
|
+
|
|
1075
|
+
var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  function _arrayLikeToArray(r, a) {
    (null == a || a > r.length) && (a = r.length);
    for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
    return n;
  }
  function _arrayWithoutHoles(r) {
    if (Array.isArray(r)) return _arrayLikeToArray(r);
  }
  function _iterableToArray(r) {
    if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r);
  }
  function _nonIterableSpread() {
    throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
  }
  function _toConsumableArray(r) {
    return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread();
  }
  function _unsupportedIterableToArray(r, a) {
    if (r) {
      if ("string" == typeof r) return _arrayLikeToArray(r, a);
      var t = {}.toString.call(r).slice(8, -1);
      return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
    }
  }

  // We should save these
  //const canvas = new OffscreenCanvas(256, 256);
  //const ctx = canvas.getContext("2d");

  /** Mapbox Terrain-RGB default decode function
  *  (r * 256 * 256) / 10 + (g * 256) / 10 + b / 10 - 10000
  */
  var defaultMapboxDecodeRgb = function defaultMapboxDecodeRgb(r, g, b, a) {
    return r * 6553.6 + g * 25.6 + b * 0.1 - 10000;
  };
  function rgbTerrainToGrid(png, decodeRgb) {
    // maybe we should do this on the GPU using REGL?
    // but that would require GPU -> CPU -> GPU
    var gridSize = png.shape[0] + 1;
    var terrain = new Float32Array(gridSize * gridSize);
    var tileSize = png.shape[0];
    var decode = decodeRgb !== null && decodeRgb !== void 0 ? decodeRgb : defaultMapboxDecodeRgb;

    // decode terrain values
    for (var y = 0; y < tileSize; y++) {
      for (var x = 0; x < tileSize; x++) {
        var yc = y;
        var _r = png.get(x, yc, 0);
        var _g = png.get(x, yc, 1);
        var _b = png.get(x, yc, 2);
        var _a = png.get(x, yc, 3);
        terrain[y * gridSize + x] = decode(_r, _g, _b, _a);
      }
    }
    // backfill right and bottom borders
    for (var _x = 0; _x < gridSize - 1; _x++) {
      terrain[gridSize * (gridSize - 1) + _x] = terrain[gridSize * (gridSize - 2) + _x];
    }
    for (var _y = 0; _y < gridSize; _y++) {
      terrain[gridSize * _y + gridSize - 1] = terrain[gridSize * _y + gridSize - 2];
    }
    return terrain;
  }
  function createQuantizedMeshData(tile, mesh, tileSize) {
    var xvals = [];
    var yvals = [];
    var heightMeters = [];
    var northIndices = [];
    var southIndices = [];
    var eastIndices = [];
    var westIndices = [];
    var minimumHeight = Infinity;
    var maximumHeight = -Infinity;
    var scalar = 32768.0 / tileSize;
    for (var ix = 0; ix < mesh.vertices.length / 2; ix++) {
      var vertexIx = ix;
      var px = mesh.vertices[ix * 2];
      var py = mesh.vertices[ix * 2 + 1];
      var height = tile.terrain[py * (tileSize + 1) + px];
      if (height > maximumHeight) maximumHeight = height;
      if (height < minimumHeight) minimumHeight = height;
      heightMeters.push(height);
      if (py == 0) northIndices.push(vertexIx);
      if (py == tileSize) southIndices.push(vertexIx);
      if (px == 0) westIndices.push(vertexIx);
      if (px == tileSize) eastIndices.push(vertexIx);
      var xv = px * scalar;
      var yv = (tileSize - py) * scalar;
      xvals.push(xv);
      yvals.push(yv);
    }
    var heightRange = maximumHeight - minimumHeight;
    var heights = heightMeters.map(function (d) {
      if (heightRange < 1) return 0;
      return (d - minimumHeight) * (32767.0 / heightRange);
    });
    var triangles = new Uint16Array(mesh.triangles);
    var quantizedVertices = new Uint16Array(//verts
    [].concat(xvals, yvals, _toConsumableArray(heights)));

    // SE NW NE
    // NE NW SE

    return {
      minimumHeight: minimumHeight,
      maximumHeight: maximumHeight,
      quantizedVertices: quantizedVertices,
      indices: triangles,
      westIndices: westIndices,
      southIndices: southIndices,
      eastIndices: eastIndices,
      northIndices: northIndices
    };
  }

  function iota(n) {
    var result = new Array(n);
    for (var i = 0; i < n; ++i) {
      result[i] = i;
    }
    return result;
  }
  var iota_1 = iota;

  /*!
   * Determine if an object is a Buffer
   *
   * @author   Feross Aboukhadijeh <https://feross.org>
   * @license  MIT
   */
  // The _isBuffer check is for Safari 5-7 support, because it's missing
  // Object.prototype.constructor. Remove this eventually
  var isBuffer_1 = function (obj) {
    return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer);
  };
  function isBuffer(obj) {
    return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj);
  }

  // For Node v0.10 support. Remove this eventually.
  function isSlowBuffer(obj) {
    return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0));
  }

  var hasTypedArrays = typeof Float64Array !== "undefined";
  function compare1st(a, b) {
    return a[0] - b[0];
  }
  function order() {
    var stride = this.stride;
    var terms = new Array(stride.length);
    var i;
    for (i = 0; i < terms.length; ++i) {
      terms[i] = [Math.abs(stride[i]), i];
    }
    terms.sort(compare1st);
    var result = new Array(terms.length);
    for (i = 0; i < result.length; ++i) {
      result[i] = terms[i][1];
    }
    return result;
  }
  function compileConstructor(dtype, dimension) {
    var className = ["View", dimension, "d", dtype].join("");
    if (dimension < 0) {
      className = "View_Nil" + dtype;
    }
    var useGetters = dtype === "generic";
    if (dimension === -1) {
      //Special case for trivial arrays
      var code = "function " + className + "(a){this.data=a;};\
var proto=" + className + ".prototype;\
proto.dtype='" + dtype + "';\
proto.index=function(){return -1};\
proto.size=0;\
proto.dimension=-1;\
proto.shape=proto.stride=proto.order=[];\
proto.lo=proto.hi=proto.transpose=proto.step=\
function(){return new " + className + "(this.data);};\
proto.get=proto.set=function(){};\
proto.pick=function(){return null};\
return function construct_" + className + "(a){return new " + className + "(a);}";
      var procedure = new Function(code);
      return procedure();
    } else if (dimension === 0) {
      //Special case for 0d arrays
      var code = "function " + className + "(a,d) {\
this.data = a;\
this.offset = d\
};\
var proto=" + className + ".prototype;\
proto.dtype='" + dtype + "';\
proto.index=function(){return this.offset};\
proto.dimension=0;\
proto.size=1;\
proto.shape=\
proto.stride=\
proto.order=[];\
proto.lo=\
proto.hi=\
proto.transpose=\
proto.step=function " + className + "_copy() {\
return new " + className + "(this.data,this.offset)\
};\
proto.pick=function " + className + "_pick(){\
return TrivialArray(this.data);\
};\
proto.valueOf=proto.get=function " + className + "_get(){\
return " + (useGetters ? "this.data.get(this.offset)" : "this.data[this.offset]") + "};\
proto.set=function " + className + "_set(v){\
return " + (useGetters ? "this.data.set(this.offset,v)" : "this.data[this.offset]=v") + "\
};\
return function construct_" + className + "(a,b,c,d){return new " + className + "(a,d)}";
      var procedure = new Function("TrivialArray", code);
      return procedure(CACHED_CONSTRUCTORS[dtype][0]);
    }
    var code = ["'use strict'"];

    //Create constructor for view
    var indices = iota_1(dimension);
    var args = indices.map(function (i) {
      return "i" + i;
    });
    var index_str = "this.offset+" + indices.map(function (i) {
      return "this.stride[" + i + "]*i" + i;
    }).join("+");
    var shapeArg = indices.map(function (i) {
      return "b" + i;
    }).join(",");
    var strideArg = indices.map(function (i) {
      return "c" + i;
    }).join(",");
    code.push("function " + className + "(a," + shapeArg + "," + strideArg + ",d){this.data=a", "this.shape=[" + shapeArg + "]", "this.stride=[" + strideArg + "]", "this.offset=d|0}", "var proto=" + className + ".prototype", "proto.dtype='" + dtype + "'", "proto.dimension=" + dimension);

    //view.size:
    code.push("Object.defineProperty(proto,'size',{get:function " + className + "_size(){\
return " + indices.map(function (i) {
      return "this.shape[" + i + "]";
    }).join("*"), "}})");

    //view.order:
    if (dimension === 1) {
      code.push("proto.order=[0]");
    } else {
      code.push("Object.defineProperty(proto,'order',{get:");
      if (dimension < 4) {
        code.push("function " + className + "_order(){");
        if (dimension === 2) {
          code.push("return (Math.abs(this.stride[0])>Math.abs(this.stride[1]))?[1,0]:[0,1]}})");
        } else if (dimension === 3) {
          code.push("var s0=Math.abs(this.stride[0]),s1=Math.abs(this.stride[1]),s2=Math.abs(this.stride[2]);\
if(s0>s1){\
if(s1>s2){\
return [2,1,0];\
}else if(s0>s2){\
return [1,2,0];\
}else{\
return [1,0,2];\
}\
}else if(s0>s2){\
return [2,0,1];\
}else if(s2>s1){\
return [0,1,2];\
}else{\
return [0,2,1];\
}}})");
        }
      } else {
        code.push("ORDER})");
      }
    }

    //view.set(i0, ..., v):
    code.push("proto.set=function " + className + "_set(" + args.join(",") + ",v){");
    if (useGetters) {
      code.push("return this.data.set(" + index_str + ",v)}");
    } else {
      code.push("return this.data[" + index_str + "]=v}");
    }

    //view.get(i0, ...):
    code.push("proto.get=function " + className + "_get(" + args.join(",") + "){");
    if (useGetters) {
      code.push("return this.data.get(" + index_str + ")}");
    } else {
      code.push("return this.data[" + index_str + "]}");
    }

    //view.index:
    code.push("proto.index=function " + className + "_index(", args.join(), "){return " + index_str + "}");

    //view.hi():
    code.push("proto.hi=function " + className + "_hi(" + args.join(",") + "){return new " + className + "(this.data," + indices.map(function (i) {
      return ["(typeof i", i, "!=='number'||i", i, "<0)?this.shape[", i, "]:i", i, "|0"].join("");
    }).join(",") + "," + indices.map(function (i) {
      return "this.stride[" + i + "]";
    }).join(",") + ",this.offset)}");

    //view.lo():
    var a_vars = indices.map(function (i) {
      return "a" + i + "=this.shape[" + i + "]";
    });
    var c_vars = indices.map(function (i) {
      return "c" + i + "=this.stride[" + i + "]";
    });
    code.push("proto.lo=function " + className + "_lo(" + args.join(",") + "){var b=this.offset,d=0," + a_vars.join(",") + "," + c_vars.join(","));
    for (var i = 0; i < dimension; ++i) {
      code.push("if(typeof i" + i + "==='number'&&i" + i + ">=0){\
d=i" + i + "|0;\
b+=c" + i + "*d;\
a" + i + "-=d}");
    }
    code.push("return new " + className + "(this.data," + indices.map(function (i) {
      return "a" + i;
    }).join(",") + "," + indices.map(function (i) {
      return "c" + i;
    }).join(",") + ",b)}");

    //view.step():
    code.push("proto.step=function " + className + "_step(" + args.join(",") + "){var " + indices.map(function (i) {
      return "a" + i + "=this.shape[" + i + "]";
    }).join(",") + "," + indices.map(function (i) {
      return "b" + i + "=this.stride[" + i + "]";
    }).join(",") + ",c=this.offset,d=0,ceil=Math.ceil");
    for (var i = 0; i < dimension; ++i) {
      code.push("if(typeof i" + i + "==='number'){\
d=i" + i + "|0;\
if(d<0){\
c+=b" + i + "*(a" + i + "-1);\
a" + i + "=ceil(-a" + i + "/d)\
}else{\
a" + i + "=ceil(a" + i + "/d)\
}\
b" + i + "*=d\
}");
    }
    code.push("return new " + className + "(this.data," + indices.map(function (i) {
      return "a" + i;
    }).join(",") + "," + indices.map(function (i) {
      return "b" + i;
    }).join(",") + ",c)}");

    //view.transpose():
    var tShape = new Array(dimension);
    var tStride = new Array(dimension);
    for (var i = 0; i < dimension; ++i) {
      tShape[i] = "a[i" + i + "]";
      tStride[i] = "b[i" + i + "]";
    }
    code.push("proto.transpose=function " + className + "_transpose(" + args + "){" + args.map(function (n, idx) {
      return n + "=(" + n + "===undefined?" + idx + ":" + n + "|0)";
    }).join(";"), "var a=this.shape,b=this.stride;return new " + className + "(this.data," + tShape.join(",") + "," + tStride.join(",") + ",this.offset)}");

    //view.pick():
    code.push("proto.pick=function " + className + "_pick(" + args + "){var a=[],b=[],c=this.offset");
    for (var i = 0; i < dimension; ++i) {
      code.push("if(typeof i" + i + "==='number'&&i" + i + ">=0){c=(c+this.stride[" + i + "]*i" + i + ")|0}else{a.push(this.shape[" + i + "]);b.push(this.stride[" + i + "])}");
    }
    code.push("var ctor=CTOR_LIST[a.length+1];return ctor(this.data,a,b,c)}");

    //Add return statement
    code.push("return function construct_" + className + "(data,shape,stride,offset){return new " + className + "(data," + indices.map(function (i) {
      return "shape[" + i + "]";
    }).join(",") + "," + indices.map(function (i) {
      return "stride[" + i + "]";
    }).join(",") + ",offset)}");

    //Compile procedure
    var procedure = new Function("CTOR_LIST", "ORDER", code.join("\n"));
    return procedure(CACHED_CONSTRUCTORS[dtype], order);
  }
  function arrayDType(data) {
    if (isBuffer_1(data)) {
      return "buffer";
    }
    if (hasTypedArrays) {
      switch (Object.prototype.toString.call(data)) {
        case "[object Float64Array]":
          return "float64";
        case "[object Float32Array]":
          return "float32";
        case "[object Int8Array]":
          return "int8";
        case "[object Int16Array]":
          return "int16";
        case "[object Int32Array]":
          return "int32";
        case "[object Uint8Array]":
          return "uint8";
        case "[object Uint16Array]":
          return "uint16";
        case "[object Uint32Array]":
          return "uint32";
        case "[object Uint8ClampedArray]":
          return "uint8_clamped";
        case "[object BigInt64Array]":
          return "bigint64";
        case "[object BigUint64Array]":
          return "biguint64";
      }
    }
    if (Array.isArray(data)) {
      return "array";
    }
    return "generic";
  }
  var CACHED_CONSTRUCTORS = {
    "float32": [],
    "float64": [],
    "int8": [],
    "int16": [],
    "int32": [],
    "uint8": [],
    "uint16": [],
    "uint32": [],
    "array": [],
    "uint8_clamped": [],
    "bigint64": [],
    "biguint64": [],
    "buffer": [],
    "generic": []
  };
  function wrappedNDArrayCtor(data, shape, stride, offset) {
    if (data === undefined) {
      var ctor = CACHED_CONSTRUCTORS.array[0];
      return ctor([]);
    } else if (typeof data === "number") {
      data = [data];
    }
    if (shape === undefined) {
      shape = [data.length];
    }
    var d = shape.length;
    if (stride === undefined) {
      stride = new Array(d);
      for (var i = d - 1, sz = 1; i >= 0; --i) {
        stride[i] = sz;
        sz *= shape[i];
      }
    }
    if (offset === undefined) {
      offset = 0;
      for (var i = 0; i < d; ++i) {
        if (stride[i] < 0) {
          offset -= (shape[i] - 1) * stride[i];
        }
      }
    }
    var dtype = arrayDType(data);
    var ctor_list = CACHED_CONSTRUCTORS[dtype];
    while (ctor_list.length <= d + 1) {
      ctor_list.push(compileConstructor(dtype, ctor_list.length - 1));
    }
    var ctor = ctor_list[d + 1];
    return ctor(data, shape, stride, offset);
  }
  var ndarray = wrappedNDArrayCtor;

  class Martini {
    constructor(gridSize = 257) {
      this.gridSize = gridSize;
      const tileSize = gridSize - 1;
      if (tileSize & tileSize - 1) throw new Error(`Expected grid size to be 2^n+1, got ${gridSize}.`);
      this.numTriangles = tileSize * tileSize * 2 - 2;
      this.numParentTriangles = this.numTriangles - tileSize * tileSize;
      this.indices = new Uint32Array(this.gridSize * this.gridSize);

      // coordinates for all possible triangles in an RTIN tile
      this.coords = new Uint16Array(this.numTriangles * 4);

      // get triangle coordinates from its index in an implicit binary tree
      for (let i = 0; i < this.numTriangles; i++) {
        let id = i + 2;
        let ax = 0,
          ay = 0,
          bx = 0,
          by = 0,
          cx = 0,
          cy = 0;
        if (id & 1) {
          bx = by = cx = tileSize; // bottom-left triangle
        } else {
          ax = ay = cy = tileSize; // top-right triangle
        }
        while ((id >>= 1) > 1) {
          const mx = ax + bx >> 1;
          const my = ay + by >> 1;
          if (id & 1) {
            // left half
            bx = ax;
            by = ay;
            ax = cx;
            ay = cy;
          } else {
            // right half
            ax = bx;
            ay = by;
            bx = cx;
            by = cy;
          }
          cx = mx;
          cy = my;
        }
        const k = i * 4;
        this.coords[k + 0] = ax;
        this.coords[k + 1] = ay;
        this.coords[k + 2] = bx;
        this.coords[k + 3] = by;
      }
    }
    createTile(terrain) {
      return new Tile(terrain, this);
    }
  }
  class Tile {
    constructor(terrain, martini) {
      const size = martini.gridSize;
      if (terrain.length !== size * size) throw new Error(`Expected terrain data of length ${size * size} (${size} x ${size}), got ${terrain.length}.`);
      this.terrain = terrain;
      this.martini = martini;
      this.errors = new Float32Array(terrain.length);
      this.update();
    }
    update() {
      const {
        numTriangles,
        numParentTriangles,
        coords,
        gridSize: size
      } = this.martini;
      const {
        terrain,
        errors
      } = this;

      // iterate over all possible triangles, starting from the smallest level
      for (let i = numTriangles - 1; i >= 0; i--) {
        const k = i * 4;
        const ax = coords[k + 0];
        const ay = coords[k + 1];
        const bx = coords[k + 2];
        const by = coords[k + 3];
        const mx = ax + bx >> 1;
        const my = ay + by >> 1;
        const cx = mx + my - ay;
        const cy = my + ax - mx;

        // calculate error in the middle of the long edge of the triangle
        const interpolatedHeight = (terrain[ay * size + ax] + terrain[by * size + bx]) / 2;
        const middleIndex = my * size + mx;
        const middleError = Math.abs(interpolatedHeight - terrain[middleIndex]);
        errors[middleIndex] = Math.max(errors[middleIndex], middleError);
        if (i < numParentTriangles) {
          // bigger triangles; accumulate error with children
          const leftChildIndex = (ay + cy >> 1) * size + (ax + cx >> 1);
          const rightChildIndex = (by + cy >> 1) * size + (bx + cx >> 1);
          errors[middleIndex] = Math.max(errors[middleIndex], errors[leftChildIndex], errors[rightChildIndex]);
        }
      }
    }
    getMesh(maxError = 0, maxLength = null) {
      const {
        gridSize: size,
        indices
      } = this.martini;
      const {
        errors
      } = this;
      let numVertices = 0;
      let numTriangles = 0;
      const max = size - 1;

      // The maxLength parameter will cause triangles to be generated until the legs are below this length
      // It is meant to support cases where a certain mesh density is required to do spherical math on digital globes
      const maxScale = maxLength || size;

      // use an index grid to keep track of vertices that were already used to avoid duplication
      indices.fill(0);

      // retrieve mesh in two stages that both traverse the error map:
      // - countElements: find used vertices (and assign each an index), and count triangles (for minimum allocation)
      // - processTriangle: fill the allocated vertices & triangles typed arrays

      function countElements(ax, ay, bx, by, cx, cy) {
        const mx = ax + bx >> 1;
        const my = ay + by >> 1;
        const legLength = Math.abs(ax - cx) + Math.abs(ay - cy);
        if (legLength > 1 && errors[my * size + mx] > maxError || legLength > maxScale) {
          countElements(cx, cy, ax, ay, mx, my);
          countElements(bx, by, cx, cy, mx, my);
        } else {
          indices[ay * size + ax] = indices[ay * size + ax] || ++numVertices;
          indices[by * size + bx] = indices[by * size + bx] || ++numVertices;
          indices[cy * size + cx] = indices[cy * size + cx] || ++numVertices;
          numTriangles++;
        }
      }
      countElements(0, 0, max, max, max, 0);
      countElements(max, max, 0, 0, 0, max);
      const vertices = new Uint16Array(numVertices * 2);
      const triangles = new Uint32Array(numTriangles * 3);
      let triIndex = 0;
      function processTriangle(ax, ay, bx, by, cx, cy) {
        const mx = ax + bx >> 1;
        const my = ay + by >> 1;
        const legLength = Math.abs(ax - cx) + Math.abs(ay - cy);
        if (legLength > 1 && errors[my * size + mx] > maxError || legLength > maxScale) {
          // triangle doesn't approximate the surface well enough; drill down further
          processTriangle(cx, cy, ax, ay, mx, my);
          processTriangle(bx, by, cx, cy, mx, my);
        } else {
          // add a triangle
          const a = indices[ay * size + ax] - 1;
          const b = indices[by * size + bx] - 1;
          const c = indices[cy * size + cx] - 1;
          vertices[2 * a] = ax;
          vertices[2 * a + 1] = ay;
          vertices[2 * b] = bx;
          vertices[2 * b + 1] = by;
          vertices[2 * c] = cx;
          vertices[2 * c + 1] = cy;
          triangles[triIndex++] = a;
          triangles[triIndex++] = b;
          triangles[triIndex++] = c;
        }
      }
      processTriangle(0, 0, max, max, max, 0);
      processTriangle(max, max, 0, 0, 0, max);
      return {
        vertices,
        triangles
      };
    }
  }

  // https://github.com/CesiumGS/cesium/blob/1.76/Source/WorkersES6/createVerticesFromQuantizedTerrainMesh.js

  var martini = null;
  function decodeTerrain(parameters, transferableObjects) {
    var imageData = parameters.imageData,
      _parameters$tileSize = parameters.tileSize,
      tileSize = _parameters$tileSize === void 0 ? 256 : _parameters$tileSize,
      errorLevel = parameters.errorLevel;
    var pixels = ndarray(new Uint8Array(imageData), [tileSize, tileSize, 4], [4, 4 * tileSize, 1], 0);

    // Tile size must be maintained through the life of the worker
    martini !== null && martini !== void 0 ? martini : martini = new Martini(tileSize + 1);
    var terrain = rgbTerrainToGrid(pixels);
    var tile = martini.createTile(terrain);

    // get a mesh (vertices and triangles indices) for a 10m error
    var mesh = tile.getMesh(errorLevel, parameters.maxLength);
    return createQuantizedMeshData(tile, mesh, tileSize);
  }
  self.onmessage = function (msg) {
    var _msg$data = msg.data,
      id = _msg$data.id,
      payload = _msg$data.payload;
    if (id == null) return;
    var objects = [];
    var res = null;
    try {
      res = decodeTerrain(payload);
      objects.push(res.indices.buffer);
      objects.push(res.quantizedVertices.buffer);
      self.postMessage({
        id: id,
        payload: res
      }, objects);
    } catch (err) {
      self.postMessage({
        id: id,
        err: err.toString()
      });
    } finally {
      res = null;
      objects = null;
    }
  };

})();

', null, false);
|
|
1076
|
+
/* eslint-enable */
|
|
1077
|
+
|
|
1078
|
+
var MapboxTerrainProvider = /*#__PURE__*/function (_MartiniTerrainProvid) {
|
|
1079
|
+
function MapboxTerrainProvider() {
|
|
1080
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1081
|
+
_classCallCheck(this, MapboxTerrainProvider);
|
|
1082
|
+
var resource = new MapboxTerrainResource(opts);
|
|
1083
|
+
var decoder = new WorkerFarmTerrainDecoder({
|
|
1084
|
+
worker: new WorkerFactory()
|
|
1085
|
+
});
|
|
1086
|
+
return _callSuper(this, MapboxTerrainProvider, [_objectSpread2(_objectSpread2({}, opts), {}, {
|
|
1087
|
+
resource: resource,
|
|
1088
|
+
decoder: decoder
|
|
1089
|
+
})]);
|
|
1090
|
+
}
|
|
1091
|
+
_inherits(MapboxTerrainProvider, _MartiniTerrainProvid);
|
|
1092
|
+
return _createClass(MapboxTerrainProvider);
|
|
1093
|
+
}(MartiniTerrainProvider);
|
|
1094
|
+
|
|
1095
|
+
exports.DefaultHeightmapResource = DefaultHeightmapResource;
|
|
1096
|
+
exports.MapboxTerrainResource = MapboxTerrainResource;
|
|
1097
|
+
exports.MartiniTerrainProvider = MartiniTerrainProvider;
|
|
1098
|
+
exports["default"] = MapboxTerrainProvider;
|
|
1099
|
+
//# sourceMappingURL=index.cjs.map
|