@loaders.gl/images 3.1.0-alpha.3 → 3.1.0-beta.2

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.
Files changed (162) hide show
  1. package/dist/bundle.d.ts +2 -0
  2. package/dist/bundle.d.ts.map +1 -0
  3. package/dist/bundle.js +2 -2
  4. package/dist/dist.min.js +2 -2
  5. package/dist/dist.min.js.map +7 -1
  6. package/dist/es5/bundle.js +7 -0
  7. package/dist/es5/bundle.js.map +1 -0
  8. package/dist/es5/image-loader.js +38 -0
  9. package/dist/es5/image-loader.js.map +1 -0
  10. package/dist/es5/image-writer.js +27 -0
  11. package/dist/es5/image-writer.js.map +1 -0
  12. package/dist/es5/index.js +86 -0
  13. package/dist/es5/index.js.map +1 -0
  14. package/dist/es5/lib/category-api/binary-image-api.js +126 -0
  15. package/dist/es5/lib/category-api/binary-image-api.js.map +1 -0
  16. package/dist/es5/lib/category-api/image-format.js +53 -0
  17. package/dist/es5/lib/category-api/image-format.js.map +1 -0
  18. package/dist/es5/lib/category-api/image-type.js +53 -0
  19. package/dist/es5/lib/category-api/image-type.js.map +1 -0
  20. package/dist/es5/lib/category-api/parsed-image-api.js +79 -0
  21. package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -0
  22. package/dist/es5/lib/encoders/encode-image.js +79 -0
  23. package/dist/es5/lib/encoders/encode-image.js.map +1 -0
  24. package/dist/es5/lib/parsers/parse-image.js +67 -0
  25. package/dist/es5/lib/parsers/parse-image.js.map +1 -0
  26. package/dist/es5/lib/parsers/parse-to-image-bitmap.js +55 -0
  27. package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -0
  28. package/dist/es5/lib/parsers/parse-to-image.js +44 -0
  29. package/dist/es5/lib/parsers/parse-to-image.js.map +1 -0
  30. package/dist/es5/lib/parsers/parse-to-node-image.js +20 -0
  31. package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -0
  32. package/dist/es5/lib/parsers/svg-utils.js +43 -0
  33. package/dist/es5/lib/parsers/svg-utils.js.map +1 -0
  34. package/dist/es5/lib/texture-api/async-deep-map.js +48 -0
  35. package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -0
  36. package/dist/es5/lib/texture-api/deep-load.js +20 -0
  37. package/dist/es5/lib/texture-api/deep-load.js.map +1 -0
  38. package/dist/es5/lib/texture-api/generate-url.js +30 -0
  39. package/dist/es5/lib/texture-api/generate-url.js.map +1 -0
  40. package/dist/es5/lib/texture-api/load-image.js +69 -0
  41. package/dist/es5/lib/texture-api/load-image.js.map +1 -0
  42. package/dist/es5/lib/utils/version.js +9 -0
  43. package/dist/es5/lib/utils/version.js.map +1 -0
  44. package/dist/es5/types.js +2 -0
  45. package/dist/{types.js.map → es5/types.js.map} +0 -0
  46. package/dist/esm/bundle.js +5 -0
  47. package/dist/esm/bundle.js.map +1 -0
  48. package/dist/esm/image-loader.js +24 -0
  49. package/dist/esm/image-loader.js.map +1 -0
  50. package/dist/esm/image-writer.js +17 -0
  51. package/dist/esm/image-writer.js.map +1 -0
  52. package/dist/esm/index.js +8 -0
  53. package/dist/esm/index.js.map +1 -0
  54. package/dist/esm/lib/category-api/binary-image-api.js +118 -0
  55. package/dist/esm/lib/category-api/binary-image-api.js.map +1 -0
  56. package/dist/esm/lib/category-api/image-format.js +44 -0
  57. package/dist/esm/lib/category-api/image-format.js.map +1 -0
  58. package/dist/esm/lib/category-api/image-type.js +42 -0
  59. package/dist/esm/lib/category-api/image-type.js.map +1 -0
  60. package/dist/esm/lib/category-api/parsed-image-api.js +64 -0
  61. package/dist/esm/lib/category-api/parsed-image-api.js.map +1 -0
  62. package/dist/esm/lib/encoders/encode-image.js +69 -0
  63. package/dist/esm/lib/encoders/encode-image.js.map +1 -0
  64. package/dist/esm/lib/parsers/parse-image.js +52 -0
  65. package/dist/esm/lib/parsers/parse-image.js.map +1 -0
  66. package/dist/esm/lib/parsers/parse-to-image-bitmap.js +43 -0
  67. package/dist/esm/lib/parsers/parse-to-image-bitmap.js.map +1 -0
  68. package/dist/esm/lib/parsers/parse-to-image.js +34 -0
  69. package/dist/esm/lib/parsers/parse-to-image.js.map +1 -0
  70. package/dist/esm/lib/parsers/parse-to-node-image.js +11 -0
  71. package/dist/esm/lib/parsers/parse-to-node-image.js.map +1 -0
  72. package/dist/esm/lib/parsers/svg-utils.js +32 -0
  73. package/dist/esm/lib/parsers/svg-utils.js.map +1 -0
  74. package/dist/esm/lib/texture-api/async-deep-map.js +39 -0
  75. package/dist/esm/lib/texture-api/async-deep-map.js.map +1 -0
  76. package/dist/esm/lib/texture-api/deep-load.js +10 -0
  77. package/dist/esm/lib/texture-api/deep-load.js.map +1 -0
  78. package/dist/esm/lib/texture-api/generate-url.js +22 -0
  79. package/dist/esm/lib/texture-api/generate-url.js.map +1 -0
  80. package/dist/esm/lib/texture-api/load-image.js +52 -0
  81. package/dist/esm/lib/texture-api/load-image.js.map +1 -0
  82. package/dist/esm/lib/utils/version.js +2 -0
  83. package/dist/esm/lib/utils/version.js.map +1 -0
  84. package/dist/esm/types.js +2 -0
  85. package/dist/esm/types.js.map +1 -0
  86. package/dist/image-loader.d.ts +26 -0
  87. package/dist/image-loader.d.ts.map +1 -0
  88. package/dist/image-loader.js +39 -20
  89. package/dist/image-writer.d.ts +16 -0
  90. package/dist/image-writer.d.ts.map +1 -0
  91. package/dist/image-writer.js +19 -16
  92. package/dist/index.d.ts +10 -0
  93. package/dist/index.d.ts.map +1 -0
  94. package/dist/index.js +27 -8
  95. package/dist/lib/category-api/binary-image-api.d.ts +19 -0
  96. package/dist/lib/category-api/binary-image-api.d.ts.map +1 -0
  97. package/dist/lib/category-api/binary-image-api.js +125 -102
  98. package/dist/lib/category-api/image-format.d.ts +5 -0
  99. package/dist/lib/category-api/image-format.d.ts.map +1 -0
  100. package/dist/lib/category-api/image-format.js +56 -37
  101. package/dist/lib/category-api/image-type.d.ts +12 -0
  102. package/dist/lib/category-api/image-type.d.ts.map +1 -0
  103. package/dist/lib/category-api/image-type.js +44 -38
  104. package/dist/lib/category-api/parsed-image-api.d.ts +10 -0
  105. package/dist/lib/category-api/parsed-image-api.d.ts.map +1 -0
  106. package/dist/lib/category-api/parsed-image-api.js +62 -57
  107. package/dist/lib/encoders/encode-image.d.ts +12 -0
  108. package/dist/lib/encoders/encode-image.d.ts.map +1 -0
  109. package/dist/lib/encoders/encode-image.js +73 -60
  110. package/dist/lib/parsers/parse-image.d.ts +5 -0
  111. package/dist/lib/parsers/parse-image.d.ts.map +1 -0
  112. package/dist/lib/parsers/parse-image.js +54 -49
  113. package/dist/lib/parsers/parse-to-image-bitmap.d.ts +10 -0
  114. package/dist/lib/parsers/parse-to-image-bitmap.d.ts.map +1 -0
  115. package/dist/lib/parsers/parse-to-image-bitmap.js +53 -35
  116. package/dist/lib/parsers/parse-to-image.d.ts +4 -0
  117. package/dist/lib/parsers/parse-to-image.d.ts.map +1 -0
  118. package/dist/lib/parsers/parse-to-image.js +43 -30
  119. package/dist/lib/parsers/parse-to-node-image.d.ts +4 -0
  120. package/dist/lib/parsers/parse-to-node-image.d.ts.map +1 -0
  121. package/dist/lib/parsers/parse-to-node-image.js +13 -10
  122. package/dist/lib/parsers/svg-utils.d.ts +4 -0
  123. package/dist/lib/parsers/svg-utils.d.ts.map +1 -0
  124. package/dist/lib/parsers/svg-utils.js +36 -26
  125. package/dist/lib/texture-api/async-deep-map.d.ts +3 -0
  126. package/dist/lib/texture-api/async-deep-map.d.ts.map +1 -0
  127. package/dist/lib/texture-api/async-deep-map.js +49 -32
  128. package/dist/lib/texture-api/deep-load.d.ts +3 -0
  129. package/dist/lib/texture-api/deep-load.d.ts.map +1 -0
  130. package/dist/lib/texture-api/deep-load.js +13 -8
  131. package/dist/lib/texture-api/generate-url.d.ts +2 -0
  132. package/dist/lib/texture-api/generate-url.d.ts.map +1 -0
  133. package/dist/lib/texture-api/generate-url.js +19 -21
  134. package/dist/lib/texture-api/load-image.d.ts +7 -0
  135. package/dist/lib/texture-api/load-image.d.ts.map +1 -0
  136. package/dist/lib/texture-api/load-image.js +42 -47
  137. package/dist/lib/utils/version.d.ts +2 -0
  138. package/dist/lib/utils/version.d.ts.map +1 -0
  139. package/dist/lib/utils/version.js +7 -2
  140. package/dist/types.d.ts +18 -0
  141. package/dist/types.d.ts.map +1 -0
  142. package/dist/types.js +2 -2
  143. package/package.json +7 -8
  144. package/dist/bundle.js.map +0 -1
  145. package/dist/image-loader.js.map +0 -1
  146. package/dist/image-writer.js.map +0 -1
  147. package/dist/index.js.map +0 -1
  148. package/dist/lib/category-api/binary-image-api.js.map +0 -1
  149. package/dist/lib/category-api/image-format.js.map +0 -1
  150. package/dist/lib/category-api/image-type.js.map +0 -1
  151. package/dist/lib/category-api/parsed-image-api.js.map +0 -1
  152. package/dist/lib/encoders/encode-image.js.map +0 -1
  153. package/dist/lib/parsers/parse-image.js.map +0 -1
  154. package/dist/lib/parsers/parse-to-image-bitmap.js.map +0 -1
  155. package/dist/lib/parsers/parse-to-image.js.map +0 -1
  156. package/dist/lib/parsers/parse-to-node-image.js.map +0 -1
  157. package/dist/lib/parsers/svg-utils.js.map +0 -1
  158. package/dist/lib/texture-api/async-deep-map.js.map +0 -1
  159. package/dist/lib/texture-api/deep-load.js.map +0 -1
  160. package/dist/lib/texture-api/generate-url.js.map +0 -1
  161. package/dist/lib/texture-api/load-image.js.map +0 -1
  162. package/dist/lib/utils/version.js.map +0 -1
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = parseToNodeImage;
7
+
8
+ var _loaderUtils = require("@loaders.gl/loader-utils");
9
+
10
+ var _binaryImageApi = require("../category-api/binary-image-api");
11
+
12
+ async function parseToNodeImage(arrayBuffer, options) {
13
+ const {
14
+ mimeType
15
+ } = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {};
16
+ const _parseImageNode = globalThis._parseImageNode;
17
+ (0, _loaderUtils.assert)(_parseImageNode);
18
+ return await _parseImageNode(arrayBuffer, mimeType);
19
+ }
20
+ //# sourceMappingURL=parse-to-node-image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/parsers/parse-to-node-image.ts"],"names":["parseToNodeImage","arrayBuffer","options","mimeType","_parseImageNode","globalThis"],"mappings":";;;;;;;AAEA;;AACA;;AAgBe,eAAeA,gBAAf,CACbC,WADa,EAEbC,OAFa,EAGW;AACxB,QAAM;AAACC,IAAAA;AAAD,MAAa,4CAAuBF,WAAvB,KAAuC,EAA1D;AAGA,QAAMG,eAA+B,GAAGC,UAAU,CAACD,eAAnD;AACA,2BAAOA,eAAP;AAGA,SAAO,MAAMA,eAAe,CAACH,WAAD,EAAcE,QAAd,CAA5B;AACD","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 default 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"],"file":"parse-to-node-image.js"}
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.isSVG = isSVG;
7
+ exports.getBlobOrSVGDataUrl = getBlobOrSVGDataUrl;
8
+ exports.getBlob = getBlob;
9
+ const SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
10
+ const SVG_URL_PATTERN = /\.svg((\?|#).*)?$/;
11
+
12
+ function isSVG(url) {
13
+ return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));
14
+ }
15
+
16
+ function getBlobOrSVGDataUrl(arrayBuffer, url) {
17
+ if (isSVG(url)) {
18
+ const textDecoder = new TextDecoder();
19
+ let xmlText = textDecoder.decode(arrayBuffer);
20
+
21
+ try {
22
+ if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {
23
+ xmlText = unescape(encodeURIComponent(xmlText));
24
+ }
25
+ } catch (error) {
26
+ throw new Error(error.message);
27
+ }
28
+
29
+ const src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
30
+ return src;
31
+ }
32
+
33
+ return getBlob(arrayBuffer, url);
34
+ }
35
+
36
+ function getBlob(arrayBuffer, url) {
37
+ if (isSVG(url)) {
38
+ throw new Error('SVG cannot be parsed directly to imagebitmap');
39
+ }
40
+
41
+ return new Blob([new Uint8Array(arrayBuffer)]);
42
+ }
43
+ //# sourceMappingURL=svg-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/parsers/svg-utils.ts"],"names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","btoa","getBlob","Blob","Uint8Array"],"mappings":";;;;;;;;AAGA,MAAMA,oBAAoB,GAAG,uBAA7B;AACA,MAAMC,eAAe,GAAG,mBAAxB;;AAEO,SAASC,KAAT,CAAeC,GAAf,EAAoB;AACzB,SAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAArB,CAA0BD,GAA1B,KAAkCF,eAAe,CAACG,IAAhB,CAAqBD,GAArB,CAAvC,CAAV;AACD;;AAEM,SAASE,mBAAT,CAA6BC,WAA7B,EAAuDH,GAAvD,EAAoF;AACzF,MAAID,KAAK,CAACC,GAAD,CAAT,EAAgB;AAEd,UAAMI,WAAW,GAAG,IAAIC,WAAJ,EAApB;AACA,QAAIC,OAAO,GAAGF,WAAW,CAACG,MAAZ,CAAmBJ,WAAnB,CAAd;;AAEA,QAAI;AACF,UAAI,OAAOK,QAAP,KAAoB,UAApB,IAAkC,OAAOC,kBAAP,KAA8B,UAApE,EAAgF;AAC9EH,QAAAA,OAAO,GAAGE,QAAQ,CAACC,kBAAkB,CAACH,OAAD,CAAnB,CAAlB;AACD;AACF,KAJD,CAIE,OAAOI,KAAP,EAAc;AACd,YAAM,IAAIC,KAAJ,CAAWD,KAAD,CAAiBE,OAA3B,CAAN;AACD;;AAED,UAAMC,GAAG,uCAAgCC,IAAI,CAACR,OAAD,CAApC,CAAT;AACA,WAAOO,GAAP;AACD;;AACD,SAAOE,OAAO,CAACZ,WAAD,EAAcH,GAAd,CAAd;AACD;;AAEM,SAASe,OAAT,CAAiBZ,WAAjB,EAA2CH,GAA3C,EAA+D;AACpE,MAAID,KAAK,CAACC,GAAD,CAAT,EAAgB;AAGd,UAAM,IAAIW,KAAJ,CAAU,8CAAV,CAAN;AACD;;AAED,SAAO,IAAIK,IAAJ,CAAS,CAAC,IAAIC,UAAJ,CAAed,WAAf,CAAD,CAAT,CAAP;AACD","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"],"file":"svg-utils.js"}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.asyncDeepMap = asyncDeepMap;
7
+ exports.mapSubtree = mapSubtree;
8
+
9
+ const isObject = value => value && typeof value === 'object';
10
+
11
+ async function asyncDeepMap(tree, func, options = {}) {
12
+ return await mapSubtree(tree, func, options);
13
+ }
14
+
15
+ async function mapSubtree(object, func, options) {
16
+ if (Array.isArray(object)) {
17
+ return await mapArray(object, func, options);
18
+ }
19
+
20
+ if (isObject(object)) {
21
+ return await mapObject(object, func, options);
22
+ }
23
+
24
+ const url = object;
25
+ return await func(url, options);
26
+ }
27
+
28
+ async function mapObject(object, func, options) {
29
+ const promises = [];
30
+ const values = {};
31
+
32
+ for (const key in object) {
33
+ const url = object[key];
34
+ const promise = mapSubtree(url, func, options).then(value => {
35
+ values[key] = value;
36
+ });
37
+ promises.push(promise);
38
+ }
39
+
40
+ await Promise.all(promises);
41
+ return values;
42
+ }
43
+
44
+ async function mapArray(urlArray, func, options = {}) {
45
+ const promises = urlArray.map(url => mapSubtree(url, func, options));
46
+ return await Promise.all(promises);
47
+ }
48
+ //# sourceMappingURL=async-deep-map.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/texture-api/async-deep-map.ts"],"names":["isObject","value","asyncDeepMap","tree","func","options","mapSubtree","object","Array","isArray","mapArray","mapObject","url","promises","values","key","promise","then","push","Promise","all","urlArray","map"],"mappings":";;;;;;;;AAgBA,MAAMA,QAAQ,GAAIC,KAAD,IAAWA,KAAK,IAAI,OAAOA,KAAP,KAAiB,QAAtD;;AAKO,eAAeC,YAAf,CAA4BC,IAA5B,EAAkCC,IAAlC,EAAwCC,OAAO,GAAG,EAAlD,EAAsD;AAC3D,SAAO,MAAMC,UAAU,CAACH,IAAD,EAAOC,IAAP,EAAaC,OAAb,CAAvB;AACD;;AAEM,eAAeC,UAAf,CAA0BC,MAA1B,EAAkCH,IAAlC,EAAwCC,OAAxC,EAAiD;AACtD,MAAIG,KAAK,CAACC,OAAN,CAAcF,MAAd,CAAJ,EAA2B;AACzB,WAAO,MAAMG,QAAQ,CAACH,MAAD,EAASH,IAAT,EAAeC,OAAf,CAArB;AACD;;AAED,MAAIL,QAAQ,CAACO,MAAD,CAAZ,EAAsB;AACpB,WAAO,MAAMI,SAAS,CAACJ,MAAD,EAASH,IAAT,EAAeC,OAAf,CAAtB;AACD;;AAGD,QAAMO,GAAG,GAAGL,MAAZ;AACA,SAAO,MAAMH,IAAI,CAACQ,GAAD,EAAMP,OAAN,CAAjB;AACD;;AAID,eAAeM,SAAf,CAAyBJ,MAAzB,EAAiCH,IAAjC,EAAuCC,OAAvC,EAAgD;AAC9C,QAAMQ,QAAwB,GAAG,EAAjC;AACA,QAAMC,MAAM,GAAG,EAAf;;AAEA,OAAK,MAAMC,GAAX,IAAkBR,MAAlB,EAA0B;AACxB,UAAMK,GAAG,GAAGL,MAAM,CAACQ,GAAD,CAAlB;AACA,UAAMC,OAAO,GAAGV,UAAU,CAACM,GAAD,EAAMR,IAAN,EAAYC,OAAZ,CAAV,CAA+BY,IAA/B,CAAqChB,KAAD,IAAW;AAC7Da,MAAAA,MAAM,CAACC,GAAD,CAAN,GAAcd,KAAd;AACD,KAFe,CAAhB;AAGAY,IAAAA,QAAQ,CAACK,IAAT,CAAcF,OAAd;AACD;;AAED,QAAMG,OAAO,CAACC,GAAR,CAAYP,QAAZ,CAAN;AAEA,SAAOC,MAAP;AACD;;AAED,eAAeJ,QAAf,CAAwBW,QAAxB,EAAkCjB,IAAlC,EAAwCC,OAAO,GAAG,EAAlD,EAAsD;AACpD,QAAMQ,QAAQ,GAAGQ,QAAQ,CAACC,GAAT,CAAcV,GAAD,IAASN,UAAU,CAACM,GAAD,EAAMR,IAAN,EAAYC,OAAZ,CAAhC,CAAjB;AACA,SAAO,MAAMc,OAAO,CAACC,GAAR,CAAYP,QAAZ,CAAb;AACD","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"],"file":"async-deep-map.js"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.deepLoad = deepLoad;
7
+ exports.shallowLoad = shallowLoad;
8
+
9
+ var _asyncDeepMap = require("./async-deep-map");
10
+
11
+ async function deepLoad(urlTree, load, options) {
12
+ return await (0, _asyncDeepMap.asyncDeepMap)(urlTree, url => shallowLoad(url, load, options));
13
+ }
14
+
15
+ async function shallowLoad(url, load, options) {
16
+ const response = await fetch(url, options.fetch);
17
+ const arrayBuffer = await response.arrayBuffer();
18
+ return await load(arrayBuffer, options);
19
+ }
20
+ //# sourceMappingURL=deep-load.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/texture-api/deep-load.ts"],"names":["deepLoad","urlTree","load","options","url","shallowLoad","response","fetch","arrayBuffer"],"mappings":";;;;;;;;AAAA;;AAEO,eAAeA,QAAf,CAAwBC,OAAxB,EAAiCC,IAAjC,EAAuCC,OAAvC,EAAgD;AACrD,SAAO,MAAM,gCAAaF,OAAb,EAAuBG,GAAD,IAASC,WAAW,CAACD,GAAD,EAAMF,IAAN,EAAYC,OAAZ,CAA1C,CAAb;AACD;;AAEM,eAAeE,WAAf,CAA2BD,GAA3B,EAAgCF,IAAhC,EAAsCC,OAAtC,EAA+C;AAEpD,QAAMG,QAAQ,GAAG,MAAMC,KAAK,CAACH,GAAD,EAAMD,OAAO,CAACI,KAAd,CAA5B;AACA,QAAMC,WAAW,GAAG,MAAMF,QAAQ,CAACE,WAAT,EAA1B;AACA,SAAO,MAAMN,IAAI,CAACM,WAAD,EAAcL,OAAd,CAAjB;AACD","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"],"file":"deep-load.js"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.generateUrl = generateUrl;
7
+
8
+ var _loaderUtils = require("@loaders.gl/loader-utils");
9
+
10
+ function generateUrl(getUrl, options, urlOptions) {
11
+ let url = getUrl;
12
+
13
+ if (typeof getUrl === 'function') {
14
+ url = getUrl({ ...options,
15
+ ...urlOptions
16
+ });
17
+ }
18
+
19
+ (0, _loaderUtils.assert)(typeof url === 'string');
20
+ const {
21
+ baseUrl
22
+ } = options;
23
+
24
+ if (baseUrl) {
25
+ url = baseUrl[baseUrl.length - 1] === '/' ? "".concat(baseUrl).concat(url) : "".concat(baseUrl, "/").concat(url);
26
+ }
27
+
28
+ return (0, _loaderUtils.resolvePath)(url);
29
+ }
30
+ //# sourceMappingURL=generate-url.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/texture-api/generate-url.ts"],"names":["generateUrl","getUrl","options","urlOptions","url","baseUrl","length"],"mappings":";;;;;;;AAAA;;AAGO,SAASA,WAAT,CAAqBC,MAArB,EAA6BC,OAA7B,EAAsCC,UAAtC,EAAkD;AAEvD,MAAIC,GAAG,GAAGH,MAAV;;AACA,MAAI,OAAOA,MAAP,KAAkB,UAAtB,EAAkC;AAChCG,IAAAA,GAAG,GAAGH,MAAM,CAAC,EAAC,GAAGC,OAAJ;AAAa,SAAGC;AAAhB,KAAD,CAAZ;AACD;;AACD,2BAAO,OAAOC,GAAP,KAAe,QAAtB;AAGA,QAAM;AAACC,IAAAA;AAAD,MAAYH,OAAlB;;AACA,MAAIG,OAAJ,EAAa;AACXD,IAAAA,GAAG,GAAGC,OAAO,CAACA,OAAO,CAACC,MAAR,GAAiB,CAAlB,CAAP,KAAgC,GAAhC,aAAyCD,OAAzC,SAAmDD,GAAnD,cAA8DC,OAA9D,cAAyED,GAAzE,CAAN;AACD;;AAED,SAAO,8BAAYA,GAAZ,CAAP;AACD","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"],"file":"generate-url.js"}
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.loadImage = loadImage;
9
+ exports.getImageUrls = getImageUrls;
10
+ exports.getMipLevels = getMipLevels;
11
+
12
+ var _loaderUtils = require("@loaders.gl/loader-utils");
13
+
14
+ var _parseImage = _interopRequireDefault(require("../parsers/parse-image"));
15
+
16
+ var _parsedImageApi = require("../category-api/parsed-image-api");
17
+
18
+ var _generateUrl = require("./generate-url");
19
+
20
+ var _deepLoad = require("./deep-load");
21
+
22
+ async function loadImage(getUrl, options = {}) {
23
+ const imageUrls = await getImageUrls(getUrl, options);
24
+ return await (0, _deepLoad.deepLoad)(imageUrls, _parseImage.default, options);
25
+ }
26
+
27
+ async function getImageUrls(getUrl, options, urlOptions = {}) {
28
+ const mipLevels = options && options.image && options.image.mipLevels || 0;
29
+ return mipLevels !== 0 ? await getMipmappedImageUrls(getUrl, mipLevels, options, urlOptions) : (0, _generateUrl.generateUrl)(getUrl, options, urlOptions);
30
+ }
31
+
32
+ async function getMipmappedImageUrls(getUrl, mipLevels, options, urlOptions) {
33
+ const urls = [];
34
+
35
+ if (mipLevels === 'auto') {
36
+ const url = (0, _generateUrl.generateUrl)(getUrl, options, { ...urlOptions,
37
+ lod: 0
38
+ });
39
+ const image = await (0, _deepLoad.shallowLoad)(url, _parseImage.default, options);
40
+ const {
41
+ width,
42
+ height
43
+ } = (0, _parsedImageApi.getImageSize)(image);
44
+ mipLevels = getMipLevels({
45
+ width,
46
+ height
47
+ });
48
+ urls.push(url);
49
+ }
50
+
51
+ (0, _loaderUtils.assert)(mipLevels > 0);
52
+
53
+ for (let mipLevel = urls.length; mipLevel < mipLevels; ++mipLevel) {
54
+ const url = (0, _generateUrl.generateUrl)(getUrl, options, { ...urlOptions,
55
+ lod: mipLevel
56
+ });
57
+ urls.push(url);
58
+ }
59
+
60
+ return urls;
61
+ }
62
+
63
+ function getMipLevels({
64
+ width,
65
+ height
66
+ }) {
67
+ return 1 + Math.floor(Math.log2(Math.max(width, height)));
68
+ }
69
+ //# sourceMappingURL=load-image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/texture-api/load-image.ts"],"names":["loadImage","getUrl","options","imageUrls","getImageUrls","parseImage","urlOptions","mipLevels","image","getMipmappedImageUrls","urls","url","lod","width","height","getMipLevels","push","mipLevel","length","Math","floor","log2","max"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEO,eAAeA,SAAf,CAAyBC,MAAzB,EAAiCC,OAAO,GAAG,EAA3C,EAA+C;AACpD,QAAMC,SAAS,GAAG,MAAMC,YAAY,CAACH,MAAD,EAASC,OAAT,CAApC;AACA,SAAO,MAAM,wBAASC,SAAT,EAAoBE,mBAApB,EAAgCH,OAAhC,CAAb;AACD;;AAEM,eAAeE,YAAf,CAA4BH,MAA5B,EAAoCC,OAApC,EAA6CI,UAAU,GAAG,EAA1D,EAA8D;AACnE,QAAMC,SAAS,GAAIL,OAAO,IAAIA,OAAO,CAACM,KAAnB,IAA4BN,OAAO,CAACM,KAAR,CAAcD,SAA3C,IAAyD,CAA3E;AACA,SAAOA,SAAS,KAAK,CAAd,GACH,MAAME,qBAAqB,CAACR,MAAD,EAASM,SAAT,EAAoBL,OAApB,EAA6BI,UAA7B,CADxB,GAEH,8BAAYL,MAAZ,EAAoBC,OAApB,EAA6BI,UAA7B,CAFJ;AAGD;;AAED,eAAeG,qBAAf,CAAqCR,MAArC,EAA6CM,SAA7C,EAAwDL,OAAxD,EAAiEI,UAAjE,EAA6E;AAC3E,QAAMI,IAAc,GAAG,EAAvB;;AAGA,MAAIH,SAAS,KAAK,MAAlB,EAA0B;AACxB,UAAMI,GAAG,GAAG,8BAAYV,MAAZ,EAAoBC,OAApB,EAA6B,EAAC,GAAGI,UAAJ;AAAgBM,MAAAA,GAAG,EAAE;AAArB,KAA7B,CAAZ;AACA,UAAMJ,KAAK,GAAG,MAAM,2BAAYG,GAAZ,EAAiBN,mBAAjB,EAA6BH,OAA7B,CAApB;AAEA,UAAM;AAACW,MAAAA,KAAD;AAAQC,MAAAA;AAAR,QAAkB,kCAAaN,KAAb,CAAxB;AACAD,IAAAA,SAAS,GAAGQ,YAAY,CAAC;AAACF,MAAAA,KAAD;AAAQC,MAAAA;AAAR,KAAD,CAAxB;AAGAJ,IAAAA,IAAI,CAACM,IAAL,CAAUL,GAAV;AACD;;AAGD,2BAAOJ,SAAS,GAAG,CAAnB;;AAEA,OAAK,IAAIU,QAAQ,GAAGP,IAAI,CAACQ,MAAzB,EAAiCD,QAAQ,GAAGV,SAA5C,EAAuD,EAAEU,QAAzD,EAAmE;AACjE,UAAMN,GAAG,GAAG,8BAAYV,MAAZ,EAAoBC,OAApB,EAA6B,EAAC,GAAGI,UAAJ;AAAgBM,MAAAA,GAAG,EAAEK;AAArB,KAA7B,CAAZ;AACAP,IAAAA,IAAI,CAACM,IAAL,CAAUL,GAAV;AACD;;AAED,SAAOD,IAAP;AACD;;AAGM,SAASK,YAAT,CAAsB;AAACF,EAAAA,KAAD;AAAQC,EAAAA;AAAR,CAAtB,EAAuC;AAC5C,SAAO,IAAIK,IAAI,CAACC,KAAL,CAAWD,IAAI,CAACE,IAAL,CAAUF,IAAI,CAACG,GAAL,CAAST,KAAT,EAAgBC,MAAhB,CAAV,CAAX,CAAX;AACD","sourcesContent":["import {assert} from '@loaders.gl/loader-utils';\nimport parseImage from '../parsers/parse-image';\nimport {getImageSize} from '../category-api/parsed-image-api';\nimport {generateUrl} from './generate-url';\nimport {deepLoad, shallowLoad} from './deep-load';\n\nexport async function loadImage(getUrl, options = {}) {\n const imageUrls = await getImageUrls(getUrl, options);\n return await deepLoad(imageUrls, parseImage, options);\n}\n\nexport async function getImageUrls(getUrl, options, urlOptions = {}) {\n const mipLevels = (options && options.image && options.image.mipLevels) || 0;\n return mipLevels !== 0\n ? await getMipmappedImageUrls(getUrl, mipLevels, options, urlOptions)\n : generateUrl(getUrl, options, urlOptions);\n}\n\nasync function getMipmappedImageUrls(getUrl, mipLevels, options, urlOptions) {\n const urls: string[] = [];\n\n // If no mip levels supplied, we need to load the level 0 image and calculate based on size\n if (mipLevels === 'auto') {\n const url = generateUrl(getUrl, options, {...urlOptions, lod: 0});\n const image = await shallowLoad(url, parseImage, options);\n\n const {width, height} = getImageSize(image);\n mipLevels = getMipLevels({width, height});\n\n // TODO - push image and make `deepLoad` pass through non-url values, avoid loading twice?\n urls.push(url);\n }\n\n // We now know how many mipLevels we need, remaining image urls can now be constructed\n assert(mipLevels > 0);\n\n for (let mipLevel = urls.length; mipLevel < mipLevels; ++mipLevel) {\n const url = generateUrl(getUrl, options, {...urlOptions, lod: mipLevel});\n urls.push(url);\n }\n\n return urls;\n}\n\n// Calculates number of mipmaps based on texture size (log2)\nexport function getMipLevels({width, height}) {\n return 1 + Math.floor(Math.log2(Math.max(width, height)));\n}\n"],"file":"load-image.js"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.VERSION = void 0;
7
+ const VERSION = typeof "3.1.0-beta.2" !== 'undefined' ? "3.1.0-beta.2" : 'latest';
8
+ exports.VERSION = VERSION;
9
+ //# sourceMappingURL=version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/utils/version.ts"],"names":["VERSION"],"mappings":";;;;;;AAGO,MAAMA,OAAO,GAAG,0BAAuB,WAAvB,oBAAmD,QAAnE","sourcesContent":["// Version constant cannot be imported, it needs to correspond to the build version of **this** module.\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nexport const VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n"],"file":"version.js"}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=types.js.map
File without changes
@@ -0,0 +1,5 @@
1
+ const moduleExports = require('./index');
2
+
3
+ globalThis.loaders = globalThis.loaders || {};
4
+ module.exports = Object.assign(globalThis.loaders, moduleExports);
5
+ //# sourceMappingURL=bundle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/bundle.ts"],"names":["moduleExports","require","globalThis","loaders","module","exports","Object","assign"],"mappings":"AACA,MAAMA,aAAa,GAAGC,OAAO,CAAC,SAAD,CAA7B;;AACAC,UAAU,CAACC,OAAX,GAAqBD,UAAU,CAACC,OAAX,IAAsB,EAA3C;AACAC,MAAM,CAACC,OAAP,GAAiBC,MAAM,CAACC,MAAP,CAAcL,UAAU,CAACC,OAAzB,EAAkCH,aAAlC,CAAjB","sourcesContent":["// @ts-nocheck\nconst moduleExports = require('./index');\nglobalThis.loaders = globalThis.loaders || {};\nmodule.exports = Object.assign(globalThis.loaders, moduleExports);\n"],"file":"bundle.js"}
@@ -0,0 +1,24 @@
1
+ import { VERSION } from './lib/utils/version';
2
+ import parseImage from './lib/parsers/parse-image';
3
+ import { getBinaryImageMetadata } from './lib/category-api/binary-image-api';
4
+ const EXTENSIONS = ['png', 'jpg', 'jpeg', 'gif', 'webp', 'bmp', 'ico', 'svg'];
5
+ const MIME_TYPES = ['image/png', 'image/jpeg', 'image/gif', 'image/webp', 'image/bmp', 'image/vnd.microsoft.icon', 'image/svg+xml'];
6
+ const DEFAULT_IMAGE_LOADER_OPTIONS = {
7
+ image: {
8
+ type: 'auto',
9
+ decode: true
10
+ }
11
+ };
12
+ export const ImageLoader = {
13
+ id: 'image',
14
+ module: 'images',
15
+ name: 'Images',
16
+ version: VERSION,
17
+ mimeTypes: MIME_TYPES,
18
+ extensions: EXTENSIONS,
19
+ parse: parseImage,
20
+ tests: [arrayBuffer => Boolean(getBinaryImageMetadata(new DataView(arrayBuffer)))],
21
+ options: DEFAULT_IMAGE_LOADER_OPTIONS
22
+ };
23
+ export const _typecheckImageLoader = ImageLoader;
24
+ //# sourceMappingURL=image-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/image-loader.ts"],"names":["VERSION","parseImage","getBinaryImageMetadata","EXTENSIONS","MIME_TYPES","DEFAULT_IMAGE_LOADER_OPTIONS","image","type","decode","ImageLoader","id","module","name","version","mimeTypes","extensions","parse","tests","arrayBuffer","Boolean","DataView","options","_typecheckImageLoader"],"mappings":"AACA,SAAQA,OAAR,QAAsB,qBAAtB;AACA,OAAOC,UAAP,MAAuB,2BAAvB;AACA,SAAQC,sBAAR,QAAqC,qCAArC;AAEA,MAAMC,UAAU,GAAG,CAAC,KAAD,EAAQ,KAAR,EAAe,MAAf,EAAuB,KAAvB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,KAA7C,EAAoD,KAApD,CAAnB;AACA,MAAMC,UAAU,GAAG,CACjB,WADiB,EAEjB,YAFiB,EAGjB,WAHiB,EAIjB,YAJiB,EAKjB,WALiB,EAMjB,0BANiB,EAOjB,eAPiB,CAAnB;AAkBA,MAAMC,4BAAgD,GAAG;AACvDC,EAAAA,KAAK,EAAE;AACLC,IAAAA,IAAI,EAAE,MADD;AAELC,IAAAA,MAAM,EAAE;AAFH;AADgD,CAAzD;AAYA,OAAO,MAAMC,WAAW,GAAG;AACzBC,EAAAA,EAAE,EAAE,OADqB;AAEzBC,EAAAA,MAAM,EAAE,QAFiB;AAGzBC,EAAAA,IAAI,EAAE,QAHmB;AAIzBC,EAAAA,OAAO,EAAEb,OAJgB;AAKzBc,EAAAA,SAAS,EAAEV,UALc;AAMzBW,EAAAA,UAAU,EAAEZ,UANa;AAOzBa,EAAAA,KAAK,EAAEf,UAPkB;AASzBgB,EAAAA,KAAK,EAAE,CAAEC,WAAD,IAAiBC,OAAO,CAACjB,sBAAsB,CAAC,IAAIkB,QAAJ,CAAaF,WAAb,CAAD,CAAvB,CAAzB,CATkB;AAUzBG,EAAAA,OAAO,EAAEhB;AAVgB,CAApB;AAaP,OAAO,MAAMiB,qBAAuC,GAAGb,WAAhD","sourcesContent":["import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {VERSION} from './lib/utils/version';\nimport parseImage from './lib/parsers/parse-image';\nimport {getBinaryImageMetadata} from './lib/category-api/binary-image-api';\n\nconst EXTENSIONS = ['png', 'jpg', 'jpeg', 'gif', 'webp', 'bmp', 'ico', 'svg'];\nconst MIME_TYPES = [\n 'image/png',\n 'image/jpeg',\n 'image/gif',\n 'image/webp',\n 'image/bmp',\n 'image/vnd.microsoft.icon',\n 'image/svg+xml'\n];\n\nexport type ImageLoaderOptions = LoaderOptions & {\n image?: {\n type?: 'auto' | 'data' | 'imagebitmap' | 'image';\n decode?: boolean;\n };\n imagebitmap?: ImageBitmapOptions;\n};\n\nconst DEFAULT_IMAGE_LOADER_OPTIONS: ImageLoaderOptions = {\n image: {\n type: 'auto',\n decode: true // if format is HTML\n }\n // imagebitmap: {} - passes (platform dependent) parameters to ImageBitmap constructor\n};\n\n/**\n * Loads a platform-specific image type\n * Note: This type can be used as input data to WebGL texture creation\n */\nexport const ImageLoader = {\n id: 'image',\n module: 'images',\n name: 'Images',\n version: VERSION,\n mimeTypes: MIME_TYPES,\n extensions: EXTENSIONS,\n parse: parseImage,\n // TODO: byteOffset, byteLength;\n tests: [(arrayBuffer) => Boolean(getBinaryImageMetadata(new DataView(arrayBuffer)))],\n options: DEFAULT_IMAGE_LOADER_OPTIONS\n};\n\nexport const _typecheckImageLoader: LoaderWithParser = ImageLoader;\n"],"file":"image-loader.js"}
@@ -0,0 +1,17 @@
1
+ import { VERSION } from './lib/utils/version';
2
+ import { encodeImage } from './lib/encoders/encode-image';
3
+ export const ImageWriter = {
4
+ name: 'Images',
5
+ id: 'image',
6
+ module: 'images',
7
+ version: VERSION,
8
+ extensions: ['jpeg'],
9
+ options: {
10
+ image: {
11
+ mimeType: 'image/png',
12
+ jpegQuality: null
13
+ }
14
+ },
15
+ encode: encodeImage
16
+ };
17
+ //# sourceMappingURL=image-writer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/image-writer.ts"],"names":["VERSION","encodeImage","ImageWriter","name","id","module","version","extensions","options","image","mimeType","jpegQuality","encode"],"mappings":"AACA,SAAQA,OAAR,QAAsB,qBAAtB;AACA,SAAQC,WAAR,QAA0B,6BAA1B;AAEA,OAAO,MAAMC,WAAW,GAAG;AACzBC,EAAAA,IAAI,EAAE,QADmB;AAEzBC,EAAAA,EAAE,EAAE,OAFqB;AAGzBC,EAAAA,MAAM,EAAE,QAHiB;AAIzBC,EAAAA,OAAO,EAAEN,OAJgB;AAKzBO,EAAAA,UAAU,EAAE,CAAC,MAAD,CALa;AAMzBC,EAAAA,OAAO,EAAE;AACPC,IAAAA,KAAK,EAAE;AACLC,MAAAA,QAAQ,EAAE,WADL;AAELC,MAAAA,WAAW,EAAE;AAFR;AADA,GANgB;AAYzBC,EAAAA,MAAM,EAAEX;AAZiB,CAApB","sourcesContent":["// import type {Writer} from '@loaders.gl/loader-utils';\nimport {VERSION} from './lib/utils/version';\nimport {encodeImage} from './lib/encoders/encode-image';\n\nexport const ImageWriter = {\n name: 'Images',\n id: 'image',\n module: 'images',\n version: VERSION,\n extensions: ['jpeg'],\n options: {\n image: {\n mimeType: 'image/png',\n jpegQuality: null\n }\n },\n encode: encodeImage\n};\n"],"file":"image-writer.js"}
@@ -0,0 +1,8 @@
1
+ export { ImageLoader } from './image-loader';
2
+ export { ImageWriter } from './image-writer';
3
+ export { getBinaryImageMetadata } from './lib/category-api/binary-image-api';
4
+ export { isImageTypeSupported, getDefaultImageType } from './lib/category-api/image-type';
5
+ export { isImage, getImageType, getImageSize, getImageData } from './lib/category-api/parsed-image-api';
6
+ export { _isImageFormatSupported } from './lib/category-api/image-format';
7
+ export { loadImage } from './lib/texture-api/load-image';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/index.ts"],"names":["ImageLoader","ImageWriter","getBinaryImageMetadata","isImageTypeSupported","getDefaultImageType","isImage","getImageType","getImageSize","getImageData","_isImageFormatSupported","loadImage"],"mappings":"AAKA,SAAQA,WAAR,QAA0B,gBAA1B;AACA,SAAQC,WAAR,QAA0B,gBAA1B;AAKA,SAAQC,sBAAR,QAAqC,qCAArC;AAGA,SAAQC,oBAAR,EAA8BC,mBAA9B,QAAwD,+BAAxD;AAEA,SACEC,OADF,EAEEC,YAFF,EAGEC,YAHF,EAIEC,YAJF,QAKO,qCALP;AAQA,SAAQC,uBAAR,QAAsC,iCAAtC;AAGA,SAAQC,SAAR,QAAwB,8BAAxB","sourcesContent":["// TYPES\nexport type {ImageDataType, ImageType, ImageTypeEnum} from './types';\nexport type {ImageLoaderOptions} from './image-loader';\n\n// LOADERS AND WRITERS\nexport {ImageLoader} from './image-loader';\nexport {ImageWriter} from './image-writer';\n\n// IMAGE CATEGORY API\n\n// Binary Image API\nexport {getBinaryImageMetadata} from './lib/category-api/binary-image-api';\n\n// Parsed Image API\nexport {isImageTypeSupported, getDefaultImageType} from './lib/category-api/image-type';\n\nexport {\n isImage,\n getImageType,\n getImageSize,\n getImageData\n} from './lib/category-api/parsed-image-api';\n\n// EXPERIMENTAL\nexport {_isImageFormatSupported} from './lib/category-api/image-format';\n\n// DEPRECATED - Remove in V3 (fix dependency in luma.gl)\nexport {loadImage} from './lib/texture-api/load-image';\n"],"file":"index.js"}
@@ -0,0 +1,118 @@
1
+ const BIG_ENDIAN = false;
2
+ const LITTLE_ENDIAN = true;
3
+ export function getBinaryImageMetadata(binaryData) {
4
+ const dataView = toDataView(binaryData);
5
+ return getPngMetadata(dataView) || getJpegMetadata(dataView) || getGifMetadata(dataView) || getBmpMetadata(dataView);
6
+ }
7
+
8
+ function getPngMetadata(binaryData) {
9
+ const dataView = toDataView(binaryData);
10
+ const isPng = dataView.byteLength >= 24 && dataView.getUint32(0, BIG_ENDIAN) === 0x89504e47;
11
+
12
+ if (!isPng) {
13
+ return null;
14
+ }
15
+
16
+ return {
17
+ mimeType: 'image/png',
18
+ width: dataView.getUint32(16, BIG_ENDIAN),
19
+ height: dataView.getUint32(20, BIG_ENDIAN)
20
+ };
21
+ }
22
+
23
+ function getGifMetadata(binaryData) {
24
+ const dataView = toDataView(binaryData);
25
+ const isGif = dataView.byteLength >= 10 && dataView.getUint32(0, BIG_ENDIAN) === 0x47494638;
26
+
27
+ if (!isGif) {
28
+ return null;
29
+ }
30
+
31
+ return {
32
+ mimeType: 'image/gif',
33
+ width: dataView.getUint16(6, LITTLE_ENDIAN),
34
+ height: dataView.getUint16(8, LITTLE_ENDIAN)
35
+ };
36
+ }
37
+
38
+ export function getBmpMetadata(binaryData) {
39
+ const dataView = toDataView(binaryData);
40
+ const isBmp = dataView.byteLength >= 14 && dataView.getUint16(0, BIG_ENDIAN) === 0x424d && dataView.getUint32(2, LITTLE_ENDIAN) === dataView.byteLength;
41
+
42
+ if (!isBmp) {
43
+ return null;
44
+ }
45
+
46
+ return {
47
+ mimeType: 'image/bmp',
48
+ width: dataView.getUint32(18, LITTLE_ENDIAN),
49
+ height: dataView.getUint32(22, LITTLE_ENDIAN)
50
+ };
51
+ }
52
+
53
+ function getJpegMetadata(binaryData) {
54
+ const dataView = toDataView(binaryData);
55
+ const isJpeg = dataView.byteLength >= 3 && dataView.getUint16(0, BIG_ENDIAN) === 0xffd8 && dataView.getUint8(2) === 0xff;
56
+
57
+ if (!isJpeg) {
58
+ return null;
59
+ }
60
+
61
+ const {
62
+ tableMarkers,
63
+ sofMarkers
64
+ } = getJpegMarkers();
65
+ let i = 2;
66
+
67
+ while (i + 9 < dataView.byteLength) {
68
+ const marker = dataView.getUint16(i, BIG_ENDIAN);
69
+
70
+ if (sofMarkers.has(marker)) {
71
+ return {
72
+ mimeType: 'image/jpeg',
73
+ height: dataView.getUint16(i + 5, BIG_ENDIAN),
74
+ width: dataView.getUint16(i + 7, BIG_ENDIAN)
75
+ };
76
+ }
77
+
78
+ if (!tableMarkers.has(marker)) {
79
+ return null;
80
+ }
81
+
82
+ i += 2;
83
+ i += dataView.getUint16(i, BIG_ENDIAN);
84
+ }
85
+
86
+ return null;
87
+ }
88
+
89
+ function getJpegMarkers() {
90
+ const tableMarkers = new Set([0xffdb, 0xffc4, 0xffcc, 0xffdd, 0xfffe]);
91
+
92
+ for (let i = 0xffe0; i < 0xfff0; ++i) {
93
+ tableMarkers.add(i);
94
+ }
95
+
96
+ const sofMarkers = new Set([0xffc0, 0xffc1, 0xffc2, 0xffc3, 0xffc5, 0xffc6, 0xffc7, 0xffc9, 0xffca, 0xffcb, 0xffcd, 0xffce, 0xffcf, 0xffde]);
97
+ return {
98
+ tableMarkers,
99
+ sofMarkers
100
+ };
101
+ }
102
+
103
+ function toDataView(data) {
104
+ if (data instanceof DataView) {
105
+ return data;
106
+ }
107
+
108
+ if (ArrayBuffer.isView(data)) {
109
+ return new DataView(data.buffer);
110
+ }
111
+
112
+ if (data instanceof ArrayBuffer) {
113
+ return new DataView(data);
114
+ }
115
+
116
+ throw new Error('toDataView');
117
+ }
118
+ //# sourceMappingURL=binary-image-api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/category-api/binary-image-api.ts"],"names":["BIG_ENDIAN","LITTLE_ENDIAN","getBinaryImageMetadata","binaryData","dataView","toDataView","getPngMetadata","getJpegMetadata","getGifMetadata","getBmpMetadata","isPng","byteLength","getUint32","mimeType","width","height","isGif","getUint16","isBmp","isJpeg","getUint8","tableMarkers","sofMarkers","getJpegMarkers","i","marker","has","Set","add","data","DataView","ArrayBuffer","isView","buffer","Error"],"mappings":"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","sourcesContent":["// Attributions\n// * Based on binary-gltf-utils under MIT license: Copyright (c) 2016-17 Karl Cheng\n\n// TODO: make these functions work for Node.js buffers?\n// Quarantine references to Buffer to prevent bundler from adding big polyfills\n// import {bufferToArrayBuffer} from '../node/buffer-to-array-buffer';\n// TODO - this should be handled in @loaders.gl/polyfills\n\n/** MIME type, width and height extracted from binary compressed image data */\nexport type BinaryImageMetadata = {\n mimeType: string;\n width: number;\n height: number;\n};\n\nconst BIG_ENDIAN = false;\nconst LITTLE_ENDIAN = true;\n\n/**\n * Extracts `{mimeType, width and height}` from a memory buffer containing a known image format\n * Currently supports `image/png`, `image/jpeg`, `image/bmp` and `image/gif`.\n * @param binaryData image file memory to parse\n * @returns metadata or null if memory is not a valid image file format layout.\n */\nexport function getBinaryImageMetadata(\n binaryData: DataView | ArrayBuffer\n): BinaryImageMetadata | null {\n const dataView = toDataView(binaryData);\n return (\n getPngMetadata(dataView) ||\n getJpegMetadata(dataView) ||\n getGifMetadata(dataView) ||\n getBmpMetadata(dataView)\n );\n}\n\n// PNG\n\nfunction getPngMetadata(binaryData) {\n const dataView = toDataView(binaryData);\n // Check file contains the first 4 bytes of the PNG signature.\n const isPng = dataView.byteLength >= 24 && dataView.getUint32(0, BIG_ENDIAN) === 0x89504e47;\n if (!isPng) {\n return null;\n }\n\n // Extract size from a binary PNG file\n return {\n mimeType: 'image/png',\n width: dataView.getUint32(16, BIG_ENDIAN),\n height: dataView.getUint32(20, BIG_ENDIAN)\n };\n}\n\n// GIF\n\n// Extract size from a binary GIF file\n// TODO: GIF is not this simple\nfunction getGifMetadata(binaryData) {\n const dataView = toDataView(binaryData);\n // Check first 4 bytes of the GIF signature (\"GIF8\").\n const isGif = dataView.byteLength >= 10 && dataView.getUint32(0, BIG_ENDIAN) === 0x47494638;\n if (!isGif) {\n return null;\n }\n\n // GIF is little endian.\n return {\n mimeType: 'image/gif',\n width: dataView.getUint16(6, LITTLE_ENDIAN),\n height: dataView.getUint16(8, LITTLE_ENDIAN)\n };\n}\n\n// BMP\n\n// TODO: BMP is not this simple\nexport function getBmpMetadata(binaryData) {\n const dataView = toDataView(binaryData);\n // Check magic number is valid (first 2 characters should be \"BM\").\n // The mandatory bitmap file header is 14 bytes long.\n const isBmp =\n dataView.byteLength >= 14 &&\n dataView.getUint16(0, BIG_ENDIAN) === 0x424d &&\n dataView.getUint32(2, LITTLE_ENDIAN) === dataView.byteLength;\n\n if (!isBmp) {\n return null;\n }\n\n // BMP is little endian.\n return {\n mimeType: 'image/bmp',\n width: dataView.getUint32(18, LITTLE_ENDIAN),\n height: dataView.getUint32(22, LITTLE_ENDIAN)\n };\n}\n\n// JPEG\n\n// Extract width and height from a binary JPEG file\nfunction getJpegMetadata(binaryData) {\n const dataView = toDataView(binaryData);\n // Check file contains the JPEG \"start of image\" (SOI) marker\n // followed by another marker.\n const isJpeg =\n dataView.byteLength >= 3 &&\n dataView.getUint16(0, BIG_ENDIAN) === 0xffd8 &&\n dataView.getUint8(2) === 0xff;\n\n if (!isJpeg) {\n return null;\n }\n\n const {tableMarkers, sofMarkers} = getJpegMarkers();\n\n // Exclude the two byte SOI marker.\n let i = 2;\n while (i + 9 < dataView.byteLength) {\n const marker = dataView.getUint16(i, BIG_ENDIAN);\n\n // The frame that contains the width and height of the JPEG image.\n if (sofMarkers.has(marker)) {\n return {\n mimeType: 'image/jpeg',\n height: dataView.getUint16(i + 5, BIG_ENDIAN), // Number of lines\n width: dataView.getUint16(i + 7, BIG_ENDIAN) // Number of pixels per line\n };\n }\n\n // Miscellaneous tables/data preceding the frame header.\n if (!tableMarkers.has(marker)) {\n return null;\n }\n\n // Length includes size of length parameter but not the two byte header.\n i += 2;\n i += dataView.getUint16(i, BIG_ENDIAN);\n }\n\n return null;\n}\n\nfunction getJpegMarkers() {\n // Tables/misc header markers.\n // DQT, DHT, DAC, DRI, COM, APP_n\n const tableMarkers = new Set([0xffdb, 0xffc4, 0xffcc, 0xffdd, 0xfffe]);\n for (let i = 0xffe0; i < 0xfff0; ++i) {\n tableMarkers.add(i);\n }\n\n // SOF markers and DHP marker.\n // These markers are after tables/misc data.\n const sofMarkers = new Set([\n 0xffc0, 0xffc1, 0xffc2, 0xffc3, 0xffc5, 0xffc6, 0xffc7, 0xffc9, 0xffca, 0xffcb, 0xffcd, 0xffce,\n 0xffcf, 0xffde\n ]);\n\n return {tableMarkers, sofMarkers};\n}\n\n// TODO - move into image module?\nfunction toDataView(data) {\n if (data instanceof DataView) {\n return data;\n }\n if (ArrayBuffer.isView(data)) {\n return new DataView(data.buffer);\n }\n\n // TODO: make these functions work for Node.js buffers?\n // if (bufferToArrayBuffer) {\n // data = bufferToArrayBuffer(data);\n // }\n\n // Careful - Node Buffers will look like ArrayBuffers (keep after isBuffer)\n if (data instanceof ArrayBuffer) {\n return new DataView(data);\n }\n throw new Error('toDataView');\n}\n"],"file":"binary-image-api.js"}
@@ -0,0 +1,44 @@
1
+ import { isBrowser } from '@loaders.gl/loader-utils';
2
+ const NODE_FORMAT_SUPPORT = ['image/png', 'image/jpeg', 'image/gif'];
3
+ const mimeTypeSupported = {};
4
+ export function _isImageFormatSupported(mimeType) {
5
+ if (mimeTypeSupported[mimeType] === undefined) {
6
+ mimeTypeSupported[mimeType] = checkFormatSupport(mimeType);
7
+ }
8
+
9
+ return mimeTypeSupported[mimeType];
10
+ }
11
+
12
+ function checkFormatSupport(mimeType) {
13
+ switch (mimeType) {
14
+ case 'image/webp':
15
+ return checkWebPSupport();
16
+
17
+ case 'image/svg':
18
+ return isBrowser;
19
+
20
+ default:
21
+ if (!isBrowser) {
22
+ const {
23
+ _parseImageNode
24
+ } = globalThis;
25
+ return Boolean(_parseImageNode) && NODE_FORMAT_SUPPORT.includes(mimeType);
26
+ }
27
+
28
+ return true;
29
+ }
30
+ }
31
+
32
+ function checkWebPSupport() {
33
+ if (!isBrowser) {
34
+ return false;
35
+ }
36
+
37
+ try {
38
+ const element = document.createElement('canvas');
39
+ return element.toDataURL('image/webp').indexOf('data:image/webp') === 0;
40
+ } catch {
41
+ return false;
42
+ }
43
+ }
44
+ //# sourceMappingURL=image-format.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/category-api/image-format.ts"],"names":["isBrowser","NODE_FORMAT_SUPPORT","mimeTypeSupported","_isImageFormatSupported","mimeType","undefined","checkFormatSupport","checkWebPSupport","_parseImageNode","globalThis","Boolean","includes","element","document","createElement","toDataURL","indexOf"],"mappings":"AAAA,SAAQA,SAAR,QAAwB,0BAAxB;AAGA,MAAMC,mBAAmB,GAAG,CAAC,WAAD,EAAc,YAAd,EAA4B,WAA5B,CAA5B;AAGA,MAAMC,iBAAgD,GAAG,EAAzD;AAKA,OAAO,SAASC,uBAAT,CAAiCC,QAAjC,EAA4D;AACjE,MAAIF,iBAAiB,CAACE,QAAD,CAAjB,KAAgCC,SAApC,EAA+C;AAC7CH,IAAAA,iBAAiB,CAACE,QAAD,CAAjB,GAA8BE,kBAAkB,CAACF,QAAD,CAAhD;AACD;;AACD,SAAOF,iBAAiB,CAACE,QAAD,CAAxB;AACD;;AAKD,SAASE,kBAAT,CAA4BF,QAA5B,EAAuD;AACrD,UAAQA,QAAR;AACE,SAAK,YAAL;AACE,aAAOG,gBAAgB,EAAvB;;AACF,SAAK,WAAL;AACE,aAAOP,SAAP;;AACF;AACE,UAAI,CAACA,SAAL,EAAgB;AAEd,cAAM;AAACQ,UAAAA;AAAD,YAAoBC,UAA1B;AACA,eAAOC,OAAO,CAACF,eAAD,CAAP,IAA4BP,mBAAmB,CAACU,QAApB,CAA6BP,QAA7B,CAAnC;AACD;;AACD,aAAO,IAAP;AAXJ;AAaD;;AAGD,SAASG,gBAAT,GAA4B;AAC1B,MAAI,CAACP,SAAL,EAAgB;AACd,WAAO,KAAP;AACD;;AACD,MAAI;AACF,UAAMY,OAAO,GAAGC,QAAQ,CAACC,aAAT,CAAuB,QAAvB,CAAhB;AACA,WAAOF,OAAO,CAACG,SAAR,CAAkB,YAAlB,EAAgCC,OAAhC,CAAwC,iBAAxC,MAA+D,CAAtE;AACD,GAHD,CAGE,MAAM;AAEN,WAAO,KAAP;AACD;AACF","sourcesContent":["import {isBrowser} from '@loaders.gl/loader-utils';\n\n// The following formats are supported by loaders.gl polyfills\nconst NODE_FORMAT_SUPPORT = ['image/png', 'image/jpeg', 'image/gif'];\n\n/** Cache values for speed */\nconst mimeTypeSupported: {[mimeType: string]: boolean} = {};\n\n/**\n * Check if image MIME type is supported. Result is cached.\n */\nexport function _isImageFormatSupported(mimeType: string): boolean {\n if (mimeTypeSupported[mimeType] === undefined) {\n mimeTypeSupported[mimeType] = checkFormatSupport(mimeType);\n }\n return mimeTypeSupported[mimeType];\n}\n\n/**\n * Check if image MIME type is supported.\n */\nfunction checkFormatSupport(mimeType: string): boolean {\n switch (mimeType) {\n case 'image/webp':\n return checkWebPSupport();\n case 'image/svg':\n return isBrowser;\n default:\n if (!isBrowser) {\n // @ts-ignore\n const {_parseImageNode} = globalThis;\n return Boolean(_parseImageNode) && NODE_FORMAT_SUPPORT.includes(mimeType);\n }\n return true;\n }\n}\n\n/** Check WebPSupport synchronously */\nfunction checkWebPSupport() {\n if (!isBrowser) {\n return false;\n }\n try {\n const element = document.createElement('canvas');\n return element.toDataURL('image/webp').indexOf('data:image/webp') === 0;\n } catch {\n // Probably Safari...\n return false;\n }\n}\n\n// Note: better test but asynchronous\n\n// Lossy test image. Support for lossy images doesn't guarantee support for all WebP images.\n// https://stackoverflow.com/questions/5573096/detecting-webp-support\n// const WEBP_TEST_IMAGE = '';\n\n// Check WebPSupport asynchronously\n// async function isWebPSupported() {\n// return new Promise( resolve => {\n// const image = new Image();\n// image.src = WEBP_TEST_IMAGE;\n// image.onload = image.onerror = function () {\n// resolve( image.height === 1 );\n// }\n// }\n"],"file":"image-format.js"}
@@ -0,0 +1,42 @@
1
+ import { isBrowser } from '@loaders.gl/loader-utils';
2
+ const {
3
+ _parseImageNode
4
+ } = globalThis;
5
+ const IMAGE_SUPPORTED = typeof Image !== 'undefined';
6
+ const IMAGE_BITMAP_SUPPORTED = typeof ImageBitmap !== 'undefined';
7
+ const NODE_IMAGE_SUPPORTED = Boolean(_parseImageNode);
8
+ const DATA_SUPPORTED = isBrowser ? true : NODE_IMAGE_SUPPORTED;
9
+ export function isImageTypeSupported(type) {
10
+ switch (type) {
11
+ case 'auto':
12
+ return IMAGE_BITMAP_SUPPORTED || IMAGE_SUPPORTED || DATA_SUPPORTED;
13
+
14
+ case 'imagebitmap':
15
+ return IMAGE_BITMAP_SUPPORTED;
16
+
17
+ case 'image':
18
+ return IMAGE_SUPPORTED;
19
+
20
+ case 'data':
21
+ return DATA_SUPPORTED;
22
+
23
+ default:
24
+ throw new Error("@loaders.gl/images: image ".concat(type, " not supported in this environment"));
25
+ }
26
+ }
27
+ export function getDefaultImageType() {
28
+ if (IMAGE_BITMAP_SUPPORTED) {
29
+ return 'imagebitmap';
30
+ }
31
+
32
+ if (IMAGE_SUPPORTED) {
33
+ return 'image';
34
+ }
35
+
36
+ if (DATA_SUPPORTED) {
37
+ return 'data';
38
+ }
39
+
40
+ throw new Error('Install \'@loaders.gl/polyfills\' to parse images under Node.js');
41
+ }
42
+ //# sourceMappingURL=image-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/lib/category-api/image-type.ts"],"names":["isBrowser","_parseImageNode","globalThis","IMAGE_SUPPORTED","Image","IMAGE_BITMAP_SUPPORTED","ImageBitmap","NODE_IMAGE_SUPPORTED","Boolean","DATA_SUPPORTED","isImageTypeSupported","type","Error","getDefaultImageType"],"mappings":"AAAA,SAAQA,SAAR,QAAwB,0BAAxB;AAIA,MAAM;AAACC,EAAAA;AAAD,IAAoBC,UAA1B;AAEA,MAAMC,eAAe,GAAG,OAAOC,KAAP,KAAiB,WAAzC;AACA,MAAMC,sBAAsB,GAAG,OAAOC,WAAP,KAAuB,WAAtD;AACA,MAAMC,oBAAoB,GAAGC,OAAO,CAACP,eAAD,CAApC;AACA,MAAMQ,cAAc,GAAGT,SAAS,GAAG,IAAH,GAAUO,oBAA1C;AAMA,OAAO,SAASG,oBAAT,CAA8BC,IAA9B,EAAqD;AAC1D,UAAQA,IAAR;AACE,SAAK,MAAL;AAEE,aAAON,sBAAsB,IAAIF,eAA1B,IAA6CM,cAApD;;AAEF,SAAK,aAAL;AACE,aAAOJ,sBAAP;;AACF,SAAK,OAAL;AACE,aAAOF,eAAP;;AACF,SAAK,MAAL;AACE,aAAOM,cAAP;;AAEF;AACE,YAAM,IAAIG,KAAJ,qCAAuCD,IAAvC,wCAAN;AAbJ;AAeD;AAMD,OAAO,SAASE,mBAAT,GAA8C;AACnD,MAAIR,sBAAJ,EAA4B;AAC1B,WAAO,aAAP;AACD;;AACD,MAAIF,eAAJ,EAAqB;AACnB,WAAO,OAAP;AACD;;AACD,MAAIM,cAAJ,EAAoB;AAClB,WAAO,MAAP;AACD;;AAGD,QAAM,IAAIG,KAAJ,CAAU,iEAAV,CAAN;AACD","sourcesContent":["import {isBrowser} from '@loaders.gl/loader-utils';\nimport type {ImageTypeEnum} from '../../types';\n\n// @ts-ignore TS2339: Property does not exist on type\nconst {_parseImageNode} = globalThis;\n\nconst IMAGE_SUPPORTED = typeof Image !== 'undefined'; // NOTE: \"false\" positives if jsdom is installed\nconst IMAGE_BITMAP_SUPPORTED = typeof ImageBitmap !== 'undefined';\nconst NODE_IMAGE_SUPPORTED = Boolean(_parseImageNode);\nconst DATA_SUPPORTED = isBrowser ? true : NODE_IMAGE_SUPPORTED;\n\n/**\n * Checks if a loaders.gl image type is supported\n * @param type image type string\n */\nexport function isImageTypeSupported(type: string): boolean {\n switch (type) {\n case 'auto':\n // Should only ever be false in Node.js, if polyfills have not been installed...\n return IMAGE_BITMAP_SUPPORTED || IMAGE_SUPPORTED || DATA_SUPPORTED;\n\n case 'imagebitmap':\n return IMAGE_BITMAP_SUPPORTED;\n case 'image':\n return IMAGE_SUPPORTED;\n case 'data':\n return DATA_SUPPORTED;\n\n default:\n throw new Error(`@loaders.gl/images: image ${type} not supported in this environment`);\n }\n}\n\n/**\n * Returns the \"most performant\" supported image type on this platform\n * @returns image type string\n */\nexport function getDefaultImageType(): ImageTypeEnum {\n if (IMAGE_BITMAP_SUPPORTED) {\n return 'imagebitmap';\n }\n if (IMAGE_SUPPORTED) {\n return 'image';\n }\n if (DATA_SUPPORTED) {\n return 'data';\n }\n\n // This should only happen in Node.js\n throw new Error('Install \\'@loaders.gl/polyfills\\' to parse images under Node.js');\n}\n"],"file":"image-type.js"}