@loaders.gl/images 3.4.13 → 3.4.15
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/dist/dist.min.js +1 -1
- package/dist/dist.min.js.map +2 -2
- package/dist/es5/bundle.js +1 -1
- package/dist/es5/bundle.js.map +1 -1
- package/dist/es5/image-loader.js +8 -11
- package/dist/es5/image-loader.js.map +1 -1
- package/dist/es5/image-writer.js +1 -1
- package/dist/es5/image-writer.js.map +1 -1
- package/dist/es5/index.js +12 -12
- package/dist/es5/lib/category-api/binary-image-api.js +24 -23
- package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
- package/dist/es5/lib/category-api/image-format.js +35 -142
- package/dist/es5/lib/category-api/image-format.js.map +1 -1
- package/dist/es5/lib/category-api/image-type.js +7 -5
- package/dist/es5/lib/category-api/image-type.js.map +1 -1
- package/dist/es5/lib/category-api/parse-isobmff-binary.js +6 -10
- package/dist/es5/lib/category-api/parse-isobmff-binary.js.map +1 -1
- package/dist/es5/lib/category-api/parsed-image-api.js +4 -6
- package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
- package/dist/es5/lib/encoders/encode-image.js +45 -78
- package/dist/es5/lib/encoders/encode-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-image.js +30 -56
- package/dist/es5/lib/parsers/parse-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js +29 -83
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-image.js +27 -76
- package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-node-image.js +8 -27
- package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
- package/dist/es5/lib/parsers/svg-utils.js +5 -5
- package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
- package/dist/es5/lib/texture-api/async-deep-map.js +32 -147
- package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
- package/dist/es5/lib/texture-api/deep-load.js +6 -52
- package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
- package/dist/es5/lib/texture-api/generate-url.js +8 -7
- package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
- package/dist/es5/lib/texture-api/load-image.js +40 -113
- package/dist/es5/lib/texture-api/load-image.js.map +1 -1
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/es5/lib/utils/version.js.map +1 -1
- package/dist/esm/image-loader.js +1 -1
- package/dist/esm/image-loader.js.map +1 -1
- package/dist/esm/lib/parsers/parse-image.js +4 -4
- package/dist/esm/lib/parsers/parse-image.js.map +1 -1
- package/dist/esm/lib/parsers/parse-to-image-bitmap.js +2 -2
- package/dist/esm/lib/parsers/parse-to-image-bitmap.js.map +1 -1
- package/dist/esm/lib/parsers/parse-to-image.js +1 -1
- package/dist/esm/lib/parsers/parse-to-image.js.map +1 -1
- package/dist/esm/lib/parsers/parse-to-node-image.js +1 -1
- package/dist/esm/lib/parsers/parse-to-node-image.js.map +1 -1
- package/dist/esm/lib/texture-api/load-image.js +1 -1
- package/dist/esm/lib/texture-api/load-image.js.map +1 -1
- package/dist/esm/lib/utils/version.js +1 -1
- package/dist/image-loader.d.ts +1 -1
- package/dist/image-loader.d.ts.map +1 -1
- package/dist/lib/parsers/parse-image.d.ts +1 -1
- package/dist/lib/parsers/parse-image.d.ts.map +1 -1
- package/dist/lib/parsers/parse-to-image-bitmap.d.ts +1 -1
- package/dist/lib/parsers/parse-to-image-bitmap.d.ts.map +1 -1
- package/dist/lib/parsers/parse-to-image.d.ts +1 -1
- package/dist/lib/parsers/parse-to-image.d.ts.map +1 -1
- package/dist/lib/parsers/parse-to-node-image.d.ts +1 -1
- package/dist/lib/parsers/parse-to-node-image.d.ts.map +1 -1
- package/package.json +3 -3
- package/src/image-loader.ts +1 -1
- package/src/lib/parsers/parse-image.ts +4 -4
- package/src/lib/parsers/parse-to-image-bitmap.ts +2 -2
- package/src/lib/parsers/parse-to-image.ts +1 -1
- package/src/lib/parsers/parse-to-node-image.ts +1 -1
- package/src/lib/texture-api/load-image.ts +1 -1
|
@@ -1,36 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
|
-
exports.
|
|
8
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
exports.parseToNodeImage = parseToNodeImage;
|
|
10
7
|
var _loaderUtils = require("@loaders.gl/loader-utils");
|
|
11
8
|
var _binaryImageApi = require("../category-api/binary-image-api");
|
|
12
|
-
function parseToNodeImage(
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
while (1) switch (_context.prev = _context.next) {
|
|
20
|
-
case 0:
|
|
21
|
-
_ref = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {}, mimeType = _ref.mimeType;
|
|
22
|
-
_parseImageNode = globalThis._parseImageNode;
|
|
23
|
-
(0, _loaderUtils.assert)(_parseImageNode);
|
|
24
|
-
_context.next = 5;
|
|
25
|
-
return _parseImageNode(arrayBuffer, mimeType);
|
|
26
|
-
case 5:
|
|
27
|
-
return _context.abrupt("return", _context.sent);
|
|
28
|
-
case 6:
|
|
29
|
-
case "end":
|
|
30
|
-
return _context.stop();
|
|
31
|
-
}
|
|
32
|
-
}, _callee);
|
|
33
|
-
}));
|
|
34
|
-
return _parseToNodeImage.apply(this, arguments);
|
|
9
|
+
async function parseToNodeImage(arrayBuffer, options) {
|
|
10
|
+
const {
|
|
11
|
+
mimeType
|
|
12
|
+
} = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {};
|
|
13
|
+
const _parseImageNode = globalThis._parseImageNode;
|
|
14
|
+
(0, _loaderUtils.assert)(_parseImageNode);
|
|
15
|
+
return await _parseImageNode(arrayBuffer, mimeType);
|
|
35
16
|
}
|
|
36
17
|
//# sourceMappingURL=parse-to-node-image.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse-to-node-image.js","names":["_loaderUtils","require","_binaryImageApi","parseToNodeImage","
|
|
1
|
+
{"version":3,"file":"parse-to-node-image.js","names":["_loaderUtils","require","_binaryImageApi","parseToNodeImage","arrayBuffer","options","mimeType","getBinaryImageMetadata","_parseImageNode","globalThis","assert"],"sources":["../../../../src/lib/parsers/parse-to-node-image.ts"],"sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport type {ImageDataType} from '../../types';\nimport {assert} from '@loaders.gl/loader-utils';\nimport {getBinaryImageMetadata} from '../category-api/binary-image-api';\n\n// Note: These types should be consistent with loaders.gl/polyfills\n\ntype NDArray = {\n shape: number[];\n data: Uint8Array;\n width: number;\n height: number;\n components: number;\n layers: number[];\n};\n\ntype ParseImageNode = (arrayBuffer: ArrayBuffer, mimeType: string) => Promise<NDArray>;\n\n// Use polyfills if installed to parsed image using get-pixels\nexport async function parseToNodeImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions\n): Promise<ImageDataType> {\n const {mimeType} = getBinaryImageMetadata(arrayBuffer) || {};\n\n // @ts-ignore\n const _parseImageNode: ParseImageNode = globalThis._parseImageNode;\n assert(_parseImageNode); // '@loaders.gl/polyfills not installed'\n\n // @ts-expect-error TODO should we throw error in this case?\n return await _parseImageNode(arrayBuffer, mimeType);\n}\n"],"mappings":";;;;;;AAEA,IAAAA,YAAA,GAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AAgBO,eAAeE,gBAAgBA,CACpCC,WAAwB,EACxBC,OAA2B,EACH;EACxB,MAAM;IAACC;EAAQ,CAAC,GAAG,IAAAC,sCAAsB,EAACH,WAAW,CAAC,IAAI,CAAC,CAAC;EAG5D,MAAMI,eAA+B,GAAGC,UAAU,CAACD,eAAe;EAClE,IAAAE,mBAAM,EAACF,eAAe,CAAC;EAGvB,OAAO,MAAMA,eAAe,CAACJ,WAAW,EAAEE,QAAQ,CAAC;AACrD"}
|
|
@@ -6,15 +6,15 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.getBlob = getBlob;
|
|
7
7
|
exports.getBlobOrSVGDataUrl = getBlobOrSVGDataUrl;
|
|
8
8
|
exports.isSVG = isSVG;
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
const SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
|
|
10
|
+
const SVG_URL_PATTERN = /\.svg((\?|#).*)?$/;
|
|
11
11
|
function isSVG(url) {
|
|
12
12
|
return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));
|
|
13
13
|
}
|
|
14
14
|
function getBlobOrSVGDataUrl(arrayBuffer, url) {
|
|
15
15
|
if (isSVG(url)) {
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
const textDecoder = new TextDecoder();
|
|
17
|
+
let xmlText = textDecoder.decode(arrayBuffer);
|
|
18
18
|
try {
|
|
19
19
|
if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {
|
|
20
20
|
xmlText = unescape(encodeURIComponent(xmlText));
|
|
@@ -22,7 +22,7 @@ function getBlobOrSVGDataUrl(arrayBuffer, url) {
|
|
|
22
22
|
} catch (error) {
|
|
23
23
|
throw new Error(error.message);
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
const src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
|
|
26
26
|
return src;
|
|
27
27
|
}
|
|
28
28
|
return getBlob(arrayBuffer, url);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"svg-utils.js","names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","concat","btoa","getBlob","Blob","Uint8Array"],"sources":["../../../../src/lib/parsers/svg-utils.ts"],"sourcesContent":["// SVG parsing has limitations, e.g:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n\nconst SVG_DATA_URL_PATTERN = /^data:image\\/svg\\+xml/;\nconst SVG_URL_PATTERN = /\\.svg((\\?|#).*)?$/;\n\nexport function isSVG(url) {\n return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));\n}\n\nexport function getBlobOrSVGDataUrl(arrayBuffer: ArrayBuffer, url?: string): Blob | string {\n if (isSVG(url)) {\n // Prepare a properly tagged data URL, and load using normal mechanism\n const textDecoder = new TextDecoder();\n let xmlText = textDecoder.decode(arrayBuffer);\n // TODO Escape in browser to support e.g. Chinese characters\n try {\n if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {\n xmlText = unescape(encodeURIComponent(xmlText));\n }\n } catch (error) {\n throw new Error((error as Error).message);\n }\n // base64 encoding is safer. utf-8 fails in some browsers\n const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;\n return src;\n }\n return getBlob(arrayBuffer, url);\n}\n\nexport function getBlob(arrayBuffer: ArrayBuffer, url?: string): Blob {\n if (isSVG(url)) {\n // https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n // return new Blob([new Uint8Array(arrayBuffer)], {type: 'image/svg+xml'});\n throw new Error('SVG cannot be parsed directly to imagebitmap');\n }\n // TODO - how to determine mime type? Param? Sniff here?\n return new Blob([new Uint8Array(arrayBuffer)]); // MIME type not needed?\n}\n"],"mappings":";;;;;;;;AAGA,
|
|
1
|
+
{"version":3,"file":"svg-utils.js","names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","concat","btoa","getBlob","Blob","Uint8Array"],"sources":["../../../../src/lib/parsers/svg-utils.ts"],"sourcesContent":["// SVG parsing has limitations, e.g:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n\nconst SVG_DATA_URL_PATTERN = /^data:image\\/svg\\+xml/;\nconst SVG_URL_PATTERN = /\\.svg((\\?|#).*)?$/;\n\nexport function isSVG(url) {\n return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));\n}\n\nexport function getBlobOrSVGDataUrl(arrayBuffer: ArrayBuffer, url?: string): Blob | string {\n if (isSVG(url)) {\n // Prepare a properly tagged data URL, and load using normal mechanism\n const textDecoder = new TextDecoder();\n let xmlText = textDecoder.decode(arrayBuffer);\n // TODO Escape in browser to support e.g. Chinese characters\n try {\n if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {\n xmlText = unescape(encodeURIComponent(xmlText));\n }\n } catch (error) {\n throw new Error((error as Error).message);\n }\n // base64 encoding is safer. utf-8 fails in some browsers\n const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;\n return src;\n }\n return getBlob(arrayBuffer, url);\n}\n\nexport function getBlob(arrayBuffer: ArrayBuffer, url?: string): Blob {\n if (isSVG(url)) {\n // https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n // return new Blob([new Uint8Array(arrayBuffer)], {type: 'image/svg+xml'});\n throw new Error('SVG cannot be parsed directly to imagebitmap');\n }\n // TODO - how to determine mime type? Param? Sniff here?\n return new Blob([new Uint8Array(arrayBuffer)]); // MIME type not needed?\n}\n"],"mappings":";;;;;;;;AAGA,MAAMA,oBAAoB,GAAG,uBAAuB;AACpD,MAAMC,eAAe,GAAG,mBAAmB;AAEpC,SAASC,KAAKA,CAACC,GAAG,EAAE;EACzB,OAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAAI,CAACD,GAAG,CAAC,IAAIF,eAAe,CAACG,IAAI,CAACD,GAAG,CAAC,CAAC;AAC7E;AAEO,SAASE,mBAAmBA,CAACC,WAAwB,EAAEH,GAAY,EAAiB;EACzF,IAAID,KAAK,CAACC,GAAG,CAAC,EAAE;IAEd,MAAMI,WAAW,GAAG,IAAIC,WAAW,CAAC,CAAC;IACrC,IAAIC,OAAO,GAAGF,WAAW,CAACG,MAAM,CAACJ,WAAW,CAAC;IAE7C,IAAI;MACF,IAAI,OAAOK,QAAQ,KAAK,UAAU,IAAI,OAAOC,kBAAkB,KAAK,UAAU,EAAE;QAC9EH,OAAO,GAAGE,QAAQ,CAACC,kBAAkB,CAACH,OAAO,CAAC,CAAC;MACjD;IACF,CAAC,CAAC,OAAOI,KAAK,EAAE;MACd,MAAM,IAAIC,KAAK,CAAED,KAAK,CAAWE,OAAO,CAAC;IAC3C;IAEA,MAAMC,GAAG,gCAAAC,MAAA,CAAgCC,IAAI,CAACT,OAAO,CAAC,CAAE;IACxD,OAAOO,GAAG;EACZ;EACA,OAAOG,OAAO,CAACb,WAAW,EAAEH,GAAG,CAAC;AAClC;AAEO,SAASgB,OAAOA,CAACb,WAAwB,EAAEH,GAAY,EAAQ;EACpE,IAAID,KAAK,CAACC,GAAG,CAAC,EAAE;IAGd,MAAM,IAAIW,KAAK,CAAC,8CAA8C,CAAC;EACjE;EAEA,OAAO,IAAIM,IAAI,CAAC,CAAC,IAAIC,UAAU,CAACf,WAAW,CAAC,CAAC,CAAC;AAChD"}
|
|
@@ -1,156 +1,41 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.asyncDeepMap = asyncDeepMap;
|
|
8
7
|
exports.mapSubtree = mapSubtree;
|
|
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
|
-
function _mapSubtree() {
|
|
42
|
-
_mapSubtree = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(object, func, options) {
|
|
43
|
-
var url;
|
|
44
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
45
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
46
|
-
case 0:
|
|
47
|
-
if (!Array.isArray(object)) {
|
|
48
|
-
_context2.next = 4;
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
_context2.next = 3;
|
|
52
|
-
return mapArray(object, func, options);
|
|
53
|
-
case 3:
|
|
54
|
-
return _context2.abrupt("return", _context2.sent);
|
|
55
|
-
case 4:
|
|
56
|
-
if (!isObject(object)) {
|
|
57
|
-
_context2.next = 8;
|
|
58
|
-
break;
|
|
59
|
-
}
|
|
60
|
-
_context2.next = 7;
|
|
61
|
-
return mapObject(object, func, options);
|
|
62
|
-
case 7:
|
|
63
|
-
return _context2.abrupt("return", _context2.sent);
|
|
64
|
-
case 8:
|
|
65
|
-
url = object;
|
|
66
|
-
_context2.next = 11;
|
|
67
|
-
return func(url, options);
|
|
68
|
-
case 11:
|
|
69
|
-
return _context2.abrupt("return", _context2.sent);
|
|
70
|
-
case 12:
|
|
71
|
-
case "end":
|
|
72
|
-
return _context2.stop();
|
|
73
|
-
}
|
|
74
|
-
}, _callee2);
|
|
75
|
-
}));
|
|
76
|
-
return _mapSubtree.apply(this, arguments);
|
|
77
|
-
}
|
|
78
|
-
function mapObject(_x6, _x7, _x8) {
|
|
79
|
-
return _mapObject.apply(this, arguments);
|
|
80
|
-
}
|
|
81
|
-
function _mapObject() {
|
|
82
|
-
_mapObject = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee3(object, func, options) {
|
|
83
|
-
var promises, values, _loop, key;
|
|
84
|
-
return _regenerator.default.wrap(function _callee3$(_context4) {
|
|
85
|
-
while (1) switch (_context4.prev = _context4.next) {
|
|
86
|
-
case 0:
|
|
87
|
-
promises = [];
|
|
88
|
-
values = {};
|
|
89
|
-
_loop = _regenerator.default.mark(function _loop(key) {
|
|
90
|
-
var url, promise;
|
|
91
|
-
return _regenerator.default.wrap(function _loop$(_context3) {
|
|
92
|
-
while (1) switch (_context3.prev = _context3.next) {
|
|
93
|
-
case 0:
|
|
94
|
-
url = object[key];
|
|
95
|
-
promise = mapSubtree(url, func, options).then(function (value) {
|
|
96
|
-
values[key] = value;
|
|
97
|
-
});
|
|
98
|
-
promises.push(promise);
|
|
99
|
-
case 3:
|
|
100
|
-
case "end":
|
|
101
|
-
return _context3.stop();
|
|
102
|
-
}
|
|
103
|
-
}, _loop);
|
|
104
|
-
});
|
|
105
|
-
_context4.t0 = _regenerator.default.keys(object);
|
|
106
|
-
case 4:
|
|
107
|
-
if ((_context4.t1 = _context4.t0()).done) {
|
|
108
|
-
_context4.next = 9;
|
|
109
|
-
break;
|
|
110
|
-
}
|
|
111
|
-
key = _context4.t1.value;
|
|
112
|
-
return _context4.delegateYield(_loop(key), "t2", 7);
|
|
113
|
-
case 7:
|
|
114
|
-
_context4.next = 4;
|
|
115
|
-
break;
|
|
116
|
-
case 9:
|
|
117
|
-
_context4.next = 11;
|
|
118
|
-
return Promise.all(promises);
|
|
119
|
-
case 11:
|
|
120
|
-
return _context4.abrupt("return", values);
|
|
121
|
-
case 12:
|
|
122
|
-
case "end":
|
|
123
|
-
return _context4.stop();
|
|
124
|
-
}
|
|
125
|
-
}, _callee3);
|
|
126
|
-
}));
|
|
127
|
-
return _mapObject.apply(this, arguments);
|
|
128
|
-
}
|
|
129
|
-
function mapArray(_x9, _x10) {
|
|
130
|
-
return _mapArray.apply(this, arguments);
|
|
131
|
-
}
|
|
132
|
-
function _mapArray() {
|
|
133
|
-
_mapArray = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee4(urlArray, func) {
|
|
134
|
-
var options,
|
|
135
|
-
promises,
|
|
136
|
-
_args5 = arguments;
|
|
137
|
-
return _regenerator.default.wrap(function _callee4$(_context5) {
|
|
138
|
-
while (1) switch (_context5.prev = _context5.next) {
|
|
139
|
-
case 0:
|
|
140
|
-
options = _args5.length > 2 && _args5[2] !== undefined ? _args5[2] : {};
|
|
141
|
-
promises = urlArray.map(function (url) {
|
|
142
|
-
return mapSubtree(url, func, options);
|
|
143
|
-
});
|
|
144
|
-
_context5.next = 4;
|
|
145
|
-
return Promise.all(promises);
|
|
146
|
-
case 4:
|
|
147
|
-
return _context5.abrupt("return", _context5.sent);
|
|
148
|
-
case 5:
|
|
149
|
-
case "end":
|
|
150
|
-
return _context5.stop();
|
|
151
|
-
}
|
|
152
|
-
}, _callee4);
|
|
153
|
-
}));
|
|
154
|
-
return _mapArray.apply(this, arguments);
|
|
8
|
+
const isObject = value => value && typeof value === 'object';
|
|
9
|
+
async function asyncDeepMap(tree, func) {
|
|
10
|
+
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
11
|
+
return await mapSubtree(tree, func, options);
|
|
12
|
+
}
|
|
13
|
+
async function mapSubtree(object, func, options) {
|
|
14
|
+
if (Array.isArray(object)) {
|
|
15
|
+
return await mapArray(object, func, options);
|
|
16
|
+
}
|
|
17
|
+
if (isObject(object)) {
|
|
18
|
+
return await mapObject(object, func, options);
|
|
19
|
+
}
|
|
20
|
+
const url = object;
|
|
21
|
+
return await func(url, options);
|
|
22
|
+
}
|
|
23
|
+
async function mapObject(object, func, options) {
|
|
24
|
+
const promises = [];
|
|
25
|
+
const values = {};
|
|
26
|
+
for (const key in object) {
|
|
27
|
+
const url = object[key];
|
|
28
|
+
const promise = mapSubtree(url, func, options).then(value => {
|
|
29
|
+
values[key] = value;
|
|
30
|
+
});
|
|
31
|
+
promises.push(promise);
|
|
32
|
+
}
|
|
33
|
+
await Promise.all(promises);
|
|
34
|
+
return values;
|
|
35
|
+
}
|
|
36
|
+
async function mapArray(urlArray, func) {
|
|
37
|
+
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
38
|
+
const promises = urlArray.map(url => mapSubtree(url, func, options));
|
|
39
|
+
return await Promise.all(promises);
|
|
155
40
|
}
|
|
156
41
|
//# sourceMappingURL=async-deep-map.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"async-deep-map.js","names":["isObject","value","
|
|
1
|
+
{"version":3,"file":"async-deep-map.js","names":["isObject","value","asyncDeepMap","tree","func","options","arguments","length","undefined","mapSubtree","object","Array","isArray","mapArray","mapObject","url","promises","values","key","promise","then","push","Promise","all","urlArray","map"],"sources":["../../../../src/lib/texture-api/async-deep-map.ts"],"sourcesContent":["/*\nAsynchronously maps a deep structure of values (e.g. objects and arrays of urls).\n\nE.g. a mipmapped cubemap\n{\n [CUBE_FACE_FRONT]: [\n \"image-front-0.jpg\",\n \"image-front-1.jpg\",\n \"image-front-2.jpg\",\n ],\n [CUBE_MAP_BACK]: [\n ...\n ]\n}\n*/\n\nconst isObject = (value) => value && typeof value === 'object';\n\n// Loads a deep structure of urls (objects and arrays of urls)\n// Returns an object with six key-value pairs containing the images (or image mip arrays)\n// for each cube face\nexport async function asyncDeepMap(tree, func, options = {}) {\n return await mapSubtree(tree, func, options);\n}\n\nexport async function mapSubtree(object, func, options) {\n if (Array.isArray(object)) {\n return await mapArray(object, func, options);\n }\n\n if (isObject(object)) {\n return await mapObject(object, func, options);\n }\n\n // TODO - ignore non-urls, non-arraybuffers?\n const url = object;\n return await func(url, options);\n}\n\n// HELPERS\n\nasync function mapObject(object, func, options) {\n const promises: Promise<any>[] = [];\n const values = {};\n\n for (const key in object) {\n const url = object[key];\n const promise = mapSubtree(url, func, options).then((value) => {\n values[key] = value;\n });\n promises.push(promise);\n }\n\n await Promise.all(promises);\n\n return values;\n}\n\nasync function mapArray(urlArray, func, options = {}) {\n const promises = urlArray.map((url) => mapSubtree(url, func, options));\n return await Promise.all(promises);\n}\n"],"mappings":";;;;;;;AAgBA,MAAMA,QAAQ,GAAIC,KAAK,IAAKA,KAAK,IAAI,OAAOA,KAAK,KAAK,QAAQ;AAKvD,eAAeC,YAAYA,CAACC,IAAI,EAAEC,IAAI,EAAgB;EAAA,IAAdC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EACzD,OAAO,MAAMG,UAAU,CAACN,IAAI,EAAEC,IAAI,EAAEC,OAAO,CAAC;AAC9C;AAEO,eAAeI,UAAUA,CAACC,MAAM,EAAEN,IAAI,EAAEC,OAAO,EAAE;EACtD,IAAIM,KAAK,CAACC,OAAO,CAACF,MAAM,CAAC,EAAE;IACzB,OAAO,MAAMG,QAAQ,CAACH,MAAM,EAAEN,IAAI,EAAEC,OAAO,CAAC;EAC9C;EAEA,IAAIL,QAAQ,CAACU,MAAM,CAAC,EAAE;IACpB,OAAO,MAAMI,SAAS,CAACJ,MAAM,EAAEN,IAAI,EAAEC,OAAO,CAAC;EAC/C;EAGA,MAAMU,GAAG,GAAGL,MAAM;EAClB,OAAO,MAAMN,IAAI,CAACW,GAAG,EAAEV,OAAO,CAAC;AACjC;AAIA,eAAeS,SAASA,CAACJ,MAAM,EAAEN,IAAI,EAAEC,OAAO,EAAE;EAC9C,MAAMW,QAAwB,GAAG,EAAE;EACnC,MAAMC,MAAM,GAAG,CAAC,CAAC;EAEjB,KAAK,MAAMC,GAAG,IAAIR,MAAM,EAAE;IACxB,MAAMK,GAAG,GAAGL,MAAM,CAACQ,GAAG,CAAC;IACvB,MAAMC,OAAO,GAAGV,UAAU,CAACM,GAAG,EAAEX,IAAI,EAAEC,OAAO,CAAC,CAACe,IAAI,CAAEnB,KAAK,IAAK;MAC7DgB,MAAM,CAACC,GAAG,CAAC,GAAGjB,KAAK;IACrB,CAAC,CAAC;IACFe,QAAQ,CAACK,IAAI,CAACF,OAAO,CAAC;EACxB;EAEA,MAAMG,OAAO,CAACC,GAAG,CAACP,QAAQ,CAAC;EAE3B,OAAOC,MAAM;AACf;AAEA,eAAeJ,QAAQA,CAACW,QAAQ,EAAEpB,IAAI,EAAgB;EAAA,IAAdC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAClD,MAAMU,QAAQ,GAAGQ,QAAQ,CAACC,GAAG,CAAEV,GAAG,IAAKN,UAAU,CAACM,GAAG,EAAEX,IAAI,EAAEC,OAAO,CAAC,CAAC;EACtE,OAAO,MAAMiB,OAAO,CAACC,GAAG,CAACP,QAAQ,CAAC;AACpC"}
|
|
@@ -1,63 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.deepLoad = deepLoad;
|
|
8
7
|
exports.shallowLoad = shallowLoad;
|
|
9
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
11
8
|
var _asyncDeepMap = require("./async-deep-map");
|
|
12
|
-
function deepLoad(
|
|
13
|
-
return
|
|
9
|
+
async function deepLoad(urlTree, load, options) {
|
|
10
|
+
return await (0, _asyncDeepMap.asyncDeepMap)(urlTree, url => shallowLoad(url, load, options));
|
|
14
11
|
}
|
|
15
|
-
function
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
case 0:
|
|
20
|
-
_context.next = 2;
|
|
21
|
-
return (0, _asyncDeepMap.asyncDeepMap)(urlTree, function (url) {
|
|
22
|
-
return shallowLoad(url, load, options);
|
|
23
|
-
});
|
|
24
|
-
case 2:
|
|
25
|
-
return _context.abrupt("return", _context.sent);
|
|
26
|
-
case 3:
|
|
27
|
-
case "end":
|
|
28
|
-
return _context.stop();
|
|
29
|
-
}
|
|
30
|
-
}, _callee);
|
|
31
|
-
}));
|
|
32
|
-
return _deepLoad.apply(this, arguments);
|
|
33
|
-
}
|
|
34
|
-
function shallowLoad(_x4, _x5, _x6) {
|
|
35
|
-
return _shallowLoad.apply(this, arguments);
|
|
36
|
-
}
|
|
37
|
-
function _shallowLoad() {
|
|
38
|
-
_shallowLoad = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(url, load, options) {
|
|
39
|
-
var response, arrayBuffer;
|
|
40
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
41
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
42
|
-
case 0:
|
|
43
|
-
_context2.next = 2;
|
|
44
|
-
return fetch(url, options.fetch);
|
|
45
|
-
case 2:
|
|
46
|
-
response = _context2.sent;
|
|
47
|
-
_context2.next = 5;
|
|
48
|
-
return response.arrayBuffer();
|
|
49
|
-
case 5:
|
|
50
|
-
arrayBuffer = _context2.sent;
|
|
51
|
-
_context2.next = 8;
|
|
52
|
-
return load(arrayBuffer, options);
|
|
53
|
-
case 8:
|
|
54
|
-
return _context2.abrupt("return", _context2.sent);
|
|
55
|
-
case 9:
|
|
56
|
-
case "end":
|
|
57
|
-
return _context2.stop();
|
|
58
|
-
}
|
|
59
|
-
}, _callee2);
|
|
60
|
-
}));
|
|
61
|
-
return _shallowLoad.apply(this, arguments);
|
|
12
|
+
async function shallowLoad(url, load, options) {
|
|
13
|
+
const response = await fetch(url, options.fetch);
|
|
14
|
+
const arrayBuffer = await response.arrayBuffer();
|
|
15
|
+
return await load(arrayBuffer, options);
|
|
62
16
|
}
|
|
63
17
|
//# sourceMappingURL=deep-load.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deep-load.js","names":["_asyncDeepMap","require","deepLoad","
|
|
1
|
+
{"version":3,"file":"deep-load.js","names":["_asyncDeepMap","require","deepLoad","urlTree","load","options","asyncDeepMap","url","shallowLoad","response","fetch","arrayBuffer"],"sources":["../../../../src/lib/texture-api/deep-load.ts"],"sourcesContent":["import {asyncDeepMap} from './async-deep-map';\n\nexport async function deepLoad(urlTree, load, options) {\n return await asyncDeepMap(urlTree, (url) => shallowLoad(url, load, options));\n}\n\nexport async function shallowLoad(url, load, options) {\n // console.error('loading', url);\n const response = await fetch(url, options.fetch);\n const arrayBuffer = await response.arrayBuffer();\n return await load(arrayBuffer, options);\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,aAAA,GAAAC,OAAA;AAEO,eAAeC,QAAQA,CAACC,OAAO,EAAEC,IAAI,EAAEC,OAAO,EAAE;EACrD,OAAO,MAAM,IAAAC,0BAAY,EAACH,OAAO,EAAGI,GAAG,IAAKC,WAAW,CAACD,GAAG,EAAEH,IAAI,EAAEC,OAAO,CAAC,CAAC;AAC9E;AAEO,eAAeG,WAAWA,CAACD,GAAG,EAAEH,IAAI,EAAEC,OAAO,EAAE;EAEpD,MAAMI,QAAQ,GAAG,MAAMC,KAAK,CAACH,GAAG,EAAEF,OAAO,CAACK,KAAK,CAAC;EAChD,MAAMC,WAAW,GAAG,MAAMF,QAAQ,CAACE,WAAW,CAAC,CAAC;EAChD,OAAO,MAAMP,IAAI,CAACO,WAAW,EAAEN,OAAO,CAAC;AACzC"}
|
|
@@ -1,21 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.generateUrl = generateUrl;
|
|
8
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
7
|
var _loaderUtils = require("@loaders.gl/loader-utils");
|
|
10
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
11
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
12
8
|
function generateUrl(getUrl, options, urlOptions) {
|
|
13
|
-
|
|
9
|
+
let url = getUrl;
|
|
14
10
|
if (typeof getUrl === 'function') {
|
|
15
|
-
url = getUrl(
|
|
11
|
+
url = getUrl({
|
|
12
|
+
...options,
|
|
13
|
+
...urlOptions
|
|
14
|
+
});
|
|
16
15
|
}
|
|
17
16
|
(0, _loaderUtils.assert)(typeof url === 'string');
|
|
18
|
-
|
|
17
|
+
const {
|
|
18
|
+
baseUrl
|
|
19
|
+
} = options;
|
|
19
20
|
if (baseUrl) {
|
|
20
21
|
url = baseUrl[baseUrl.length - 1] === '/' ? "".concat(baseUrl).concat(url) : "".concat(baseUrl, "/").concat(url);
|
|
21
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generate-url.js","names":["_loaderUtils","require","
|
|
1
|
+
{"version":3,"file":"generate-url.js","names":["_loaderUtils","require","generateUrl","getUrl","options","urlOptions","url","assert","baseUrl","length","concat","resolvePath"],"sources":["../../../../src/lib/texture-api/generate-url.ts"],"sourcesContent":["import {resolvePath, assert} from '@loaders.gl/loader-utils';\n\n// Generate a url by calling getUrl with mix of options, applying options.baseUrl\nexport function generateUrl(getUrl, options, urlOptions) {\n // Get url\n let url = getUrl;\n if (typeof getUrl === 'function') {\n url = getUrl({...options, ...urlOptions});\n }\n assert(typeof url === 'string');\n\n // Apply options.baseUrl\n const {baseUrl} = options;\n if (baseUrl) {\n url = baseUrl[baseUrl.length - 1] === '/' ? `${baseUrl}${url}` : `${baseUrl}/${url}`;\n }\n\n return resolvePath(url);\n}\n"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAGO,SAASC,WAAWA,CAACC,MAAM,EAAEC,OAAO,EAAEC,UAAU,EAAE;EAEvD,IAAIC,GAAG,GAAGH,MAAM;EAChB,IAAI,OAAOA,MAAM,KAAK,UAAU,EAAE;IAChCG,GAAG,GAAGH,MAAM,CAAC;MAAC,GAAGC,OAAO;MAAE,GAAGC;IAAU,CAAC,CAAC;EAC3C;EACA,IAAAE,mBAAM,EAAC,OAAOD,GAAG,KAAK,QAAQ,CAAC;EAG/B,MAAM;IAACE;EAAO,CAAC,GAAGJ,OAAO;EACzB,IAAII,OAAO,EAAE;IACXF,GAAG,GAAGE,OAAO,CAACA,OAAO,CAACC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,MAAAC,MAAA,CAAMF,OAAO,EAAAE,MAAA,CAAGJ,GAAG,OAAAI,MAAA,CAAQF,OAAO,OAAAE,MAAA,CAAIJ,GAAG,CAAE;EACtF;EAEA,OAAO,IAAAK,wBAAW,EAACL,GAAG,CAAC;AACzB"}
|
|
@@ -1,132 +1,59 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.getImageUrls = getImageUrls;
|
|
8
7
|
exports.getMipLevels = getMipLevels;
|
|
9
8
|
exports.loadImage = loadImage;
|
|
10
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
11
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
12
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
13
9
|
var _loaderUtils = require("@loaders.gl/loader-utils");
|
|
14
|
-
var _parseImage =
|
|
10
|
+
var _parseImage = require("../parsers/parse-image");
|
|
15
11
|
var _parsedImageApi = require("../category-api/parsed-image-api");
|
|
16
12
|
var _generateUrl = require("./generate-url");
|
|
17
13
|
var _deepLoad = require("./deep-load");
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
return
|
|
14
|
+
async function loadImage(getUrl) {
|
|
15
|
+
let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
16
|
+
const imageUrls = await getImageUrls(getUrl, options);
|
|
17
|
+
return await (0, _deepLoad.deepLoad)(imageUrls, _parseImage.parseImage, options);
|
|
22
18
|
}
|
|
23
|
-
function
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
_args = arguments;
|
|
28
|
-
return _regenerator.default.wrap(function _callee$(_context) {
|
|
29
|
-
while (1) switch (_context.prev = _context.next) {
|
|
30
|
-
case 0:
|
|
31
|
-
options = _args.length > 1 && _args[1] !== undefined ? _args[1] : {};
|
|
32
|
-
_context.next = 3;
|
|
33
|
-
return getImageUrls(getUrl, options);
|
|
34
|
-
case 3:
|
|
35
|
-
imageUrls = _context.sent;
|
|
36
|
-
_context.next = 6;
|
|
37
|
-
return (0, _deepLoad.deepLoad)(imageUrls, _parseImage.default, options);
|
|
38
|
-
case 6:
|
|
39
|
-
return _context.abrupt("return", _context.sent);
|
|
40
|
-
case 7:
|
|
41
|
-
case "end":
|
|
42
|
-
return _context.stop();
|
|
43
|
-
}
|
|
44
|
-
}, _callee);
|
|
45
|
-
}));
|
|
46
|
-
return _loadImage.apply(this, arguments);
|
|
19
|
+
async function getImageUrls(getUrl, options) {
|
|
20
|
+
let urlOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
21
|
+
const mipLevels = options && options.image && options.image.mipLevels || 0;
|
|
22
|
+
return mipLevels !== 0 ? await getMipmappedImageUrls(getUrl, mipLevels, options, urlOptions) : (0, _generateUrl.generateUrl)(getUrl, options, urlOptions);
|
|
47
23
|
}
|
|
48
|
-
function
|
|
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
|
-
case 10:
|
|
76
|
-
case "end":
|
|
77
|
-
return _context2.stop();
|
|
78
|
-
}
|
|
79
|
-
}, _callee2);
|
|
80
|
-
}));
|
|
81
|
-
return _getImageUrls.apply(this, arguments);
|
|
82
|
-
}
|
|
83
|
-
function getMipmappedImageUrls(_x4, _x5, _x6, _x7) {
|
|
84
|
-
return _getMipmappedImageUrls.apply(this, arguments);
|
|
85
|
-
}
|
|
86
|
-
function _getMipmappedImageUrls() {
|
|
87
|
-
_getMipmappedImageUrls = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee3(getUrl, mipLevels, options, urlOptions) {
|
|
88
|
-
var urls, url, image, _getImageSize, width, height, mipLevel, _url;
|
|
89
|
-
return _regenerator.default.wrap(function _callee3$(_context3) {
|
|
90
|
-
while (1) switch (_context3.prev = _context3.next) {
|
|
91
|
-
case 0:
|
|
92
|
-
urls = [];
|
|
93
|
-
if (!(mipLevels === 'auto')) {
|
|
94
|
-
_context3.next = 9;
|
|
95
|
-
break;
|
|
96
|
-
}
|
|
97
|
-
url = (0, _generateUrl.generateUrl)(getUrl, options, _objectSpread(_objectSpread({}, urlOptions), {}, {
|
|
98
|
-
lod: 0
|
|
99
|
-
}));
|
|
100
|
-
_context3.next = 5;
|
|
101
|
-
return (0, _deepLoad.shallowLoad)(url, _parseImage.default, options);
|
|
102
|
-
case 5:
|
|
103
|
-
image = _context3.sent;
|
|
104
|
-
_getImageSize = (0, _parsedImageApi.getImageSize)(image), width = _getImageSize.width, height = _getImageSize.height;
|
|
105
|
-
mipLevels = getMipLevels({
|
|
106
|
-
width: width,
|
|
107
|
-
height: height
|
|
108
|
-
});
|
|
109
|
-
urls.push(url);
|
|
110
|
-
case 9:
|
|
111
|
-
(0, _loaderUtils.assert)(mipLevels > 0);
|
|
112
|
-
for (mipLevel = urls.length; mipLevel < mipLevels; ++mipLevel) {
|
|
113
|
-
_url = (0, _generateUrl.generateUrl)(getUrl, options, _objectSpread(_objectSpread({}, urlOptions), {}, {
|
|
114
|
-
lod: mipLevel
|
|
115
|
-
}));
|
|
116
|
-
urls.push(_url);
|
|
117
|
-
}
|
|
118
|
-
return _context3.abrupt("return", urls);
|
|
119
|
-
case 12:
|
|
120
|
-
case "end":
|
|
121
|
-
return _context3.stop();
|
|
122
|
-
}
|
|
123
|
-
}, _callee3);
|
|
124
|
-
}));
|
|
125
|
-
return _getMipmappedImageUrls.apply(this, arguments);
|
|
24
|
+
async function getMipmappedImageUrls(getUrl, mipLevels, options, urlOptions) {
|
|
25
|
+
const urls = [];
|
|
26
|
+
if (mipLevels === 'auto') {
|
|
27
|
+
const url = (0, _generateUrl.generateUrl)(getUrl, options, {
|
|
28
|
+
...urlOptions,
|
|
29
|
+
lod: 0
|
|
30
|
+
});
|
|
31
|
+
const image = await (0, _deepLoad.shallowLoad)(url, _parseImage.parseImage, options);
|
|
32
|
+
const {
|
|
33
|
+
width,
|
|
34
|
+
height
|
|
35
|
+
} = (0, _parsedImageApi.getImageSize)(image);
|
|
36
|
+
mipLevels = getMipLevels({
|
|
37
|
+
width,
|
|
38
|
+
height
|
|
39
|
+
});
|
|
40
|
+
urls.push(url);
|
|
41
|
+
}
|
|
42
|
+
(0, _loaderUtils.assert)(mipLevels > 0);
|
|
43
|
+
for (let mipLevel = urls.length; mipLevel < mipLevels; ++mipLevel) {
|
|
44
|
+
const url = (0, _generateUrl.generateUrl)(getUrl, options, {
|
|
45
|
+
...urlOptions,
|
|
46
|
+
lod: mipLevel
|
|
47
|
+
});
|
|
48
|
+
urls.push(url);
|
|
49
|
+
}
|
|
50
|
+
return urls;
|
|
126
51
|
}
|
|
127
52
|
function getMipLevels(_ref) {
|
|
128
|
-
|
|
129
|
-
|
|
53
|
+
let {
|
|
54
|
+
width,
|
|
55
|
+
height
|
|
56
|
+
} = _ref;
|
|
130
57
|
return 1 + Math.floor(Math.log2(Math.max(width, height)));
|
|
131
58
|
}
|
|
132
59
|
//# sourceMappingURL=load-image.js.map
|