@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.
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/esm/lib/utils/version.js +1 -1
- package/package.json +6 -6
- package/dist/bundle.js +0 -5
- package/dist/glb-loader.js +0 -39
- package/dist/glb-writer.js +0 -37
- package/dist/gltf-loader.js +0 -50
- package/dist/gltf-writer.js +0 -32
- package/dist/index.js +0 -23
- package/dist/lib/api/gltf-extensions.js +0 -83
- package/dist/lib/api/gltf-scenegraph.js +0 -566
- package/dist/lib/api/normalize-gltf-v1.js +0 -299
- package/dist/lib/api/post-process-gltf.js +0 -370
- package/dist/lib/encoders/encode-glb.js +0 -61
- package/dist/lib/encoders/encode-gltf.js +0 -27
- package/dist/lib/extensions/EXT_meshopt_compression.js +0 -45
- package/dist/lib/extensions/EXT_texture_webp.js +0 -39
- package/dist/lib/extensions/KHR_binary_gltf.js +0 -42
- package/dist/lib/extensions/KHR_draco_mesh_compression.js +0 -141
- package/dist/lib/extensions/KHR_texture_basisu.js +0 -32
- package/dist/lib/extensions/KHR_texture_transform.js +0 -230
- package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +0 -118
- package/dist/lib/extensions/deprecated/KHR_lights_punctual.js +0 -62
- package/dist/lib/extensions/deprecated/KHR_materials_unlit.js +0 -47
- package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js +0 -82
- package/dist/lib/gltf-utils/get-typed-array.js +0 -41
- package/dist/lib/gltf-utils/gltf-attribute-utils.js +0 -73
- package/dist/lib/gltf-utils/gltf-constants.js +0 -43
- package/dist/lib/gltf-utils/gltf-utils.js +0 -85
- package/dist/lib/gltf-utils/resolve-url.js +0 -18
- package/dist/lib/parsers/parse-glb.js +0 -141
- package/dist/lib/parsers/parse-gltf.js +0 -203
- package/dist/lib/types/glb-types.js +0 -2
- package/dist/lib/types/gltf-json-schema.js +0 -4
- package/dist/lib/types/gltf-postprocessed-schema.js +0 -4
- package/dist/lib/types/gltf-types.js +0 -3
- package/dist/lib/utils/assert.js +0 -12
- package/dist/lib/utils/version.js +0 -7
- package/dist/meshopt/meshopt-decoder.js +0 -118
- 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
|
-
}
|
package/dist/lib/utils/assert.js
DELETED
|
@@ -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
|
-
}
|