@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.
- package/dist/bundle.d.ts +2 -0
- package/dist/bundle.d.ts.map +1 -0
- package/dist/bundle.js +5 -0
- package/dist/dist.min.js +2 -2
- package/dist/dist.min.js.map +7 -1
- package/dist/es5/bundle.js +1 -1
- package/dist/es5/bundle.js.map +1 -1
- package/dist/es5/image-loader.js +6 -8
- package/dist/es5/image-loader.js.map +1 -1
- package/dist/es5/image-writer.js +1 -1
- package/dist/es5/image-writer.js.map +1 -1
- package/dist/es5/index.js +11 -11
- package/dist/es5/lib/category-api/binary-image-api.js +22 -22
- package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
- package/dist/es5/lib/category-api/image-format.js +7 -5
- package/dist/es5/lib/category-api/image-format.js.map +1 -1
- package/dist/es5/lib/category-api/image-type.js +7 -5
- package/dist/es5/lib/category-api/image-type.js.map +1 -1
- package/dist/es5/lib/category-api/parsed-image-api.js +4 -8
- package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
- package/dist/es5/lib/encoders/encode-image.js +45 -97
- package/dist/es5/lib/encoders/encode-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-image.js +31 -66
- package/dist/es5/lib/parsers/parse-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js +26 -98
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-image.js +27 -93
- package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-node-image.js +7 -35
- package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
- package/dist/es5/lib/parsers/svg-utils.js +5 -5
- package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
- package/dist/es5/lib/texture-api/async-deep-map.js +27 -156
- package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
- package/dist/es5/lib/texture-api/deep-load.js +6 -67
- package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
- package/dist/es5/lib/texture-api/generate-url.js +7 -11
- package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
- package/dist/es5/lib/texture-api/load-image.js +39 -143
- package/dist/es5/lib/texture-api/load-image.js.map +1 -1
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/es5/lib/utils/version.js.map +1 -1
- package/dist/esm/lib/category-api/image-type.js +1 -1
- package/dist/esm/lib/category-api/image-type.js.map +1 -1
- package/dist/esm/lib/parsers/parse-to-image.js +1 -1
- package/dist/esm/lib/parsers/parse-to-image.js.map +1 -1
- package/dist/esm/lib/parsers/svg-utils.js +1 -1
- package/dist/esm/lib/parsers/svg-utils.js.map +1 -1
- package/dist/esm/lib/texture-api/generate-url.js +1 -1
- package/dist/esm/lib/texture-api/generate-url.js.map +1 -1
- package/dist/esm/lib/utils/version.js +1 -1
- package/dist/esm/lib/utils/version.js.map +1 -1
- package/dist/image-loader.d.ts +26 -0
- package/dist/image-loader.d.ts.map +1 -0
- package/dist/image-loader.js +43 -0
- package/dist/image-writer.d.ts +16 -0
- package/dist/image-writer.d.ts.map +1 -0
- package/dist/image-writer.js +20 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +27 -0
- package/dist/lib/category-api/binary-image-api.d.ts +19 -0
- package/dist/lib/category-api/binary-image-api.d.ts.map +1 -0
- package/dist/lib/category-api/binary-image-api.js +141 -0
- package/dist/lib/category-api/image-format.d.ts +5 -0
- package/dist/lib/category-api/image-format.d.ts.map +1 -0
- package/dist/lib/category-api/image-format.js +63 -0
- package/dist/lib/category-api/image-type.d.ts +12 -0
- package/dist/lib/category-api/image-type.d.ts.map +1 -0
- package/dist/lib/category-api/image-type.js +48 -0
- package/dist/lib/category-api/parsed-image-api.d.ts +10 -0
- package/dist/lib/category-api/parsed-image-api.d.ts.map +1 -0
- package/dist/lib/category-api/parsed-image-api.js +69 -0
- package/dist/lib/encoders/encode-image.d.ts +12 -0
- package/dist/lib/encoders/encode-image.d.ts.map +1 -0
- package/dist/lib/encoders/encode-image.js +82 -0
- package/dist/lib/parsers/parse-image.d.ts +5 -0
- package/dist/lib/parsers/parse-image.d.ts.map +1 -0
- package/dist/lib/parsers/parse-image.js +57 -0
- package/dist/lib/parsers/parse-to-image-bitmap.d.ts +10 -0
- package/dist/lib/parsers/parse-to-image-bitmap.d.ts.map +1 -0
- package/dist/lib/parsers/parse-to-image-bitmap.js +61 -0
- package/dist/lib/parsers/parse-to-image.d.ts +4 -0
- package/dist/lib/parsers/parse-to-image.d.ts.map +1 -0
- package/dist/lib/parsers/parse-to-image.js +47 -0
- package/dist/lib/parsers/parse-to-node-image.d.ts +4 -0
- package/dist/lib/parsers/parse-to-node-image.d.ts.map +1 -0
- package/dist/lib/parsers/parse-to-node-image.js +14 -0
- package/dist/lib/parsers/svg-utils.d.ts +4 -0
- package/dist/lib/parsers/svg-utils.d.ts.map +1 -0
- package/dist/lib/parsers/svg-utils.js +42 -0
- package/dist/lib/texture-api/async-deep-map.d.ts +3 -0
- package/dist/lib/texture-api/async-deep-map.d.ts.map +1 -0
- package/dist/lib/texture-api/async-deep-map.js +56 -0
- package/dist/lib/texture-api/deep-load.d.ts +3 -0
- package/dist/lib/texture-api/deep-load.d.ts.map +1 -0
- package/dist/lib/texture-api/deep-load.js +15 -0
- package/dist/lib/texture-api/generate-url.d.ts +2 -0
- package/dist/lib/texture-api/generate-url.d.ts.map +1 -0
- package/dist/lib/texture-api/generate-url.js +20 -0
- package/dist/lib/texture-api/load-image.d.ts +7 -0
- package/dist/lib/texture-api/load-image.d.ts.map +1 -0
- package/dist/lib/texture-api/load-image.js +47 -0
- package/dist/lib/utils/version.d.ts +2 -0
- package/dist/lib/utils/version.d.ts.map +1 -0
- package/dist/lib/utils/version.js +7 -0
- package/dist/types.d.ts +18 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- 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(
|
|
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,
|
|
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"}
|
|
@@ -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,
|
|
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] === '/' ?
|
|
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,
|
|
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-
|
|
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,
|
|
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
|
+
};
|
package/dist/index.d.ts
ADDED
|
@@ -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 @@
|
|
|
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
|
+
}
|