@loaders.gl/images 4.0.0-alpha.5 → 4.0.0-alpha.6
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.js +2 -2
- package/dist/dist.min.js +1 -1
- package/dist/dist.min.js.map +3 -3
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/image-loader.js +33 -0
- package/dist/es5/image-loader.js.map +1 -0
- package/dist/es5/image-writer.js +24 -0
- package/dist/es5/image-writer.js.map +1 -0
- package/dist/es5/index.js +85 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/lib/category-api/binary-image-api.js +113 -0
- package/dist/es5/lib/category-api/binary-image-api.js.map +1 -0
- package/dist/es5/lib/category-api/image-format.js +181 -0
- package/dist/es5/lib/category-api/image-format.js.map +1 -0
- package/dist/es5/lib/category-api/image-type.js +40 -0
- package/dist/es5/lib/category-api/image-type.js.map +1 -0
- package/dist/es5/lib/category-api/parse-isobmff-binary.js +50 -0
- package/dist/es5/lib/category-api/parse-isobmff-binary.js.map +1 -0
- package/dist/es5/lib/category-api/parsed-image-api.js +65 -0
- package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -0
- package/dist/es5/lib/encoders/encode-image.js +101 -0
- package/dist/es5/lib/encoders/encode-image.js.map +1 -0
- package/dist/es5/lib/parsers/parse-image.js +76 -0
- package/dist/es5/lib/parsers/parse-image.js.map +1 -0
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js +97 -0
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -0
- package/dist/es5/lib/parsers/parse-to-image.js +86 -0
- package/dist/es5/lib/parsers/parse-to-image.js.map +1 -0
- package/dist/es5/lib/parsers/parse-to-node-image.js +36 -0
- package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -0
- package/dist/es5/lib/parsers/svg-utils.js +36 -0
- package/dist/es5/lib/parsers/svg-utils.js.map +1 -0
- package/dist/es5/lib/texture-api/async-deep-map.js +156 -0
- package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -0
- package/dist/es5/lib/texture-api/deep-load.js +63 -0
- package/dist/es5/lib/texture-api/deep-load.js.map +1 -0
- package/dist/es5/lib/texture-api/generate-url.js +24 -0
- package/dist/es5/lib/texture-api/generate-url.js.map +1 -0
- package/dist/es5/lib/texture-api/load-image.js +132 -0
- package/dist/es5/lib/texture-api/load-image.js.map +1 -0
- package/dist/es5/lib/utils/version.js +9 -0
- package/dist/es5/lib/utils/version.js.map +1 -0
- package/dist/es5/types.js +2 -0
- package/dist/es5/types.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/image-loader.js +23 -0
- package/dist/esm/image-loader.js.map +1 -0
- package/dist/esm/image-writer.js +17 -0
- package/dist/esm/image-writer.js.map +1 -0
- package/dist/esm/index.js +9 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/category-api/binary-image-api.js +107 -0
- package/dist/esm/lib/category-api/binary-image-api.js.map +1 -0
- package/dist/esm/lib/category-api/image-format.js +67 -0
- package/dist/esm/lib/category-api/image-format.js.map +1 -0
- package/dist/esm/lib/category-api/image-type.js +35 -0
- package/dist/esm/lib/category-api/image-type.js.map +1 -0
- package/dist/esm/lib/category-api/parse-isobmff-binary.js +39 -0
- package/dist/esm/lib/category-api/parse-isobmff-binary.js.map +1 -0
- package/dist/esm/lib/category-api/parsed-image-api.js +53 -0
- package/dist/esm/lib/category-api/parsed-image-api.js.map +1 -0
- package/dist/esm/lib/encoders/encode-image.js +62 -0
- package/dist/esm/lib/encoders/encode-image.js.map +1 -0
- package/dist/esm/lib/parsers/parse-image.js +44 -0
- package/dist/esm/lib/parsers/parse-image.js.map +1 -0
- package/dist/esm/lib/parsers/parse-to-image-bitmap.js +37 -0
- package/dist/esm/lib/parsers/parse-to-image-bitmap.js.map +1 -0
- package/dist/esm/lib/parsers/parse-to-image.js +30 -0
- package/dist/esm/lib/parsers/parse-to-image.js.map +1 -0
- package/dist/esm/lib/parsers/parse-to-node-image.js +11 -0
- package/dist/esm/lib/parsers/parse-to-node-image.js.map +1 -0
- package/dist/esm/lib/parsers/svg-utils.js +28 -0
- package/dist/esm/lib/parsers/svg-utils.js.map +1 -0
- package/dist/esm/lib/texture-api/async-deep-map.js +34 -0
- package/dist/esm/lib/texture-api/async-deep-map.js.map +1 -0
- package/dist/esm/lib/texture-api/deep-load.js +10 -0
- package/dist/esm/lib/texture-api/deep-load.js.map +1 -0
- package/dist/esm/lib/texture-api/generate-url.js +19 -0
- package/dist/esm/lib/texture-api/generate-url.js.map +1 -0
- package/dist/esm/lib/texture-api/load-image.js +51 -0
- package/dist/esm/lib/texture-api/load-image.js.map +1 -0
- package/dist/esm/lib/utils/version.js +2 -0
- package/dist/esm/lib/utils/version.js.map +1 -0
- package/dist/esm/types.js +2 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/image-loader.d.ts +3 -14
- package/dist/image-loader.d.ts.map +1 -1
- package/dist/image-loader.js +41 -21
- package/dist/image-writer.d.ts +8 -13
- package/dist/image-writer.d.ts.map +1 -1
- package/dist/image-writer.js +20 -16
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +29 -8
- package/dist/lib/category-api/binary-image-api.d.ts +3 -7
- package/dist/lib/category-api/binary-image-api.d.ts.map +1 -1
- package/dist/lib/category-api/binary-image-api.js +145 -102
- package/dist/lib/category-api/image-format.d.ts +4 -2
- package/dist/lib/category-api/image-format.d.ts.map +1 -1
- package/dist/lib/category-api/image-format.js +107 -41
- package/dist/lib/category-api/image-type.js +44 -38
- package/dist/lib/category-api/parse-isobmff-binary.d.ts +19 -0
- package/dist/lib/category-api/parse-isobmff-binary.d.ts.map +1 -0
- package/dist/lib/category-api/parse-isobmff-binary.js +94 -0
- package/dist/lib/category-api/parsed-image-api.js +62 -57
- package/dist/lib/encoders/encode-image.d.ts +2 -1
- package/dist/lib/encoders/encode-image.d.ts.map +1 -1
- package/dist/lib/encoders/encode-image.js +72 -60
- package/dist/lib/parsers/parse-image.js +54 -49
- package/dist/lib/parsers/parse-to-image-bitmap.js +53 -35
- package/dist/lib/parsers/parse-to-image.js +43 -30
- package/dist/lib/parsers/parse-to-node-image.js +13 -10
- package/dist/lib/parsers/svg-utils.js +36 -26
- package/dist/lib/texture-api/async-deep-map.js +49 -32
- package/dist/lib/texture-api/deep-load.js +13 -8
- package/dist/lib/texture-api/generate-url.js +19 -21
- package/dist/lib/texture-api/load-image.js +42 -47
- package/dist/lib/utils/version.js +7 -2
- package/dist/types.d.ts +3 -3
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +2 -2
- package/package.json +8 -5
- package/src/image-loader.ts +5 -4
- package/src/image-writer.ts +13 -2
- package/src/index.ts +3 -2
- package/src/lib/category-api/binary-image-api.ts +25 -6
- package/src/lib/category-api/image-format.ts +92 -39
- package/src/lib/category-api/parse-isobmff-binary.ts +105 -0
- package/src/lib/encoders/encode-image.ts +2 -1
- package/src/types.ts +1 -1
- package/dist/bundle.js.map +0 -1
- package/dist/image-loader.js.map +0 -1
- package/dist/image-writer.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/lib/category-api/binary-image-api.js.map +0 -1
- package/dist/lib/category-api/image-format.js.map +0 -1
- package/dist/lib/category-api/image-type.js.map +0 -1
- package/dist/lib/category-api/parsed-image-api.js.map +0 -1
- package/dist/lib/encoders/encode-image.js.map +0 -1
- package/dist/lib/parsers/parse-image.js.map +0 -1
- package/dist/lib/parsers/parse-to-image-bitmap.js.map +0 -1
- package/dist/lib/parsers/parse-to-image.js.map +0 -1
- package/dist/lib/parsers/parse-to-node-image.js.map +0 -1
- package/dist/lib/parsers/svg-utils.js.map +0 -1
- package/dist/lib/texture-api/async-deep-map.js.map +0 -1
- package/dist/lib/texture-api/deep-load.js.map +0 -1
- package/dist/lib/texture-api/generate-url.js.map +0 -1
- package/dist/lib/texture-api/load-image.js.map +0 -1
- package/dist/lib/utils/version.js.map +0 -1
- package/dist/types.js.map +0 -1
|
@@ -1,42 +1,48 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
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
|
|
6
8
|
const IMAGE_BITMAP_SUPPORTED = typeof ImageBitmap !== 'undefined';
|
|
7
9
|
const NODE_IMAGE_SUPPORTED = Boolean(_parseImageNode);
|
|
8
|
-
const DATA_SUPPORTED = isBrowser ? true : NODE_IMAGE_SUPPORTED;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
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
|
+
}
|
|
26
29
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
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');
|
|
41
47
|
}
|
|
42
|
-
|
|
48
|
+
exports.getDefaultImageType = getDefaultImageType;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Box is a container format that can contain a variety of media related files,
|
|
3
|
+
* so we want to return information about which type of file is actually contained inside
|
|
4
|
+
*/
|
|
5
|
+
export type BoxFileType = {
|
|
6
|
+
extension: string;
|
|
7
|
+
mimeType: string;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* Tests if a buffer is in ISO base media file format (ISOBMFF) @see https://en.wikipedia.org/wiki/ISO_base_media_file_format
|
|
11
|
+
* (ISOBMFF is a media container standard based on the Apple QuickTime container format)
|
|
12
|
+
*/
|
|
13
|
+
export declare function getISOBMFFMediaType(buffer: Uint8Array): BoxFileType | null;
|
|
14
|
+
/**
|
|
15
|
+
* brands explained @see https://github.com/strukturag/libheif/issues/83
|
|
16
|
+
* code adapted from @see https://github.com/sindresorhus/file-type/blob/main/core.js#L489-L492
|
|
17
|
+
*/
|
|
18
|
+
export declare function decodeMajorBrand(buffer: Uint8Array): BoxFileType | null;
|
|
19
|
+
//# sourceMappingURL=parse-isobmff-binary.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-isobmff-binary.d.ts","sourceRoot":"","sources":["../../../src/lib/category-api/parse-isobmff-binary.ts"],"names":[],"mappings":"AAGA;;;GAGG;AACH,MAAM,MAAM,WAAW,GAAG;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAC,CAAC;AAEhE;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,UAAU,GAAG,WAAW,GAAG,IAAI,CAa1E;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,UAAU,GAAG,WAAW,GAAG,IAAI,CAmDvE"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
3
|
+
// code adapted from https://github.com/sindresorhus/file-type under MIT license
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.decodeMajorBrand = exports.getISOBMFFMediaType = void 0;
|
|
6
|
+
/**
|
|
7
|
+
* Tests if a buffer is in ISO base media file format (ISOBMFF) @see https://en.wikipedia.org/wiki/ISO_base_media_file_format
|
|
8
|
+
* (ISOBMFF is a media container standard based on the Apple QuickTime container format)
|
|
9
|
+
*/
|
|
10
|
+
function getISOBMFFMediaType(buffer) {
|
|
11
|
+
// Almost all ISO base media files start with `ftyp` box. (It's not required to be first, but it's recommended to be.)
|
|
12
|
+
if (!checkString(buffer, 'ftyp', 4)) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
// Extra check: test for 8859-1 printable characters (for simplicity, it's a mask which also catches one non-printable character).
|
|
16
|
+
if ((buffer[8] & 0x60) === 0x00) {
|
|
17
|
+
return null;
|
|
18
|
+
}
|
|
19
|
+
// `ftyp` box must contain a brand major identifier, which must consist of ISO 8859-1 printable characters.
|
|
20
|
+
return decodeMajorBrand(buffer);
|
|
21
|
+
}
|
|
22
|
+
exports.getISOBMFFMediaType = getISOBMFFMediaType;
|
|
23
|
+
/**
|
|
24
|
+
* brands explained @see https://github.com/strukturag/libheif/issues/83
|
|
25
|
+
* code adapted from @see https://github.com/sindresorhus/file-type/blob/main/core.js#L489-L492
|
|
26
|
+
*/
|
|
27
|
+
function decodeMajorBrand(buffer) {
|
|
28
|
+
const brandMajor = getUTF8String(buffer, 8, 12).replace('\0', ' ').trim();
|
|
29
|
+
switch (brandMajor) {
|
|
30
|
+
case 'avif':
|
|
31
|
+
case 'avis':
|
|
32
|
+
return { extension: 'avif', mimeType: 'image/avif' };
|
|
33
|
+
default:
|
|
34
|
+
return null;
|
|
35
|
+
}
|
|
36
|
+
// We don't need these now, but they are easy to add
|
|
37
|
+
// case 'mif1':
|
|
38
|
+
// return {extension: 'heic', mimeType: 'image/heif'};
|
|
39
|
+
// case 'msf1':
|
|
40
|
+
// return {extension: 'heic', mimeType: 'image/heif-sequence'};
|
|
41
|
+
// case 'heic':
|
|
42
|
+
// case 'heix':
|
|
43
|
+
// return {extension: 'heic', mimeType: 'image/heic'};
|
|
44
|
+
// case 'hevc':
|
|
45
|
+
// case 'hevx':
|
|
46
|
+
// return {extension: 'heic', mimeType: 'image/heic-sequence'};
|
|
47
|
+
// case 'qt':
|
|
48
|
+
// return {ext: 'mov', mime: 'video/quicktime'};
|
|
49
|
+
// case 'M4V':
|
|
50
|
+
// case 'M4VH':
|
|
51
|
+
// case 'M4VP':
|
|
52
|
+
// return {ext: 'm4v', mime: 'video/x-m4v'};
|
|
53
|
+
// case 'M4P':
|
|
54
|
+
// return {ext: 'm4p', mime: 'video/mp4'};
|
|
55
|
+
// case 'M4B':
|
|
56
|
+
// return {ext: 'm4b', mime: 'audio/mp4'};
|
|
57
|
+
// case 'M4A':
|
|
58
|
+
// return {ext: 'm4a', mime: 'audio/x-m4a'};
|
|
59
|
+
// case 'F4V':
|
|
60
|
+
// return {ext: 'f4v', mime: 'video/mp4'};
|
|
61
|
+
// case 'F4P':
|
|
62
|
+
// return {ext: 'f4p', mime: 'video/mp4'};
|
|
63
|
+
// case 'F4A':
|
|
64
|
+
// return {ext: 'f4a', mime: 'audio/mp4'};
|
|
65
|
+
// case 'F4B':
|
|
66
|
+
// return {ext: 'f4b', mime: 'audio/mp4'};
|
|
67
|
+
// case 'crx':
|
|
68
|
+
// return {ext: 'cr3', mime: 'image/x-canon-cr3'};
|
|
69
|
+
// default:
|
|
70
|
+
// if (brandMajor.startsWith('3g')) {
|
|
71
|
+
// if (brandMajor.startsWith('3g2')) {
|
|
72
|
+
// return {ext: '3g2', mime: 'video/3gpp2'};
|
|
73
|
+
// }
|
|
74
|
+
// return {ext: '3gp', mime: 'video/3gpp'};
|
|
75
|
+
// }
|
|
76
|
+
// return {ext: 'mp4', mime: 'video/mp4'};
|
|
77
|
+
}
|
|
78
|
+
exports.decodeMajorBrand = decodeMajorBrand;
|
|
79
|
+
/** Interpret a chunk of bytes as a UTF8 string */
|
|
80
|
+
function getUTF8String(array, start, end) {
|
|
81
|
+
return String.fromCharCode(...array.slice(start, end));
|
|
82
|
+
}
|
|
83
|
+
function stringToBytes(string) {
|
|
84
|
+
return [...string].map((character) => character.charCodeAt(0));
|
|
85
|
+
}
|
|
86
|
+
function checkString(buffer, header, offset = 0) {
|
|
87
|
+
const headerBytes = stringToBytes(header);
|
|
88
|
+
for (let i = 0; i < headerBytes.length; ++i) {
|
|
89
|
+
if (headerBytes[i] !== buffer[i + offset]) {
|
|
90
|
+
return false;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return true;
|
|
94
|
+
}
|
|
@@ -1,64 +1,69 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
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));
|
|
3
6
|
}
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
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
|
+
}
|
|
12
16
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
return format;
|
|
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;
|
|
21
24
|
}
|
|
22
|
-
|
|
23
|
-
|
|
25
|
+
exports.getImageType = getImageType;
|
|
26
|
+
function getImageSize(image) {
|
|
27
|
+
return getImageData(image);
|
|
24
28
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
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
|
+
}
|
|
47
54
|
}
|
|
48
|
-
|
|
55
|
+
exports.getImageData = getImageData;
|
|
56
|
+
// PRIVATE
|
|
57
|
+
// eslint-disable-next-line complexity
|
|
49
58
|
function getImageTypeOrNull(image) {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
return
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
return null;
|
|
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;
|
|
63
69
|
}
|
|
64
|
-
//# sourceMappingURL=parsed-image-api.js.map
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { ImageDataType } from '../../types';
|
|
1
2
|
/**
|
|
2
3
|
* Returns data bytes representing a compressed image in PNG or JPG format,
|
|
3
4
|
* This data can be saved using file system (f) methods or used in a request.
|
|
@@ -6,7 +7,7 @@
|
|
|
6
7
|
* param opt.type='png' - png, jpg or image/png, image/jpg are valid
|
|
7
8
|
* param mimeType= - Whether to include a data URI header
|
|
8
9
|
*/
|
|
9
|
-
export declare function encodeImage(image:
|
|
10
|
+
export declare function encodeImage(image: ImageDataType, options?: {
|
|
10
11
|
[key: string]: any;
|
|
11
12
|
}): Promise<ArrayBuffer>;
|
|
12
13
|
//# sourceMappingURL=encode-image.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"encode-image.d.ts","sourceRoot":"","sources":["../../../src/lib/encoders/encode-image.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"encode-image.d.ts","sourceRoot":"","sources":["../../../src/lib/encoders/encode-image.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,aAAa,EAAC,MAAM,aAAa,CAAC;AAM1C;;;;;;;GAOG;AACH,wBAAsB,WAAW,CAC/B,KAAK,EAAE,aAAa,EACpB,OAAO,CAAC,EAAE;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CAAC,GAC7B,OAAO,CAAC,WAAW,CAAC,CAOtB"}
|
|
@@ -1,69 +1,81 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.encodeImage = void 0;
|
|
4
|
+
const parsed_image_api_1 = require("../category-api/parsed-image-api");
|
|
5
|
+
// @ts-ignore TS2339: Property does not exist on type
|
|
6
|
+
const { _encodeImageNode } = globalThis;
|
|
7
|
+
/**
|
|
8
|
+
* Returns data bytes representing a compressed image in PNG or JPG format,
|
|
9
|
+
* This data can be saved using file system (f) methods or used in a request.
|
|
10
|
+
* @param image - ImageBitmap Image or Canvas
|
|
11
|
+
* @param options
|
|
12
|
+
* param opt.type='png' - png, jpg or image/png, image/jpg are valid
|
|
13
|
+
* param mimeType= - Whether to include a data URI header
|
|
14
|
+
*/
|
|
15
|
+
async function encodeImage(image, options) {
|
|
16
|
+
options = options || {};
|
|
17
|
+
options.image = options.image || {};
|
|
18
|
+
return _encodeImageNode
|
|
19
|
+
? _encodeImageNode(image, { type: options.image.mimeType })
|
|
20
|
+
: encodeImageInBrowser(image, options);
|
|
11
21
|
}
|
|
22
|
+
exports.encodeImage = encodeImage;
|
|
23
|
+
// In case we get exceptions from canvas.toBlob(resolve, type, quality)
|
|
12
24
|
let qualityParamSupported = true;
|
|
13
|
-
|
|
25
|
+
/**
|
|
26
|
+
*
|
|
27
|
+
* @param image
|
|
28
|
+
* @param options
|
|
29
|
+
* @note Based on canvas.toBlob
|
|
30
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob
|
|
31
|
+
*/
|
|
14
32
|
async function encodeImageInBrowser(image, options) {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
const { mimeType, jpegQuality } = options.image;
|
|
34
|
+
const { width, height } = (0, parsed_image_api_1.getImageSize)(image);
|
|
35
|
+
// create a canvas and resize it to the size of our image
|
|
36
|
+
const canvas = document.createElement('canvas');
|
|
37
|
+
canvas.width = width;
|
|
38
|
+
canvas.height = height;
|
|
39
|
+
drawImageToCanvas(image, canvas);
|
|
40
|
+
// The actual encoding is done asynchronously with `canvas.toBlob()`
|
|
41
|
+
const blob = await new Promise((resolve) => {
|
|
42
|
+
// get it back as a Blob
|
|
43
|
+
if (jpegQuality && qualityParamSupported) {
|
|
44
|
+
try {
|
|
45
|
+
canvas.toBlob(resolve, mimeType, jpegQuality);
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
qualityParamSupported = false;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
canvas.toBlob(resolve, mimeType);
|
|
53
|
+
});
|
|
54
|
+
if (!blob) {
|
|
55
|
+
throw new Error('image encoding failed');
|
|
35
56
|
}
|
|
36
|
-
|
|
37
|
-
canvas.toBlob(resolve, mimeType);
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
if (!blob) {
|
|
41
|
-
throw new Error('image encoding failed');
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return await blob.arrayBuffer();
|
|
57
|
+
return await blob.arrayBuffer();
|
|
45
58
|
}
|
|
46
|
-
|
|
47
59
|
function drawImageToCanvas(image, canvas, x = 0, y = 0) {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
60
|
+
// Try optimized path for ImageBitmaps via bitmaprenderer context
|
|
61
|
+
if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
|
|
62
|
+
const context = canvas.getContext('bitmaprenderer');
|
|
63
|
+
if (context) {
|
|
64
|
+
// transfer the ImageBitmap to it
|
|
65
|
+
context.transferFromImageBitmap(image);
|
|
66
|
+
return canvas;
|
|
67
|
+
}
|
|
54
68
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
69
|
+
// Available on most platforms, except IE11 and Andriod WebViews...
|
|
70
|
+
const context = canvas.getContext('2d');
|
|
71
|
+
if (image.data) {
|
|
72
|
+
// ImageData constructor expects clamped array even though getImageData does not return a clamped array...
|
|
73
|
+
const clampedArray = new Uint8ClampedArray(image.data);
|
|
74
|
+
const imageData = new ImageData(clampedArray, image.width, image.height);
|
|
75
|
+
context.putImageData(imageData, 0, 0);
|
|
76
|
+
return canvas;
|
|
77
|
+
}
|
|
78
|
+
// Fall back to generic image/image bitmap rendering path
|
|
79
|
+
context.drawImage(image, 0, 0);
|
|
63
80
|
return canvas;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
context.drawImage(image, 0, 0);
|
|
67
|
-
return canvas;
|
|
68
81
|
}
|
|
69
|
-
//# sourceMappingURL=encode-image.js.map
|
|
@@ -1,52 +1,57 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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
|
+
const loader_utils_1 = require("@loaders.gl/loader-utils");
|
|
7
|
+
const image_type_1 = require("../category-api/image-type");
|
|
8
|
+
const parsed_image_api_1 = require("../category-api/parsed-image-api");
|
|
9
|
+
const parse_to_image_1 = __importDefault(require("./parse-to-image"));
|
|
10
|
+
const parse_to_image_bitmap_1 = __importDefault(require("./parse-to-image-bitmap"));
|
|
11
|
+
const parse_to_node_image_1 = __importDefault(require("./parse-to-node-image"));
|
|
12
|
+
// Parse to platform defined image type (data on node, ImageBitmap or HTMLImage on browser)
|
|
13
|
+
// eslint-disable-next-line complexity
|
|
14
|
+
async function parseImage(arrayBuffer, options, context) {
|
|
15
|
+
options = options || {};
|
|
16
|
+
const imageOptions = options.image || {};
|
|
17
|
+
// The user can request a specific output format via `options.image.type`
|
|
18
|
+
const imageType = imageOptions.type || 'auto';
|
|
19
|
+
const { url } = context || {};
|
|
20
|
+
// Note: For options.image.type === `data`, we may still need to load as `image` or `imagebitmap`
|
|
21
|
+
const loadType = getLoadableImageType(imageType);
|
|
22
|
+
let image;
|
|
23
|
+
switch (loadType) {
|
|
24
|
+
case 'imagebitmap':
|
|
25
|
+
image = await (0, parse_to_image_bitmap_1.default)(arrayBuffer, options, url);
|
|
26
|
+
break;
|
|
27
|
+
case 'image':
|
|
28
|
+
image = await (0, parse_to_image_1.default)(arrayBuffer, options, url);
|
|
29
|
+
break;
|
|
30
|
+
case 'data':
|
|
31
|
+
// Node.js loads imagedata directly
|
|
32
|
+
image = await (0, parse_to_node_image_1.default)(arrayBuffer, options);
|
|
33
|
+
break;
|
|
34
|
+
default:
|
|
35
|
+
(0, loader_utils_1.assert)(false);
|
|
36
|
+
}
|
|
37
|
+
// Browser: if options.image.type === 'data', we can now extract data from the loaded image
|
|
38
|
+
if (imageType === 'data') {
|
|
39
|
+
image = (0, parsed_image_api_1.getImageData)(image);
|
|
40
|
+
}
|
|
41
|
+
return image;
|
|
39
42
|
}
|
|
40
|
-
|
|
43
|
+
exports.default = parseImage;
|
|
44
|
+
// Get a loadable image type from image type
|
|
41
45
|
function getLoadableImageType(type) {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
46
|
+
switch (type) {
|
|
47
|
+
case 'auto':
|
|
48
|
+
case 'data':
|
|
49
|
+
// Browser: For image data we need still need to load using an image format
|
|
50
|
+
// Node: the default image type is `data`.
|
|
51
|
+
return (0, image_type_1.getDefaultImageType)();
|
|
52
|
+
default:
|
|
53
|
+
// Throw an error if not supported
|
|
54
|
+
(0, image_type_1.isImageTypeSupported)(type);
|
|
55
|
+
return type;
|
|
56
|
+
}
|
|
51
57
|
}
|
|
52
|
-
//# sourceMappingURL=parse-image.js.map
|