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

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 (110) hide show
  1. package/dist/bundle.d.ts +2 -0
  2. package/dist/bundle.d.ts.map +1 -0
  3. package/dist/bundle.js +5 -0
  4. package/dist/dist.min.js +2 -2
  5. package/dist/dist.min.js.map +7 -1
  6. package/dist/es5/bundle.js +1 -1
  7. package/dist/es5/bundle.js.map +1 -1
  8. package/dist/es5/image-loader.js +6 -8
  9. package/dist/es5/image-loader.js.map +1 -1
  10. package/dist/es5/image-writer.js +1 -1
  11. package/dist/es5/image-writer.js.map +1 -1
  12. package/dist/es5/index.js +11 -11
  13. package/dist/es5/lib/category-api/binary-image-api.js +22 -22
  14. package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
  15. package/dist/es5/lib/category-api/image-format.js +7 -5
  16. package/dist/es5/lib/category-api/image-format.js.map +1 -1
  17. package/dist/es5/lib/category-api/image-type.js +7 -5
  18. package/dist/es5/lib/category-api/image-type.js.map +1 -1
  19. package/dist/es5/lib/category-api/parsed-image-api.js +4 -8
  20. package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
  21. package/dist/es5/lib/encoders/encode-image.js +45 -97
  22. package/dist/es5/lib/encoders/encode-image.js.map +1 -1
  23. package/dist/es5/lib/parsers/parse-image.js +31 -66
  24. package/dist/es5/lib/parsers/parse-image.js.map +1 -1
  25. package/dist/es5/lib/parsers/parse-to-image-bitmap.js +26 -98
  26. package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
  27. package/dist/es5/lib/parsers/parse-to-image.js +27 -93
  28. package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
  29. package/dist/es5/lib/parsers/parse-to-node-image.js +7 -35
  30. package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
  31. package/dist/es5/lib/parsers/svg-utils.js +5 -5
  32. package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
  33. package/dist/es5/lib/texture-api/async-deep-map.js +27 -156
  34. package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
  35. package/dist/es5/lib/texture-api/deep-load.js +6 -67
  36. package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
  37. package/dist/es5/lib/texture-api/generate-url.js +7 -11
  38. package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
  39. package/dist/es5/lib/texture-api/load-image.js +39 -143
  40. package/dist/es5/lib/texture-api/load-image.js.map +1 -1
  41. package/dist/es5/lib/utils/version.js +1 -1
  42. package/dist/es5/lib/utils/version.js.map +1 -1
  43. package/dist/esm/lib/category-api/image-type.js +1 -1
  44. package/dist/esm/lib/category-api/image-type.js.map +1 -1
  45. package/dist/esm/lib/parsers/parse-to-image.js +1 -1
  46. package/dist/esm/lib/parsers/parse-to-image.js.map +1 -1
  47. package/dist/esm/lib/parsers/svg-utils.js +1 -1
  48. package/dist/esm/lib/parsers/svg-utils.js.map +1 -1
  49. package/dist/esm/lib/texture-api/generate-url.js +1 -1
  50. package/dist/esm/lib/texture-api/generate-url.js.map +1 -1
  51. package/dist/esm/lib/utils/version.js +1 -1
  52. package/dist/esm/lib/utils/version.js.map +1 -1
  53. package/dist/image-loader.d.ts +26 -0
  54. package/dist/image-loader.d.ts.map +1 -0
  55. package/dist/image-loader.js +43 -0
  56. package/dist/image-writer.d.ts +16 -0
  57. package/dist/image-writer.d.ts.map +1 -0
  58. package/dist/image-writer.js +20 -0
  59. package/dist/index.d.ts +10 -0
  60. package/dist/index.d.ts.map +1 -0
  61. package/dist/index.js +27 -0
  62. package/dist/lib/category-api/binary-image-api.d.ts +19 -0
  63. package/dist/lib/category-api/binary-image-api.d.ts.map +1 -0
  64. package/dist/lib/category-api/binary-image-api.js +141 -0
  65. package/dist/lib/category-api/image-format.d.ts +5 -0
  66. package/dist/lib/category-api/image-format.d.ts.map +1 -0
  67. package/dist/lib/category-api/image-format.js +63 -0
  68. package/dist/lib/category-api/image-type.d.ts +12 -0
  69. package/dist/lib/category-api/image-type.d.ts.map +1 -0
  70. package/dist/lib/category-api/image-type.js +48 -0
  71. package/dist/lib/category-api/parsed-image-api.d.ts +10 -0
  72. package/dist/lib/category-api/parsed-image-api.d.ts.map +1 -0
  73. package/dist/lib/category-api/parsed-image-api.js +69 -0
  74. package/dist/lib/encoders/encode-image.d.ts +12 -0
  75. package/dist/lib/encoders/encode-image.d.ts.map +1 -0
  76. package/dist/lib/encoders/encode-image.js +82 -0
  77. package/dist/lib/parsers/parse-image.d.ts +5 -0
  78. package/dist/lib/parsers/parse-image.d.ts.map +1 -0
  79. package/dist/lib/parsers/parse-image.js +57 -0
  80. package/dist/lib/parsers/parse-to-image-bitmap.d.ts +10 -0
  81. package/dist/lib/parsers/parse-to-image-bitmap.d.ts.map +1 -0
  82. package/dist/lib/parsers/parse-to-image-bitmap.js +61 -0
  83. package/dist/lib/parsers/parse-to-image.d.ts +4 -0
  84. package/dist/lib/parsers/parse-to-image.d.ts.map +1 -0
  85. package/dist/lib/parsers/parse-to-image.js +47 -0
  86. package/dist/lib/parsers/parse-to-node-image.d.ts +4 -0
  87. package/dist/lib/parsers/parse-to-node-image.d.ts.map +1 -0
  88. package/dist/lib/parsers/parse-to-node-image.js +14 -0
  89. package/dist/lib/parsers/svg-utils.d.ts +4 -0
  90. package/dist/lib/parsers/svg-utils.d.ts.map +1 -0
  91. package/dist/lib/parsers/svg-utils.js +42 -0
  92. package/dist/lib/texture-api/async-deep-map.d.ts +3 -0
  93. package/dist/lib/texture-api/async-deep-map.d.ts.map +1 -0
  94. package/dist/lib/texture-api/async-deep-map.js +56 -0
  95. package/dist/lib/texture-api/deep-load.d.ts +3 -0
  96. package/dist/lib/texture-api/deep-load.d.ts.map +1 -0
  97. package/dist/lib/texture-api/deep-load.js +15 -0
  98. package/dist/lib/texture-api/generate-url.d.ts +2 -0
  99. package/dist/lib/texture-api/generate-url.d.ts.map +1 -0
  100. package/dist/lib/texture-api/generate-url.js +20 -0
  101. package/dist/lib/texture-api/load-image.d.ts +7 -0
  102. package/dist/lib/texture-api/load-image.d.ts.map +1 -0
  103. package/dist/lib/texture-api/load-image.js +47 -0
  104. package/dist/lib/utils/version.d.ts +2 -0
  105. package/dist/lib/utils/version.d.ts.map +1 -0
  106. package/dist/lib/utils/version.js +7 -0
  107. package/dist/types.d.ts +18 -0
  108. package/dist/types.d.ts.map +1 -0
  109. package/dist/types.js +2 -0
  110. package/package.json +5 -6
@@ -25,7 +25,7 @@ export async function loadToImage(url, options) {
25
25
  try {
26
26
  image.onload = () => resolve(image);
27
27
 
28
- image.onerror = err => reject(new Error(`Could not load image ${url}: ${err}`));
28
+ image.onerror = err => reject(new Error("Could not load image ".concat(url, ": ").concat(err)));
29
29
  } catch (error) {
30
30
  reject(error);
31
31
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/parse-to-image.ts"],"names":["getBlobOrSVGDataUrl","parseToImage","arrayBuffer","options","url","blobOrDataUrl","URL","self","webkitURL","objectUrl","createObjectURL","loadToImage","revokeObjectURL","image","Image","src","decode","Promise","resolve","reject","onload","onerror","err","Error","error"],"mappings":"AACA,SAAQA,mBAAR,QAAkC,aAAlC;AAGA,eAAe,eAAeC,YAAf,CACbC,WADa,EAEbC,OAFa,EAGbC,GAHa,EAIc;AAK3B,QAAMC,aAAa,GAAGL,mBAAmB,CAACE,WAAD,EAAcE,GAAd,CAAzC;AACA,QAAME,GAAG,GAAGC,IAAI,CAACD,GAAL,IAAYC,IAAI,CAACC,SAA7B;AACA,QAAMC,SAAS,GAAG,OAAOJ,aAAP,KAAyB,QAAzB,IAAqCC,GAAG,CAACI,eAAJ,CAAoBL,aAApB,CAAvD;;AACA,MAAI;AACF,WAAO,MAAMM,WAAW,CAACF,SAAS,IAAIJ,aAAd,EAA6BF,OAA7B,CAAxB;AACD,GAFD,SAEU;AACR,QAAIM,SAAJ,EAAe;AACbH,MAAAA,GAAG,CAACM,eAAJ,CAAoBH,SAApB;AACD;AACF;AACF;AAED,OAAO,eAAeE,WAAf,CAA2BP,GAA3B,EAAgCD,OAAhC,EAAoE;AACzE,QAAMU,KAAK,GAAG,IAAIC,KAAJ,EAAd;AACAD,EAAAA,KAAK,CAACE,GAAN,GAAYX,GAAZ;;AASA,MAAID,OAAO,CAACU,KAAR,IAAiBV,OAAO,CAACU,KAAR,CAAcG,MAA/B,IAAyCH,KAAK,CAACG,MAAnD,EAA2D;AACzD,UAAMH,KAAK,CAACG,MAAN,EAAN;AACA,WAAOH,KAAP;AACD;;AAGD,SAAO,MAAM,IAAII,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AAC5C,QAAI;AACFN,MAAAA,KAAK,CAACO,MAAN,GAAe,MAAMF,OAAO,CAACL,KAAD,CAA5B;;AACAA,MAAAA,KAAK,CAACQ,OAAN,GAAiBC,GAAD,IAASH,MAAM,CAAC,IAAII,KAAJ,CAAW,wBAAuBnB,GAAI,KAAIkB,GAAI,EAA9C,CAAD,CAA/B;AACD,KAHD,CAGE,OAAOE,KAAP,EAAc;AACdL,MAAAA,MAAM,CAACK,KAAD,CAAN;AACD;AACF,GAPY,CAAb;AAQD","sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport default async function parseToImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<HTMLImageElement> {\n // Note: image parsing requires conversion to Blob (for createObjectURL).\n // Potentially inefficient for not using `response.blob()` (and for File / Blob inputs)...\n // But presumably not worth adding 'blob' flag to loader objects?\n\n const blobOrDataUrl = getBlobOrSVGDataUrl(arrayBuffer, url);\n const URL = self.URL || self.webkitURL;\n const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);\n try {\n return await loadToImage(objectUrl || blobOrDataUrl, options);\n } finally {\n if (objectUrl) {\n URL.revokeObjectURL(objectUrl);\n }\n }\n}\n\nexport async function loadToImage(url, options): Promise<HTMLImageElement> {\n const image = new Image();\n image.src = url;\n\n // The `image.onload()` callback does not guarantee that the image has been decoded\n // so a main thread \"freeze\" can be incurred when using the image for the first time.\n // `Image.decode()` returns a promise that completes when image is decoded.\n\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/decode\n // Note: When calling `img.decode()`, we do not need to wait for `img.onload()`\n // Note: `HTMLImageElement.decode()` is not available in Edge and IE11\n if (options.image && options.image.decode && image.decode) {\n await image.decode();\n return image;\n }\n\n // Create a promise that tracks onload/onerror callbacks\n return await new Promise((resolve, reject) => {\n try {\n image.onload = () => resolve(image);\n image.onerror = (err) => reject(new Error(`Could not load image ${url}: ${err}`));\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"file":"parse-to-image.js"}
1
+ {"version":3,"sources":["../../../../src/lib/parsers/parse-to-image.ts"],"names":["getBlobOrSVGDataUrl","parseToImage","arrayBuffer","options","url","blobOrDataUrl","URL","self","webkitURL","objectUrl","createObjectURL","loadToImage","revokeObjectURL","image","Image","src","decode","Promise","resolve","reject","onload","onerror","err","Error","error"],"mappings":"AACA,SAAQA,mBAAR,QAAkC,aAAlC;AAGA,eAAe,eAAeC,YAAf,CACbC,WADa,EAEbC,OAFa,EAGbC,GAHa,EAIc;AAK3B,QAAMC,aAAa,GAAGL,mBAAmB,CAACE,WAAD,EAAcE,GAAd,CAAzC;AACA,QAAME,GAAG,GAAGC,IAAI,CAACD,GAAL,IAAYC,IAAI,CAACC,SAA7B;AACA,QAAMC,SAAS,GAAG,OAAOJ,aAAP,KAAyB,QAAzB,IAAqCC,GAAG,CAACI,eAAJ,CAAoBL,aAApB,CAAvD;;AACA,MAAI;AACF,WAAO,MAAMM,WAAW,CAACF,SAAS,IAAIJ,aAAd,EAA6BF,OAA7B,CAAxB;AACD,GAFD,SAEU;AACR,QAAIM,SAAJ,EAAe;AACbH,MAAAA,GAAG,CAACM,eAAJ,CAAoBH,SAApB;AACD;AACF;AACF;AAED,OAAO,eAAeE,WAAf,CAA2BP,GAA3B,EAAgCD,OAAhC,EAAoE;AACzE,QAAMU,KAAK,GAAG,IAAIC,KAAJ,EAAd;AACAD,EAAAA,KAAK,CAACE,GAAN,GAAYX,GAAZ;;AASA,MAAID,OAAO,CAACU,KAAR,IAAiBV,OAAO,CAACU,KAAR,CAAcG,MAA/B,IAAyCH,KAAK,CAACG,MAAnD,EAA2D;AACzD,UAAMH,KAAK,CAACG,MAAN,EAAN;AACA,WAAOH,KAAP;AACD;;AAGD,SAAO,MAAM,IAAII,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AAC5C,QAAI;AACFN,MAAAA,KAAK,CAACO,MAAN,GAAe,MAAMF,OAAO,CAACL,KAAD,CAA5B;;AACAA,MAAAA,KAAK,CAACQ,OAAN,GAAiBC,GAAD,IAASH,MAAM,CAAC,IAAII,KAAJ,gCAAkCnB,GAAlC,eAA0CkB,GAA1C,EAAD,CAA/B;AACD,KAHD,CAGE,OAAOE,KAAP,EAAc;AACdL,MAAAA,MAAM,CAACK,KAAD,CAAN;AACD;AACF,GAPY,CAAb;AAQD","sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport default async function parseToImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<HTMLImageElement> {\n // Note: image parsing requires conversion to Blob (for createObjectURL).\n // Potentially inefficient for not using `response.blob()` (and for File / Blob inputs)...\n // But presumably not worth adding 'blob' flag to loader objects?\n\n const blobOrDataUrl = getBlobOrSVGDataUrl(arrayBuffer, url);\n const URL = self.URL || self.webkitURL;\n const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);\n try {\n return await loadToImage(objectUrl || blobOrDataUrl, options);\n } finally {\n if (objectUrl) {\n URL.revokeObjectURL(objectUrl);\n }\n }\n}\n\nexport async function loadToImage(url, options): Promise<HTMLImageElement> {\n const image = new Image();\n image.src = url;\n\n // The `image.onload()` callback does not guarantee that the image has been decoded\n // so a main thread \"freeze\" can be incurred when using the image for the first time.\n // `Image.decode()` returns a promise that completes when image is decoded.\n\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/decode\n // Note: When calling `img.decode()`, we do not need to wait for `img.onload()`\n // Note: `HTMLImageElement.decode()` is not available in Edge and IE11\n if (options.image && options.image.decode && image.decode) {\n await image.decode();\n return image;\n }\n\n // Create a promise that tracks onload/onerror callbacks\n return await new Promise((resolve, reject) => {\n try {\n image.onload = () => resolve(image);\n image.onerror = (err) => reject(new Error(`Could not load image ${url}: ${err}`));\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"file":"parse-to-image.js"}
@@ -16,7 +16,7 @@ export function getBlobOrSVGDataUrl(arrayBuffer, url) {
16
16
  throw new Error(error.message);
17
17
  }
18
18
 
19
- const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;
19
+ const src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
20
20
  return src;
21
21
  }
22
22
 
@@ -1 +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;AAEA,OAAO,SAASC,KAAT,CAAeC,GAAf,EAAoB;AACzB,SAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAArB,CAA0BD,GAA1B,KAAkCF,eAAe,CAACG,IAAhB,CAAqBD,GAArB,CAAvC,CAAV;AACD;AAED,OAAO,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,GAAI,6BAA4BC,IAAI,CAACR,OAAD,CAAU,EAAvD;AACA,WAAOO,GAAP;AACD;;AACD,SAAOE,OAAO,CAACZ,WAAD,EAAcH,GAAd,CAAd;AACD;AAED,OAAO,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"}
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;AAEA,OAAO,SAASC,KAAT,CAAeC,GAAf,EAAoB;AACzB,SAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAArB,CAA0BD,GAA1B,KAAkCF,eAAe,CAACG,IAAhB,CAAqBD,GAArB,CAAvC,CAAV;AACD;AAED,OAAO,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;AAED,OAAO,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"}
@@ -14,7 +14,7 @@ export function generateUrl(getUrl, options, urlOptions) {
14
14
  } = options;
15
15
 
16
16
  if (baseUrl) {
17
- url = baseUrl[baseUrl.length - 1] === '/' ? `${baseUrl}${url}` : `${baseUrl}/${url}`;
17
+ url = baseUrl[baseUrl.length - 1] === '/' ? "".concat(baseUrl).concat(url) : "".concat(baseUrl, "/").concat(url);
18
18
  }
19
19
 
20
20
  return resolvePath(url);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/texture-api/generate-url.ts"],"names":["resolvePath","assert","generateUrl","getUrl","options","urlOptions","url","baseUrl","length"],"mappings":"AAAA,SAAQA,WAAR,EAAqBC,MAArB,QAAkC,0BAAlC;AAGA,OAAO,SAASC,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;;AACDJ,EAAAA,MAAM,CAAC,OAAOK,GAAP,KAAe,QAAhB,CAAN;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,GAAuC,GAAED,OAAQ,GAAED,GAAI,EAAvD,GAA4D,GAAEC,OAAQ,IAAGD,GAAI,EAAnF;AACD;;AAED,SAAON,WAAW,CAACM,GAAD,CAAlB;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"}
1
+ {"version":3,"sources":["../../../../src/lib/texture-api/generate-url.ts"],"names":["resolvePath","assert","generateUrl","getUrl","options","urlOptions","url","baseUrl","length"],"mappings":"AAAA,SAAQA,WAAR,EAAqBC,MAArB,QAAkC,0BAAlC;AAGA,OAAO,SAASC,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;;AACDJ,EAAAA,MAAM,CAAC,OAAOK,GAAP,KAAe,QAAhB,CAAN;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,SAAON,WAAW,CAACM,GAAD,CAAlB;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"}
@@ -1,2 +1,2 @@
1
- export const VERSION = typeof "3.1.0-alpha.4" !== 'undefined' ? "3.1.0-alpha.4" : 'latest';
1
+ export const VERSION = typeof "3.1.0-beta.3" !== 'undefined' ? "3.1.0-beta.3" : 'latest';
2
2
  //# sourceMappingURL=version.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/utils/version.ts"],"names":["VERSION"],"mappings":"AAGA,OAAO,MAAMA,OAAO,GAAG,2BAAuB,WAAvB,qBAAmD,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"}
1
+ {"version":3,"sources":["../../../../src/lib/utils/version.ts"],"names":["VERSION"],"mappings":"AAGA,OAAO,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,26 @@
1
+ import type { LoaderOptions, LoaderWithParser } from '@loaders.gl/loader-utils';
2
+ import parseImage from './lib/parsers/parse-image';
3
+ export declare type ImageLoaderOptions = LoaderOptions & {
4
+ image?: {
5
+ type?: 'auto' | 'data' | 'imagebitmap' | 'image';
6
+ decode?: boolean;
7
+ };
8
+ imagebitmap?: ImageBitmapOptions;
9
+ };
10
+ /**
11
+ * Loads a platform-specific image type
12
+ * Note: This type can be used as input data to WebGL texture creation
13
+ */
14
+ export declare const ImageLoader: {
15
+ id: string;
16
+ module: string;
17
+ name: string;
18
+ version: any;
19
+ mimeTypes: string[];
20
+ extensions: string[];
21
+ parse: typeof parseImage;
22
+ tests: ((arrayBuffer: any) => boolean)[];
23
+ options: ImageLoaderOptions;
24
+ };
25
+ export declare const _typecheckImageLoader: LoaderWithParser;
26
+ //# sourceMappingURL=image-loader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"image-loader.d.ts","sourceRoot":"","sources":["../src/image-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,aAAa,EAAE,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAE9E,OAAO,UAAU,MAAM,2BAA2B,CAAC;AAcnD,oBAAY,kBAAkB,GAAG,aAAa,GAAG;IAC/C,KAAK,CAAC,EAAE;QACN,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,aAAa,GAAG,OAAO,CAAC;QACjD,MAAM,CAAC,EAAE,OAAO,CAAC;KAClB,CAAC;IACF,WAAW,CAAC,EAAE,kBAAkB,CAAC;CAClC,CAAC;AAUF;;;GAGG;AACH,eAAO,MAAM,WAAW;;;;;;;;;;CAWvB,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,gBAA8B,CAAC"}
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports._typecheckImageLoader = exports.ImageLoader = void 0;
7
+ const version_1 = require("./lib/utils/version");
8
+ const parse_image_1 = __importDefault(require("./lib/parsers/parse-image"));
9
+ const binary_image_api_1 = require("./lib/category-api/binary-image-api");
10
+ const EXTENSIONS = ['png', 'jpg', 'jpeg', 'gif', 'webp', 'bmp', 'ico', 'svg'];
11
+ const MIME_TYPES = [
12
+ 'image/png',
13
+ 'image/jpeg',
14
+ 'image/gif',
15
+ 'image/webp',
16
+ 'image/bmp',
17
+ 'image/vnd.microsoft.icon',
18
+ 'image/svg+xml'
19
+ ];
20
+ const DEFAULT_IMAGE_LOADER_OPTIONS = {
21
+ image: {
22
+ type: 'auto',
23
+ decode: true // if format is HTML
24
+ }
25
+ // imagebitmap: {} - passes (platform dependent) parameters to ImageBitmap constructor
26
+ };
27
+ /**
28
+ * Loads a platform-specific image type
29
+ * Note: This type can be used as input data to WebGL texture creation
30
+ */
31
+ exports.ImageLoader = {
32
+ id: 'image',
33
+ module: 'images',
34
+ name: 'Images',
35
+ version: version_1.VERSION,
36
+ mimeTypes: MIME_TYPES,
37
+ extensions: EXTENSIONS,
38
+ parse: parse_image_1.default,
39
+ // TODO: byteOffset, byteLength;
40
+ tests: [(arrayBuffer) => Boolean((0, binary_image_api_1.getBinaryImageMetadata)(new DataView(arrayBuffer)))],
41
+ options: DEFAULT_IMAGE_LOADER_OPTIONS
42
+ };
43
+ exports._typecheckImageLoader = exports.ImageLoader;
@@ -0,0 +1,16 @@
1
+ import { encodeImage } from './lib/encoders/encode-image';
2
+ export declare const ImageWriter: {
3
+ name: string;
4
+ id: string;
5
+ module: string;
6
+ version: any;
7
+ extensions: string[];
8
+ options: {
9
+ image: {
10
+ mimeType: string;
11
+ jpegQuality: null;
12
+ };
13
+ };
14
+ encode: typeof encodeImage;
15
+ };
16
+ //# sourceMappingURL=image-writer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"image-writer.d.ts","sourceRoot":"","sources":["../src/image-writer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,WAAW,EAAC,MAAM,6BAA6B,CAAC;AAExD,eAAO,MAAM,WAAW;;;;;;;;;;;;;CAavB,CAAC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ImageWriter = void 0;
4
+ // import type {Writer} from '@loaders.gl/loader-utils';
5
+ const version_1 = require("./lib/utils/version");
6
+ const encode_image_1 = require("./lib/encoders/encode-image");
7
+ exports.ImageWriter = {
8
+ name: 'Images',
9
+ id: 'image',
10
+ module: 'images',
11
+ version: version_1.VERSION,
12
+ extensions: ['jpeg'],
13
+ options: {
14
+ image: {
15
+ mimeType: 'image/png',
16
+ jpegQuality: null
17
+ }
18
+ },
19
+ encode: encode_image_1.encodeImage
20
+ };
@@ -0,0 +1,10 @@
1
+ export type { ImageDataType, ImageType, ImageTypeEnum } from './types';
2
+ export type { ImageLoaderOptions } from './image-loader';
3
+ export { ImageLoader } from './image-loader';
4
+ export { ImageWriter } from './image-writer';
5
+ export { getBinaryImageMetadata } from './lib/category-api/binary-image-api';
6
+ export { isImageTypeSupported, getDefaultImageType } from './lib/category-api/image-type';
7
+ export { isImage, getImageType, getImageSize, getImageData } from './lib/category-api/parsed-image-api';
8
+ export { _isImageFormatSupported } from './lib/category-api/image-format';
9
+ export { loadImage } from './lib/texture-api/load-image';
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,YAAY,EAAC,aAAa,EAAE,SAAS,EAAE,aAAa,EAAC,MAAM,SAAS,CAAC;AACrE,YAAY,EAAC,kBAAkB,EAAC,MAAM,gBAAgB,CAAC;AAGvD,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAK3C,OAAO,EAAC,sBAAsB,EAAC,MAAM,qCAAqC,CAAC;AAG3E,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,+BAA+B,CAAC;AAExF,OAAO,EACL,OAAO,EACP,YAAY,EACZ,YAAY,EACZ,YAAY,EACb,MAAM,qCAAqC,CAAC;AAG7C,OAAO,EAAC,uBAAuB,EAAC,MAAM,iCAAiC,CAAC;AAGxE,OAAO,EAAC,SAAS,EAAC,MAAM,8BAA8B,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.loadImage = exports._isImageFormatSupported = exports.getImageData = exports.getImageSize = exports.getImageType = exports.isImage = exports.getDefaultImageType = exports.isImageTypeSupported = exports.getBinaryImageMetadata = exports.ImageWriter = exports.ImageLoader = void 0;
4
+ // LOADERS AND WRITERS
5
+ var image_loader_1 = require("./image-loader");
6
+ Object.defineProperty(exports, "ImageLoader", { enumerable: true, get: function () { return image_loader_1.ImageLoader; } });
7
+ var image_writer_1 = require("./image-writer");
8
+ Object.defineProperty(exports, "ImageWriter", { enumerable: true, get: function () { return image_writer_1.ImageWriter; } });
9
+ // IMAGE CATEGORY API
10
+ // Binary Image API
11
+ var binary_image_api_1 = require("./lib/category-api/binary-image-api");
12
+ Object.defineProperty(exports, "getBinaryImageMetadata", { enumerable: true, get: function () { return binary_image_api_1.getBinaryImageMetadata; } });
13
+ // Parsed Image API
14
+ var image_type_1 = require("./lib/category-api/image-type");
15
+ Object.defineProperty(exports, "isImageTypeSupported", { enumerable: true, get: function () { return image_type_1.isImageTypeSupported; } });
16
+ Object.defineProperty(exports, "getDefaultImageType", { enumerable: true, get: function () { return image_type_1.getDefaultImageType; } });
17
+ var parsed_image_api_1 = require("./lib/category-api/parsed-image-api");
18
+ Object.defineProperty(exports, "isImage", { enumerable: true, get: function () { return parsed_image_api_1.isImage; } });
19
+ Object.defineProperty(exports, "getImageType", { enumerable: true, get: function () { return parsed_image_api_1.getImageType; } });
20
+ Object.defineProperty(exports, "getImageSize", { enumerable: true, get: function () { return parsed_image_api_1.getImageSize; } });
21
+ Object.defineProperty(exports, "getImageData", { enumerable: true, get: function () { return parsed_image_api_1.getImageData; } });
22
+ // EXPERIMENTAL
23
+ var image_format_1 = require("./lib/category-api/image-format");
24
+ Object.defineProperty(exports, "_isImageFormatSupported", { enumerable: true, get: function () { return image_format_1._isImageFormatSupported; } });
25
+ // DEPRECATED - Remove in V3 (fix dependency in luma.gl)
26
+ var load_image_1 = require("./lib/texture-api/load-image");
27
+ Object.defineProperty(exports, "loadImage", { enumerable: true, get: function () { return load_image_1.loadImage; } });
@@ -0,0 +1,19 @@
1
+ /** MIME type, width and height extracted from binary compressed image data */
2
+ export declare type BinaryImageMetadata = {
3
+ mimeType: string;
4
+ width: number;
5
+ height: number;
6
+ };
7
+ /**
8
+ * Extracts `{mimeType, width and height}` from a memory buffer containing a known image format
9
+ * Currently supports `image/png`, `image/jpeg`, `image/bmp` and `image/gif`.
10
+ * @param binaryData image file memory to parse
11
+ * @returns metadata or null if memory is not a valid image file format layout.
12
+ */
13
+ export declare function getBinaryImageMetadata(binaryData: DataView | ArrayBuffer): BinaryImageMetadata | null;
14
+ export declare function getBmpMetadata(binaryData: any): {
15
+ mimeType: string;
16
+ width: number;
17
+ height: number;
18
+ } | null;
19
+ //# sourceMappingURL=binary-image-api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binary-image-api.d.ts","sourceRoot":"","sources":["../../../src/lib/category-api/binary-image-api.ts"],"names":[],"mappings":"AAQA,8EAA8E;AAC9E,oBAAY,mBAAmB,GAAG;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAKF;;;;;GAKG;AACH,wBAAgB,sBAAsB,CACpC,UAAU,EAAE,QAAQ,GAAG,WAAW,GACjC,mBAAmB,GAAG,IAAI,CAQ5B;AA2CD,wBAAgB,cAAc,CAAC,UAAU,KAAA;;;;SAmBxC"}
@@ -0,0 +1,141 @@
1
+ "use strict";
2
+ // Attributions
3
+ // * Based on binary-gltf-utils under MIT license: Copyright (c) 2016-17 Karl Cheng
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.getBmpMetadata = exports.getBinaryImageMetadata = void 0;
6
+ const BIG_ENDIAN = false;
7
+ const LITTLE_ENDIAN = true;
8
+ /**
9
+ * Extracts `{mimeType, width and height}` from a memory buffer containing a known image format
10
+ * Currently supports `image/png`, `image/jpeg`, `image/bmp` and `image/gif`.
11
+ * @param binaryData image file memory to parse
12
+ * @returns metadata or null if memory is not a valid image file format layout.
13
+ */
14
+ function getBinaryImageMetadata(binaryData) {
15
+ const dataView = toDataView(binaryData);
16
+ return (getPngMetadata(dataView) ||
17
+ getJpegMetadata(dataView) ||
18
+ getGifMetadata(dataView) ||
19
+ getBmpMetadata(dataView));
20
+ }
21
+ exports.getBinaryImageMetadata = getBinaryImageMetadata;
22
+ // PNG
23
+ function getPngMetadata(binaryData) {
24
+ const dataView = toDataView(binaryData);
25
+ // Check file contains the first 4 bytes of the PNG signature.
26
+ const isPng = dataView.byteLength >= 24 && dataView.getUint32(0, BIG_ENDIAN) === 0x89504e47;
27
+ if (!isPng) {
28
+ return null;
29
+ }
30
+ // Extract size from a binary PNG file
31
+ return {
32
+ mimeType: 'image/png',
33
+ width: dataView.getUint32(16, BIG_ENDIAN),
34
+ height: dataView.getUint32(20, BIG_ENDIAN)
35
+ };
36
+ }
37
+ // GIF
38
+ // Extract size from a binary GIF file
39
+ // TODO: GIF is not this simple
40
+ function getGifMetadata(binaryData) {
41
+ const dataView = toDataView(binaryData);
42
+ // Check first 4 bytes of the GIF signature ("GIF8").
43
+ const isGif = dataView.byteLength >= 10 && dataView.getUint32(0, BIG_ENDIAN) === 0x47494638;
44
+ if (!isGif) {
45
+ return null;
46
+ }
47
+ // GIF is little endian.
48
+ return {
49
+ mimeType: 'image/gif',
50
+ width: dataView.getUint16(6, LITTLE_ENDIAN),
51
+ height: dataView.getUint16(8, LITTLE_ENDIAN)
52
+ };
53
+ }
54
+ // BMP
55
+ // TODO: BMP is not this simple
56
+ function getBmpMetadata(binaryData) {
57
+ const dataView = toDataView(binaryData);
58
+ // Check magic number is valid (first 2 characters should be "BM").
59
+ // The mandatory bitmap file header is 14 bytes long.
60
+ const isBmp = dataView.byteLength >= 14 &&
61
+ dataView.getUint16(0, BIG_ENDIAN) === 0x424d &&
62
+ dataView.getUint32(2, LITTLE_ENDIAN) === dataView.byteLength;
63
+ if (!isBmp) {
64
+ return null;
65
+ }
66
+ // BMP is little endian.
67
+ return {
68
+ mimeType: 'image/bmp',
69
+ width: dataView.getUint32(18, LITTLE_ENDIAN),
70
+ height: dataView.getUint32(22, LITTLE_ENDIAN)
71
+ };
72
+ }
73
+ exports.getBmpMetadata = getBmpMetadata;
74
+ // JPEG
75
+ // Extract width and height from a binary JPEG file
76
+ function getJpegMetadata(binaryData) {
77
+ const dataView = toDataView(binaryData);
78
+ // Check file contains the JPEG "start of image" (SOI) marker
79
+ // followed by another marker.
80
+ const isJpeg = dataView.byteLength >= 3 &&
81
+ dataView.getUint16(0, BIG_ENDIAN) === 0xffd8 &&
82
+ dataView.getUint8(2) === 0xff;
83
+ if (!isJpeg) {
84
+ return null;
85
+ }
86
+ const { tableMarkers, sofMarkers } = getJpegMarkers();
87
+ // Exclude the two byte SOI marker.
88
+ let i = 2;
89
+ while (i + 9 < dataView.byteLength) {
90
+ const marker = dataView.getUint16(i, BIG_ENDIAN);
91
+ // The frame that contains the width and height of the JPEG image.
92
+ if (sofMarkers.has(marker)) {
93
+ return {
94
+ mimeType: 'image/jpeg',
95
+ height: dataView.getUint16(i + 5, BIG_ENDIAN),
96
+ width: dataView.getUint16(i + 7, BIG_ENDIAN) // Number of pixels per line
97
+ };
98
+ }
99
+ // Miscellaneous tables/data preceding the frame header.
100
+ if (!tableMarkers.has(marker)) {
101
+ return null;
102
+ }
103
+ // Length includes size of length parameter but not the two byte header.
104
+ i += 2;
105
+ i += dataView.getUint16(i, BIG_ENDIAN);
106
+ }
107
+ return null;
108
+ }
109
+ function getJpegMarkers() {
110
+ // Tables/misc header markers.
111
+ // DQT, DHT, DAC, DRI, COM, APP_n
112
+ const tableMarkers = new Set([0xffdb, 0xffc4, 0xffcc, 0xffdd, 0xfffe]);
113
+ for (let i = 0xffe0; i < 0xfff0; ++i) {
114
+ tableMarkers.add(i);
115
+ }
116
+ // SOF markers and DHP marker.
117
+ // These markers are after tables/misc data.
118
+ const sofMarkers = new Set([
119
+ 0xffc0, 0xffc1, 0xffc2, 0xffc3, 0xffc5, 0xffc6, 0xffc7, 0xffc9, 0xffca, 0xffcb, 0xffcd, 0xffce,
120
+ 0xffcf, 0xffde
121
+ ]);
122
+ return { tableMarkers, sofMarkers };
123
+ }
124
+ // TODO - move into image module?
125
+ function toDataView(data) {
126
+ if (data instanceof DataView) {
127
+ return data;
128
+ }
129
+ if (ArrayBuffer.isView(data)) {
130
+ return new DataView(data.buffer);
131
+ }
132
+ // TODO: make these functions work for Node.js buffers?
133
+ // if (bufferToArrayBuffer) {
134
+ // data = bufferToArrayBuffer(data);
135
+ // }
136
+ // Careful - Node Buffers will look like ArrayBuffers (keep after isBuffer)
137
+ if (data instanceof ArrayBuffer) {
138
+ return new DataView(data);
139
+ }
140
+ throw new Error('toDataView');
141
+ }
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Check if image MIME type is supported. Result is cached.
3
+ */
4
+ export declare function _isImageFormatSupported(mimeType: string): boolean;
5
+ //# sourceMappingURL=image-format.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"image-format.d.ts","sourceRoot":"","sources":["../../../src/lib/category-api/image-format.ts"],"names":[],"mappings":"AAQA;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAKjE"}
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports._isImageFormatSupported = void 0;
4
+ const loader_utils_1 = require("@loaders.gl/loader-utils");
5
+ // The following formats are supported by loaders.gl polyfills
6
+ const NODE_FORMAT_SUPPORT = ['image/png', 'image/jpeg', 'image/gif'];
7
+ /** Cache values for speed */
8
+ const mimeTypeSupported = {};
9
+ /**
10
+ * Check if image MIME type is supported. Result is cached.
11
+ */
12
+ function _isImageFormatSupported(mimeType) {
13
+ if (mimeTypeSupported[mimeType] === undefined) {
14
+ mimeTypeSupported[mimeType] = checkFormatSupport(mimeType);
15
+ }
16
+ return mimeTypeSupported[mimeType];
17
+ }
18
+ exports._isImageFormatSupported = _isImageFormatSupported;
19
+ /**
20
+ * Check if image MIME type is supported.
21
+ */
22
+ function checkFormatSupport(mimeType) {
23
+ switch (mimeType) {
24
+ case 'image/webp':
25
+ return checkWebPSupport();
26
+ case 'image/svg':
27
+ return loader_utils_1.isBrowser;
28
+ default:
29
+ if (!loader_utils_1.isBrowser) {
30
+ // @ts-ignore
31
+ const { _parseImageNode } = globalThis;
32
+ return Boolean(_parseImageNode) && NODE_FORMAT_SUPPORT.includes(mimeType);
33
+ }
34
+ return true;
35
+ }
36
+ }
37
+ /** Check WebPSupport synchronously */
38
+ function checkWebPSupport() {
39
+ if (!loader_utils_1.isBrowser) {
40
+ return false;
41
+ }
42
+ try {
43
+ const element = document.createElement('canvas');
44
+ return element.toDataURL('image/webp').indexOf('data:image/webp') === 0;
45
+ }
46
+ catch {
47
+ // Probably Safari...
48
+ return false;
49
+ }
50
+ }
51
+ // Note: better test but asynchronous
52
+ // Lossy test image. Support for lossy images doesn't guarantee support for all WebP images.
53
+ // https://stackoverflow.com/questions/5573096/detecting-webp-support
54
+ // const WEBP_TEST_IMAGE = 'data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA';
55
+ // Check WebPSupport asynchronously
56
+ // async function isWebPSupported() {
57
+ // return new Promise( resolve => {
58
+ // const image = new Image();
59
+ // image.src = WEBP_TEST_IMAGE;
60
+ // image.onload = image.onerror = function () {
61
+ // resolve( image.height === 1 );
62
+ // }
63
+ // }
@@ -0,0 +1,12 @@
1
+ import type { ImageTypeEnum } from '../../types';
2
+ /**
3
+ * Checks if a loaders.gl image type is supported
4
+ * @param type image type string
5
+ */
6
+ export declare function isImageTypeSupported(type: string): boolean;
7
+ /**
8
+ * Returns the "most performant" supported image type on this platform
9
+ * @returns image type string
10
+ */
11
+ export declare function getDefaultImageType(): ImageTypeEnum;
12
+ //# sourceMappingURL=image-type.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"image-type.d.ts","sourceRoot":"","sources":["../../../src/lib/category-api/image-type.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,aAAa,CAAC;AAU/C;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAgB1D;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,IAAI,aAAa,CAanD"}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getDefaultImageType = exports.isImageTypeSupported = void 0;
4
+ const loader_utils_1 = require("@loaders.gl/loader-utils");
5
+ // @ts-ignore TS2339: Property does not exist on type
6
+ const { _parseImageNode } = globalThis;
7
+ const IMAGE_SUPPORTED = typeof Image !== 'undefined'; // NOTE: "false" positives if jsdom is installed
8
+ const IMAGE_BITMAP_SUPPORTED = typeof ImageBitmap !== 'undefined';
9
+ const NODE_IMAGE_SUPPORTED = Boolean(_parseImageNode);
10
+ const DATA_SUPPORTED = loader_utils_1.isBrowser ? true : NODE_IMAGE_SUPPORTED;
11
+ /**
12
+ * Checks if a loaders.gl image type is supported
13
+ * @param type image type string
14
+ */
15
+ function isImageTypeSupported(type) {
16
+ switch (type) {
17
+ case 'auto':
18
+ // Should only ever be false in Node.js, if polyfills have not been installed...
19
+ return IMAGE_BITMAP_SUPPORTED || IMAGE_SUPPORTED || DATA_SUPPORTED;
20
+ case 'imagebitmap':
21
+ return IMAGE_BITMAP_SUPPORTED;
22
+ case 'image':
23
+ return IMAGE_SUPPORTED;
24
+ case 'data':
25
+ return DATA_SUPPORTED;
26
+ default:
27
+ throw new Error(`@loaders.gl/images: image ${type} not supported in this environment`);
28
+ }
29
+ }
30
+ exports.isImageTypeSupported = isImageTypeSupported;
31
+ /**
32
+ * Returns the "most performant" supported image type on this platform
33
+ * @returns image type string
34
+ */
35
+ function getDefaultImageType() {
36
+ if (IMAGE_BITMAP_SUPPORTED) {
37
+ return 'imagebitmap';
38
+ }
39
+ if (IMAGE_SUPPORTED) {
40
+ return 'image';
41
+ }
42
+ if (DATA_SUPPORTED) {
43
+ return 'data';
44
+ }
45
+ // This should only happen in Node.js
46
+ throw new Error('Install \'@loaders.gl/polyfills\' to parse images under Node.js');
47
+ }
48
+ exports.getDefaultImageType = getDefaultImageType;
@@ -0,0 +1,10 @@
1
+ import type { ImageType, ImageTypeEnum, ImageDataType } from '../../types';
2
+ export declare function isImage(image: ImageType): boolean;
3
+ export declare function deleteImage(image: ImageType): void;
4
+ export declare function getImageType(image: ImageType): ImageTypeEnum;
5
+ export declare function getImageSize(image: ImageType): {
6
+ width: number;
7
+ height: number;
8
+ };
9
+ export declare function getImageData(image: ImageType): ImageDataType | ImageData;
10
+ //# sourceMappingURL=parsed-image-api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parsed-image-api.d.ts","sourceRoot":"","sources":["../../../src/lib/category-api/parsed-image-api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,SAAS,EAAE,aAAa,EAAE,aAAa,EAAC,MAAM,aAAa,CAAC;AAEzE,wBAAgB,OAAO,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAEjD;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAQlD;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,SAAS,GAAG,aAAa,CAM5D;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,SAAS,GAAG;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAC,CAE9E;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,SAAS,GAAG,aAAa,GAAG,SAAS,CA0BxE"}
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getImageData = exports.getImageSize = exports.getImageType = exports.deleteImage = exports.isImage = void 0;
4
+ function isImage(image) {
5
+ return Boolean(getImageTypeOrNull(image));
6
+ }
7
+ exports.isImage = isImage;
8
+ function deleteImage(image) {
9
+ switch (getImageType(image)) {
10
+ case 'imagebitmap':
11
+ image.close();
12
+ break;
13
+ default:
14
+ // Nothing to do for images and image data objects
15
+ }
16
+ }
17
+ exports.deleteImage = deleteImage;
18
+ function getImageType(image) {
19
+ const format = getImageTypeOrNull(image);
20
+ if (!format) {
21
+ throw new Error('Not an image');
22
+ }
23
+ return format;
24
+ }
25
+ exports.getImageType = getImageType;
26
+ function getImageSize(image) {
27
+ return getImageData(image);
28
+ }
29
+ exports.getImageSize = getImageSize;
30
+ function getImageData(image) {
31
+ switch (getImageType(image)) {
32
+ case 'data':
33
+ return image;
34
+ case 'image':
35
+ case 'imagebitmap':
36
+ // Extract the image data from the image via a canvas
37
+ const canvas = document.createElement('canvas');
38
+ // TODO - reuse the canvas?
39
+ const context = canvas.getContext('2d');
40
+ if (!context) {
41
+ throw new Error('getImageData');
42
+ }
43
+ // @ts-ignore
44
+ canvas.width = image.width;
45
+ // @ts-ignore
46
+ canvas.height = image.height;
47
+ // @ts-ignore
48
+ context.drawImage(image, 0, 0);
49
+ // @ts-ignore
50
+ return context.getImageData(0, 0, image.width, image.height);
51
+ default:
52
+ throw new Error('getImageData');
53
+ }
54
+ }
55
+ exports.getImageData = getImageData;
56
+ // PRIVATE
57
+ // eslint-disable-next-line complexity
58
+ function getImageTypeOrNull(image) {
59
+ if (typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
60
+ return 'imagebitmap';
61
+ }
62
+ if (typeof Image !== 'undefined' && image instanceof Image) {
63
+ return 'image';
64
+ }
65
+ if (image && typeof image === 'object' && image.data && image.width && image.height) {
66
+ return 'data';
67
+ }
68
+ return null;
69
+ }