@loaders.gl/gltf 3.4.11 → 3.4.13

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 (40) hide show
  1. package/dist/es5/lib/utils/version.js +1 -1
  2. package/dist/esm/lib/utils/version.js +1 -1
  3. package/package.json +6 -6
  4. package/dist/bundle.js +0 -5
  5. package/dist/glb-loader.js +0 -39
  6. package/dist/glb-writer.js +0 -37
  7. package/dist/gltf-loader.js +0 -50
  8. package/dist/gltf-writer.js +0 -32
  9. package/dist/index.js +0 -23
  10. package/dist/lib/api/gltf-extensions.js +0 -83
  11. package/dist/lib/api/gltf-scenegraph.js +0 -566
  12. package/dist/lib/api/normalize-gltf-v1.js +0 -299
  13. package/dist/lib/api/post-process-gltf.js +0 -370
  14. package/dist/lib/encoders/encode-glb.js +0 -61
  15. package/dist/lib/encoders/encode-gltf.js +0 -27
  16. package/dist/lib/extensions/EXT_meshopt_compression.js +0 -45
  17. package/dist/lib/extensions/EXT_texture_webp.js +0 -39
  18. package/dist/lib/extensions/KHR_binary_gltf.js +0 -42
  19. package/dist/lib/extensions/KHR_draco_mesh_compression.js +0 -141
  20. package/dist/lib/extensions/KHR_texture_basisu.js +0 -32
  21. package/dist/lib/extensions/KHR_texture_transform.js +0 -230
  22. package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +0 -118
  23. package/dist/lib/extensions/deprecated/KHR_lights_punctual.js +0 -62
  24. package/dist/lib/extensions/deprecated/KHR_materials_unlit.js +0 -47
  25. package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js +0 -82
  26. package/dist/lib/gltf-utils/get-typed-array.js +0 -41
  27. package/dist/lib/gltf-utils/gltf-attribute-utils.js +0 -73
  28. package/dist/lib/gltf-utils/gltf-constants.js +0 -43
  29. package/dist/lib/gltf-utils/gltf-utils.js +0 -85
  30. package/dist/lib/gltf-utils/resolve-url.js +0 -18
  31. package/dist/lib/parsers/parse-glb.js +0 -141
  32. package/dist/lib/parsers/parse-gltf.js +0 -203
  33. package/dist/lib/types/glb-types.js +0 -2
  34. package/dist/lib/types/gltf-json-schema.js +0 -4
  35. package/dist/lib/types/gltf-postprocessed-schema.js +0 -4
  36. package/dist/lib/types/gltf-types.js +0 -3
  37. package/dist/lib/utils/assert.js +0 -12
  38. package/dist/lib/utils/version.js +0 -7
  39. package/dist/meshopt/meshopt-decoder.js +0 -118
  40. package/dist/webp/webp.js +0 -38
@@ -1,141 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isGLB = void 0;
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- const MAGIC_glTF = 0x676c5446; // glTF in Big-Endian ASCII
6
- const GLB_FILE_HEADER_SIZE = 12;
7
- const GLB_CHUNK_HEADER_SIZE = 8;
8
- const GLB_CHUNK_TYPE_JSON = 0x4e4f534a;
9
- const GLB_CHUNK_TYPE_BIN = 0x004e4942;
10
- const GLB_CHUNK_TYPE_JSON_XVIZ_DEPRECATED = 0; // DEPRECATED - Backward compatibility for old xviz files
11
- const GLB_CHUNK_TYPE_BIX_XVIZ_DEPRECATED = 1; // DEPRECATED - Backward compatibility for old xviz files
12
- const GLB_V1_CONTENT_FORMAT_JSON = 0x0;
13
- const LE = true; // Binary GLTF is little endian.
14
- function getMagicString(dataView, byteOffset = 0) {
15
- return `\
16
- ${String.fromCharCode(dataView.getUint8(byteOffset + 0))}\
17
- ${String.fromCharCode(dataView.getUint8(byteOffset + 1))}\
18
- ${String.fromCharCode(dataView.getUint8(byteOffset + 2))}\
19
- ${String.fromCharCode(dataView.getUint8(byteOffset + 3))}`;
20
- }
21
- // Check if a data view is a GLB
22
- function isGLB(arrayBuffer, byteOffset = 0, options = {}) {
23
- const dataView = new DataView(arrayBuffer);
24
- // Check that GLB Header starts with the magic number
25
- const { magic = MAGIC_glTF } = options;
26
- const magic1 = dataView.getUint32(byteOffset, false);
27
- return magic1 === magic || magic1 === MAGIC_glTF;
28
- }
29
- exports.isGLB = isGLB;
30
- function parseGLBSync(glb, arrayBuffer, byteOffset = 0, options = {}) {
31
- // Check that GLB Header starts with the magic number
32
- const dataView = new DataView(arrayBuffer);
33
- // Compare format with GLBLoader documentation
34
- const type = getMagicString(dataView, byteOffset + 0);
35
- const version = dataView.getUint32(byteOffset + 4, LE); // Version 2 of binary glTF container format
36
- const byteLength = dataView.getUint32(byteOffset + 8, LE); // Total byte length of binary file
37
- Object.assign(glb, {
38
- // Put less important stuff in a header, to avoid clutter
39
- header: {
40
- byteOffset,
41
- byteLength,
42
- hasBinChunk: false
43
- },
44
- type,
45
- version,
46
- json: {},
47
- binChunks: []
48
- });
49
- byteOffset += GLB_FILE_HEADER_SIZE;
50
- switch (glb.version) {
51
- case 1:
52
- // eslint-disable-next-line
53
- return parseGLBV1(glb, dataView, byteOffset);
54
- case 2:
55
- // eslint-disable-next-line
56
- return parseGLBV2(glb, dataView, byteOffset, (options = {}));
57
- default:
58
- throw new Error(`Invalid GLB version ${glb.version}. Only supports v1 and v2.`);
59
- }
60
- }
61
- exports.default = parseGLBSync;
62
- function parseGLBV1(glb, dataView, byteOffset) {
63
- // Sanity: ensure file is big enough to hold at least the headers
64
- (0, loader_utils_1.assert)(glb.header.byteLength > GLB_FILE_HEADER_SIZE + GLB_CHUNK_HEADER_SIZE);
65
- // Explanation of GLB structure:
66
- // https://cloud.githubusercontent.com/assets/3479527/22600725/36b87122-ea55-11e6-9d40-6fd42819fcab.png
67
- const contentLength = dataView.getUint32(byteOffset + 0, LE); // Byte length of chunk
68
- const contentFormat = dataView.getUint32(byteOffset + 4, LE); // Chunk format as uint32
69
- byteOffset += GLB_CHUNK_HEADER_SIZE;
70
- // GLB v1 only supports a single chunk type
71
- (0, loader_utils_1.assert)(contentFormat === GLB_V1_CONTENT_FORMAT_JSON);
72
- parseJSONChunk(glb, dataView, byteOffset, contentLength);
73
- // No need to call the function padToBytes() from parseJSONChunk()
74
- byteOffset += contentLength;
75
- byteOffset += parseBINChunk(glb, dataView, byteOffset, glb.header.byteLength);
76
- return byteOffset;
77
- }
78
- function parseGLBV2(glb, dataView, byteOffset, options) {
79
- // Sanity: ensure file is big enough to hold at least the first chunk header
80
- (0, loader_utils_1.assert)(glb.header.byteLength > GLB_FILE_HEADER_SIZE + GLB_CHUNK_HEADER_SIZE);
81
- parseGLBChunksSync(glb, dataView, byteOffset, options);
82
- return byteOffset + glb.header.byteLength;
83
- }
84
- function parseGLBChunksSync(glb, dataView, byteOffset, options) {
85
- // Per spec we must iterate over chunks, ignoring all except JSON and BIN
86
- // Iterate as long as there is space left for another chunk header
87
- while (byteOffset + 8 <= glb.header.byteLength) {
88
- const chunkLength = dataView.getUint32(byteOffset + 0, LE); // Byte length of chunk
89
- const chunkFormat = dataView.getUint32(byteOffset + 4, LE); // Chunk format as uint32
90
- byteOffset += GLB_CHUNK_HEADER_SIZE;
91
- // Per spec we must iterate over chunks, ignoring all except JSON and BIN
92
- switch (chunkFormat) {
93
- case GLB_CHUNK_TYPE_JSON:
94
- parseJSONChunk(glb, dataView, byteOffset, chunkLength);
95
- break;
96
- case GLB_CHUNK_TYPE_BIN:
97
- parseBINChunk(glb, dataView, byteOffset, chunkLength);
98
- break;
99
- // Backward compatibility for very old xviz files
100
- case GLB_CHUNK_TYPE_JSON_XVIZ_DEPRECATED:
101
- if (!options.strict) {
102
- parseJSONChunk(glb, dataView, byteOffset, chunkLength);
103
- }
104
- break;
105
- case GLB_CHUNK_TYPE_BIX_XVIZ_DEPRECATED:
106
- if (!options.strict) {
107
- parseBINChunk(glb, dataView, byteOffset, chunkLength);
108
- }
109
- break;
110
- default:
111
- // Ignore, per spec
112
- // console.warn(`Unknown GLB chunk type`); // eslint-disable-line
113
- break;
114
- }
115
- byteOffset += (0, loader_utils_1.padToNBytes)(chunkLength, 4);
116
- }
117
- return byteOffset;
118
- }
119
- // Parse a GLB JSON chunk
120
- function parseJSONChunk(glb, dataView, byteOffset, chunkLength) {
121
- // 1. Create a "view" of the binary encoded JSON data inside the GLB
122
- const jsonChunk = new Uint8Array(dataView.buffer, byteOffset, chunkLength);
123
- // 2. Decode the JSON binary array into clear text
124
- const textDecoder = new TextDecoder('utf8');
125
- const jsonText = textDecoder.decode(jsonChunk);
126
- // 3. Parse the JSON text into a JavaScript data structure
127
- glb.json = JSON.parse(jsonText);
128
- return (0, loader_utils_1.padToNBytes)(chunkLength, 4);
129
- }
130
- // Parse a GLB BIN chunk
131
- function parseBINChunk(glb, dataView, byteOffset, chunkLength) {
132
- // Note: BIN chunk can be optional
133
- glb.header.hasBinChunk = true;
134
- glb.binChunks.push({
135
- byteOffset,
136
- byteLength: chunkLength,
137
- arrayBuffer: dataView.buffer
138
- // TODO - copy, or create typed array view?
139
- });
140
- return (0, loader_utils_1.padToNBytes)(chunkLength, 4);
141
- }
@@ -1,203 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.parseGLTF = exports.isGLTF = void 0;
27
- const textures_1 = require("@loaders.gl/textures");
28
- const images_1 = require("@loaders.gl/images");
29
- const loader_utils_1 = require("@loaders.gl/loader-utils");
30
- const assert_1 = require("../utils/assert");
31
- const resolve_url_1 = require("../gltf-utils/resolve-url");
32
- const get_typed_array_1 = require("../gltf-utils/get-typed-array");
33
- const gltf_extensions_1 = require("../api/gltf-extensions");
34
- const normalize_gltf_v1_1 = require("../api/normalize-gltf-v1");
35
- const post_process_gltf_1 = require("../api/post-process-gltf");
36
- const parse_glb_1 = __importStar(require("./parse-glb"));
37
- // export type GLTFOptions = {
38
- // gltf?: GLTFParseOptions;
39
- // };
40
- function isGLTF(arrayBuffer, options) {
41
- const byteOffset = 0;
42
- return (0, parse_glb_1.isGLB)(arrayBuffer, byteOffset, options);
43
- }
44
- exports.isGLTF = isGLTF;
45
- async function parseGLTF(gltf, arrayBufferOrString, byteOffset = 0, options, context) {
46
- parseGLTFContainerSync(gltf, arrayBufferOrString, byteOffset, options);
47
- (0, normalize_gltf_v1_1.normalizeGLTFV1)(gltf, { normalize: options?.gltf?.normalize });
48
- (0, gltf_extensions_1.preprocessExtensions)(gltf, options, context);
49
- const promises = [];
50
- // Load linked buffers asynchronously and decodes base64 buffers in parallel
51
- if (options?.gltf?.loadBuffers && gltf.json.buffers) {
52
- await loadBuffers(gltf, options, context);
53
- }
54
- if (options?.gltf?.loadImages) {
55
- const promise = loadImages(gltf, options, context);
56
- promises.push(promise);
57
- }
58
- const promise = (0, gltf_extensions_1.decodeExtensions)(gltf, options, context);
59
- promises.push(promise);
60
- // Parallelize image loading and buffer loading/extension decoding
61
- await Promise.all(promises);
62
- // Post processing resolves indices to objects, buffers
63
- return options?.gltf?.postProcess ? (0, post_process_gltf_1.postProcessGLTF)(gltf, options) : gltf;
64
- }
65
- exports.parseGLTF = parseGLTF;
66
- // `data` - can be ArrayBuffer (GLB), ArrayBuffer (Binary JSON), String (JSON), or Object (parsed JSON)
67
- function parseGLTFContainerSync(gltf, data, byteOffset, options) {
68
- // Initialize gltf container
69
- if (options.uri) {
70
- gltf.baseUri = options.uri;
71
- }
72
- // If data is binary and starting with magic bytes, assume binary JSON text, convert to string
73
- if (data instanceof ArrayBuffer && !(0, parse_glb_1.isGLB)(data, byteOffset, options)) {
74
- const textDecoder = new TextDecoder();
75
- data = textDecoder.decode(data);
76
- }
77
- if (typeof data === 'string') {
78
- // If string, try to parse as JSON
79
- gltf.json = (0, loader_utils_1.parseJSON)(data);
80
- }
81
- else if (data instanceof ArrayBuffer) {
82
- // If still ArrayBuffer, parse as GLB container
83
- const glb = {};
84
- byteOffset = (0, parse_glb_1.default)(glb, data, byteOffset, options.glb);
85
- (0, assert_1.assert)(glb.type === 'glTF', `Invalid GLB magic string ${glb.type}`);
86
- gltf._glb = glb;
87
- gltf.json = glb.json;
88
- }
89
- else {
90
- (0, assert_1.assert)(false, 'GLTF: must be ArrayBuffer or string');
91
- }
92
- // Populate buffers
93
- // Create an external buffers array to hold binary data
94
- const buffers = gltf.json.buffers || [];
95
- gltf.buffers = new Array(buffers.length).fill(null);
96
- // Populates JSON and some bin chunk info
97
- if (gltf._glb && gltf._glb.header.hasBinChunk) {
98
- const { binChunks } = gltf._glb;
99
- gltf.buffers[0] = {
100
- arrayBuffer: binChunks[0].arrayBuffer,
101
- byteOffset: binChunks[0].byteOffset,
102
- byteLength: binChunks[0].byteLength
103
- };
104
- // TODO - this modifies JSON and is a post processing thing
105
- // gltf.json.buffers[0].data = gltf.buffers[0].arrayBuffer;
106
- // gltf.json.buffers[0].byteOffset = gltf.buffers[0].byteOffset;
107
- }
108
- // Populate images
109
- const images = gltf.json.images || [];
110
- gltf.images = new Array(images.length).fill({});
111
- }
112
- /** Asynchronously fetch and parse buffers, store in buffers array outside of json
113
- * TODO - traverse gltf and determine which buffers are actually needed
114
- */
115
- async function loadBuffers(gltf, options, context) {
116
- // TODO
117
- const buffers = gltf.json.buffers || [];
118
- for (let i = 0; i < buffers.length; ++i) {
119
- const buffer = buffers[i];
120
- if (buffer.uri) {
121
- const { fetch } = context;
122
- (0, assert_1.assert)(fetch);
123
- const uri = (0, resolve_url_1.resolveUrl)(buffer.uri, options);
124
- const response = await context?.fetch?.(uri);
125
- const arrayBuffer = await response?.arrayBuffer?.();
126
- gltf.buffers[i] = {
127
- arrayBuffer,
128
- byteOffset: 0,
129
- byteLength: arrayBuffer.byteLength
130
- };
131
- delete buffer.uri;
132
- }
133
- else if (gltf.buffers[i] === null) {
134
- gltf.buffers[i] = {
135
- arrayBuffer: new ArrayBuffer(buffer.byteLength),
136
- byteOffset: 0,
137
- byteLength: buffer.byteLength
138
- };
139
- }
140
- }
141
- }
142
- /**
143
- * Loads all images
144
- * TODO - traverse gltf and determine which images are actually needed
145
- * @param gltf
146
- * @param options
147
- * @param context
148
- * @returns
149
- */
150
- async function loadImages(gltf, options, context) {
151
- const imageIndices = getReferencesImageIndices(gltf);
152
- const images = gltf.json.images || [];
153
- const promises = [];
154
- for (const imageIndex of imageIndices) {
155
- promises.push(loadImage(gltf, images[imageIndex], imageIndex, options, context));
156
- }
157
- return await Promise.all(promises);
158
- }
159
- /** Make sure we only load images that are actually referenced by textures */
160
- function getReferencesImageIndices(gltf) {
161
- const imageIndices = new Set();
162
- const textures = gltf.json.textures || [];
163
- for (const texture of textures) {
164
- if (texture.source !== undefined) {
165
- imageIndices.add(texture.source);
166
- }
167
- }
168
- return Array.from(imageIndices).sort();
169
- }
170
- /** Asynchronously fetches and parses one image, store in images array outside of json */
171
- async function loadImage(gltf, image, index, options, context) {
172
- const { fetch, parse } = context;
173
- let arrayBuffer;
174
- if (image.uri && !image.hasOwnProperty('bufferView')) {
175
- const uri = (0, resolve_url_1.resolveUrl)(image.uri, options);
176
- const response = await fetch(uri);
177
- arrayBuffer = await response.arrayBuffer();
178
- image.bufferView = {
179
- data: arrayBuffer
180
- };
181
- }
182
- if (Number.isFinite(image.bufferView)) {
183
- const array = (0, get_typed_array_1.getTypedArrayForBufferView)(gltf.json, gltf.buffers, image.bufferView);
184
- arrayBuffer = (0, loader_utils_1.sliceArrayBuffer)(array.buffer, array.byteOffset, array.byteLength);
185
- }
186
- (0, assert_1.assert)(arrayBuffer, 'glTF image has no data');
187
- // Call `parse`
188
- let parsedImage = await parse(arrayBuffer, [images_1.ImageLoader, textures_1.BasisLoader], { mimeType: image.mimeType, basis: options.basis || { format: (0, textures_1.selectSupportedBasisFormat)() } }, context);
189
- if (parsedImage && parsedImage[0]) {
190
- parsedImage = {
191
- compressed: true,
192
- mipmaps: false,
193
- width: parsedImage[0].width,
194
- height: parsedImage[0].height,
195
- data: parsedImage[0]
196
- };
197
- }
198
- // TODO making sure ImageLoader is overridable by using array of loaders
199
- // const parsedImage = await parse(arrayBuffer, [ImageLoader]);
200
- // Store the loaded image
201
- gltf.images = gltf.images || [];
202
- gltf.images[index] = parsedImage;
203
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,4 +0,0 @@
1
- "use strict";
2
- // Types forked from https://github.com/bwasty/gltf-loader-ts under MIT license
3
- // Generated from official JSON schema using `npm run generate-interface` on 2018-02-24
4
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,4 +0,0 @@
1
- "use strict";
2
- // Types forked from https://github.com/bwasty/gltf-loader-ts under MIT license
3
- // Generated from official JSON schema using `npm run generate-interface` on 2018-02-24
4
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,3 +0,0 @@
1
- "use strict";
2
- /* eslint-disable camelcase */
3
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.assert = void 0;
4
- // Replacement for the external assert method to reduce bundle size
5
- // Note: We don't use the second "message" argument in calling code,
6
- // so no need to support it here
7
- function assert(condition, message) {
8
- if (!condition) {
9
- throw new Error(message || 'assert failed: gltf');
10
- }
11
- }
12
- exports.assert = assert;
@@ -1,7 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.VERSION = void 0;
4
- // Version constant cannot be imported, it needs to correspond to the build version of **this** module.
5
- // __VERSION__ is injected by babel-plugin-version-inline
6
- // @ts-ignore TS2304: Cannot find name '__VERSION__'.
7
- exports.VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';
@@ -1,118 +0,0 @@
1
- "use strict";
2
- // This file is part of meshoptimizer library and is distributed under the terms of MIT License.
3
- // Copyright (C) 2016-2021, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
4
- Object.defineProperty(exports, "__esModule", { value: true });
5
- exports.meshoptDecodeGltfBuffer = exports.meshoptDecodeIndexSequence = exports.meshoptDecodeIndexBuffer = exports.meshoptDecodeVertexBuffer = exports.isMeshoptSupported = void 0;
6
- /* eslint-disable camelcase */
7
- const isWebAssemblySupported = typeof WebAssembly !== 'object';
8
- // Built with clang version 11.0.0 (https://github.com/llvm/llvm-project.git 0160ad802e899c2922bc9b29564080c22eb0908c)
9
- // Built from meshoptimizer 0.16
10
- const wasm_base = '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';
11
- const wasm_simd = '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';
12
- // Uses bulk-memory and simd extensions
13
- const detector = new Uint8Array([
14
- 0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 3, 2, 0, 0, 5, 3, 1, 0, 1, 12, 1, 0, 10, 22, 2,
15
- 12, 0, 65, 0, 65, 0, 65, 0, 252, 10, 0, 0, 11, 7, 0, 65, 0, 253, 15, 26, 11
16
- ]);
17
- // Used to unpack wasm
18
- const wasmpack = new Uint8Array([
19
- 32, 0, 65, 253, 3, 1, 2, 34, 4, 106, 6, 5, 11, 8, 7, 20, 13, 33, 12, 16, 128, 9, 116, 64, 19, 113,
20
- 127, 15, 10, 21, 22, 14, 255, 66, 24, 54, 136, 107, 18, 23, 192, 26, 114, 118, 132, 17, 77, 101,
21
- 130, 144, 27, 87, 131, 44, 45, 74, 156, 154, 70, 167
22
- ]);
23
- const FILTERS = {
24
- // legacy index-based enums for glTF
25
- 0: '',
26
- 1: 'meshopt_decodeFilterOct',
27
- 2: 'meshopt_decodeFilterQuat',
28
- 3: 'meshopt_decodeFilterExp',
29
- // string-based enums for glTF
30
- NONE: '',
31
- OCTAHEDRAL: 'meshopt_decodeFilterOct',
32
- QUATERNION: 'meshopt_decodeFilterQuat',
33
- EXPONENTIAL: 'meshopt_decodeFilterExp'
34
- };
35
- const DECODERS = {
36
- // legacy index-based enums for glTF
37
- 0: 'meshopt_decodeVertexBuffer',
38
- 1: 'meshopt_decodeIndexBuffer',
39
- 2: 'meshopt_decodeIndexSequence',
40
- // string-based enums for glTF
41
- ATTRIBUTES: 'meshopt_decodeVertexBuffer',
42
- TRIANGLES: 'meshopt_decodeIndexBuffer',
43
- INDICES: 'meshopt_decodeIndexSequence'
44
- };
45
- function isMeshoptSupported() {
46
- return isWebAssemblySupported;
47
- }
48
- exports.isMeshoptSupported = isMeshoptSupported;
49
- async function meshoptDecodeVertexBuffer(target, count, size, source, filter = 'NONE') {
50
- const instance = await loadWasmInstance();
51
- decode(instance, instance.exports.meshopt_decodeVertexBuffer, target, count, size, source, instance.exports[FILTERS[filter]]);
52
- }
53
- exports.meshoptDecodeVertexBuffer = meshoptDecodeVertexBuffer;
54
- async function meshoptDecodeIndexBuffer(target, count, size, source) {
55
- const instance = await loadWasmInstance();
56
- decode(instance, instance.exports.meshopt_decodeIndexBuffer, target, count, size, source);
57
- }
58
- exports.meshoptDecodeIndexBuffer = meshoptDecodeIndexBuffer;
59
- async function meshoptDecodeIndexSequence(target, count, size, source) {
60
- const instance = await loadWasmInstance();
61
- decode(instance, instance.exports.meshopt_decodeIndexSequence, target, count, size, source);
62
- }
63
- exports.meshoptDecodeIndexSequence = meshoptDecodeIndexSequence;
64
- // eslint-disable-next-line max-params
65
- async function meshoptDecodeGltfBuffer(target, count, size, source, mode, filter = 'NONE') {
66
- const instance = await loadWasmInstance();
67
- decode(instance, instance.exports[DECODERS[mode]], target, count, size, source, instance.exports[FILTERS[filter || 'NONE']]);
68
- }
69
- exports.meshoptDecodeGltfBuffer = meshoptDecodeGltfBuffer;
70
- let wasmPromise;
71
- async function loadWasmInstance() {
72
- // eslint-disable-next-line
73
- if (!wasmPromise) {
74
- wasmPromise = loadWasmModule();
75
- }
76
- return wasmPromise;
77
- }
78
- async function loadWasmModule() {
79
- let wasm = wasm_base;
80
- if (WebAssembly.validate(detector)) {
81
- wasm = wasm_simd;
82
- // eslint-disable-next-line no-console
83
- console.log('Warning: meshopt_decoder is using experimental SIMD support');
84
- }
85
- const result = await WebAssembly.instantiate(unpack(wasm), {});
86
- await result.instance.exports.__wasm_call_ctors();
87
- return result.instance;
88
- }
89
- function unpack(data) {
90
- const result = new Uint8Array(data.length);
91
- for (let i = 0; i < data.length; ++i) {
92
- const ch = data.charCodeAt(i);
93
- result[i] = ch > 96 ? ch - 71 : ch > 64 ? ch - 65 : ch > 47 ? ch + 4 : ch > 46 ? 63 : 62;
94
- }
95
- let write = 0;
96
- for (let i = 0; i < data.length; ++i) {
97
- result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
98
- }
99
- return result.buffer.slice(0, write);
100
- }
101
- // eslint-disable-next-line max-params
102
- function decode(instance, fun, target, count, size, source, filter) {
103
- const sbrk = instance.exports.sbrk;
104
- const count4 = (count + 3) & ~3; // pad for SIMD filter
105
- const tp = sbrk(count4 * size);
106
- const sp = sbrk(source.length);
107
- const heap = new Uint8Array(instance.exports.memory.buffer);
108
- heap.set(source, sp);
109
- const res = fun(tp, count, size, sp, source.length);
110
- if (res === 0 && filter) {
111
- filter(tp, count4, size);
112
- }
113
- target.set(heap.subarray(tp, tp + count * size));
114
- sbrk(tp - sbrk(0));
115
- if (res !== 0) {
116
- throw new Error(`Malformed buffer data: ${res}`);
117
- }
118
- }
package/dist/webp/webp.js DELETED
@@ -1,38 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isWebPSupported = void 0;
4
- const WEBP_TEST_IMAGES = {
5
- lossy: 'UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA',
6
- lossless: 'UklGRhoAAABXRUJQVlA4TA0AAAAvAAAAEAcQERGIiP4HAA==',
7
- alpha: 'UklGRkoAAABXRUJQVlA4WAoAAAAQAAAAAAAAAAAAQUxQSAwAAAARBxAR/Q9ERP8DAABWUDggGAAAABQBAJ0BKgEAAQAAAP4AAA3AAP7mtQAAAA==',
8
- animation: 'UklGRlIAAABXRUJQVlA4WAoAAAASAAAAAAAAAAAAQU5JTQYAAAD/////AABBTk1GJgAAAAAAAAAAAAAAAAAAAGQAAABWUDhMDQAAAC8AAAAQBxAREYiI/gcA'
9
- };
10
- const WEBP_FEATURES = ['lossy', 'lossless', 'alpha', 'animation'];
11
- /**
12
- * Checks if WebP is supported
13
- * @param features Array, can include 'lossy', 'lossless', 'alpha' or 'animation'
14
- */
15
- async function isWebPSupported(features = WEBP_FEATURES) {
16
- const promises = features.map((feature) => checkWebPFeature(feature));
17
- const statuses = await Promise.all(promises);
18
- return statuses.every((_) => _);
19
- }
20
- exports.isWebPSupported = isWebPSupported;
21
- /**
22
- * Checks if a specific WebP feature is supported
23
- * @param feature 'feature' can be one of 'lossy', 'lossless', 'alpha' or 'animation'.
24
- *
25
- * Based on Google's official recommended checks
26
- * @see https://developers.google.com/speed/webp/faq#how_can_i_detect_browser_support_for_webp
27
- */
28
- async function checkWebPFeature(feature) {
29
- if (typeof Image === 'undefined') {
30
- return false;
31
- }
32
- return await new Promise((resolve, reject) => {
33
- const img = new Image();
34
- img.onload = () => resolve(img.width > 0 && img.height > 0);
35
- img.onerror = () => resolve(false);
36
- img.src = `data:image/webp;base64,${WEBP_TEST_IMAGES[feature]}`;
37
- });
38
- }