@loaders.gl/i3s 4.0.0-alpha.7 → 4.0.0-alpha.9
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/dist.min.js +99 -31
- package/dist/es5/arcgis-webscene-loader.js +1 -1
- package/dist/es5/i3s-attribute-loader.js +1 -1
- package/dist/es5/i3s-building-scene-layer-loader.js +1 -1
- package/dist/es5/i3s-content-loader.js +1 -1
- package/dist/es5/i3s-loader.js +1 -1
- package/dist/es5/i3s-node-page-loader.js +1 -1
- package/dist/es5/i3s-slpk-loader.js +1 -1
- package/dist/es5/i3s-slpk-loader.js.map +1 -1
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/lib/parsers/parse-i3s-tile-content.js +2 -2
- package/dist/es5/lib/parsers/parse-i3s-tile-content.js.map +1 -1
- package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js +2 -2
- package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js.map +1 -1
- package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js +140 -23
- package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -1
- package/dist/es5/lib/utils/{customizeColors.js → customize-/321/201olors.js} +65 -40
- package/dist/es5/lib/utils/customize-/321/201olors.js.map +1 -0
- package/dist/es5/types.js.map +1 -1
- package/dist/esm/arcgis-webscene-loader.js +1 -1
- package/dist/esm/i3s-attribute-loader.js +1 -1
- package/dist/esm/i3s-building-scene-layer-loader.js +1 -1
- package/dist/esm/i3s-content-loader.js +1 -1
- package/dist/esm/i3s-loader.js +1 -1
- package/dist/esm/i3s-node-page-loader.js +1 -1
- package/dist/esm/i3s-slpk-loader.js +1 -1
- package/dist/esm/i3s-slpk-loader.js.map +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/parsers/parse-i3s-tile-content.js +1 -1
- package/dist/esm/lib/parsers/parse-i3s-tile-content.js.map +1 -1
- package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js +2 -2
- package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js.map +1 -1
- package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js +59 -9
- package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -1
- package/dist/esm/lib/utils/{customizeColors.js → customize-/321/201olors.js} +9 -3
- package/dist/esm/lib/utils/customize-/321/201olors.js.map +1 -0
- package/dist/esm/types.js.map +1 -1
- package/dist/i3s-content-worker-node.js +2 -2
- package/dist/i3s-content-worker-node.js.map +3 -3
- package/dist/i3s-content-worker.js +16 -10
- package/dist/i3s-slpk-loader.d.ts +6 -3
- package/dist/i3s-slpk-loader.d.ts.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/lib/parsers/parse-i3s-tile-content.js +2 -2
- package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts.map +1 -1
- package/dist/lib/parsers/parse-slpk/parse-slpk.js +1 -1
- package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts +6 -0
- package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts.map +1 -1
- package/dist/lib/parsers/parse-slpk/slpk-archieve.js +72 -9
- package/dist/lib/utils/{customizeColors.d.ts → customize-/321/201olors.d.ts} +1 -1
- package/dist/lib/utils/customize-/321/201olors.d.ts.map +1 -0
- package/dist/lib/utils/{customizeColors.js → customize-/321/201olors.js} +12 -2
- package/dist/types.d.ts +1 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +10 -10
- package/src/i3s-slpk-loader.ts +5 -3
- package/src/index.ts +2 -1
- package/src/lib/parsers/parse-i3s-tile-content.ts +1 -1
- package/src/lib/parsers/parse-slpk/parse-slpk.ts +4 -1
- package/src/lib/parsers/parse-slpk/slpk-archieve.ts +73 -9
- package/src/lib/utils/{customizeColors.ts → customize-/321/201olors.ts} +12 -2
- package/src/types.ts +1 -0
- package/dist/es5/lib/utils/customizeColors.js.map +0 -1
- package/dist/esm/lib/utils/customizeColors.js.map +0 -1
- package/dist/lib/utils/customizeColors.d.ts.map +0 -1
|
@@ -14,6 +14,34 @@ var _workerUtils = require("@loaders.gl/worker-utils");
|
|
|
14
14
|
var _md = _interopRequireDefault(require("md5"));
|
|
15
15
|
var _compression = require("@loaders.gl/compression");
|
|
16
16
|
var _localFileHeader = require("../parse-zip/local-file-header");
|
|
17
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
18
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
19
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
20
|
+
var PATH_DESCRIPTIONS = [{
|
|
21
|
+
test: /^$/,
|
|
22
|
+
extensions: ['3dSceneLayer.json.gz']
|
|
23
|
+
}, {
|
|
24
|
+
test: /^nodepages\/\d+$/,
|
|
25
|
+
extensions: ['.json.gz']
|
|
26
|
+
}, {
|
|
27
|
+
test: /^nodes\/\d+$/,
|
|
28
|
+
extensions: ['/3dNodeIndexDocument.json.gz']
|
|
29
|
+
}, {
|
|
30
|
+
test: /^nodes\/\d+\/textures\/.+$/,
|
|
31
|
+
extensions: ['.jpg', '.png', '.bin.dds.gz', '.ktx']
|
|
32
|
+
}, {
|
|
33
|
+
test: /^nodes\/\d+\/geometries\/\d+$/,
|
|
34
|
+
extensions: ['.bin.gz', '.draco.gz']
|
|
35
|
+
}, {
|
|
36
|
+
test: /^nodes\/\d+\/attributes\/f_\d+\/\d+$/,
|
|
37
|
+
extensions: ['.bin.gz']
|
|
38
|
+
}, {
|
|
39
|
+
test: /^statistics\/f_\d+\/\d+$/,
|
|
40
|
+
extensions: ['.json.gz']
|
|
41
|
+
}, {
|
|
42
|
+
test: /^nodes\/\d+\/shared$/,
|
|
43
|
+
extensions: ['/sharedResource.json.gz']
|
|
44
|
+
}];
|
|
17
45
|
var SLPKArchive = function () {
|
|
18
46
|
function SLPKArchive(slpkArchiveBuffer, hashFile) {
|
|
19
47
|
(0, _classCallCheck2.default)(this, SLPKArchive);
|
|
@@ -42,8 +70,13 @@ var SLPKArchive = function () {
|
|
|
42
70
|
value: function () {
|
|
43
71
|
var _getFile = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(path) {
|
|
44
72
|
var mode,
|
|
45
|
-
|
|
46
|
-
|
|
73
|
+
_PATH_DESCRIPTIONS$fi,
|
|
74
|
+
extensions,
|
|
75
|
+
data,
|
|
76
|
+
_iterator,
|
|
77
|
+
_step,
|
|
78
|
+
ext,
|
|
79
|
+
decompressedFile,
|
|
47
80
|
fileWithoutCompression,
|
|
48
81
|
_args = arguments;
|
|
49
82
|
return _regenerator.default.wrap(function _callee$(_context) {
|
|
@@ -51,46 +84,130 @@ var SLPKArchive = function () {
|
|
|
51
84
|
case 0:
|
|
52
85
|
mode = _args.length > 1 && _args[1] !== undefined ? _args[1] : 'raw';
|
|
53
86
|
if (!(mode === 'http')) {
|
|
54
|
-
_context.next =
|
|
87
|
+
_context.next = 26;
|
|
55
88
|
break;
|
|
56
89
|
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
if (!
|
|
61
|
-
_context.next =
|
|
90
|
+
extensions = (_PATH_DESCRIPTIONS$fi = PATH_DESCRIPTIONS.find(function (val) {
|
|
91
|
+
return val.test.test(path);
|
|
92
|
+
})) === null || _PATH_DESCRIPTIONS$fi === void 0 ? void 0 : _PATH_DESCRIPTIONS$fi.extensions;
|
|
93
|
+
if (!extensions) {
|
|
94
|
+
_context.next = 26;
|
|
62
95
|
break;
|
|
63
96
|
}
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
operation: 'decompress',
|
|
68
|
-
_workerType: 'test',
|
|
69
|
-
gzip: {}
|
|
70
|
-
});
|
|
97
|
+
_iterator = _createForOfIteratorHelper(extensions);
|
|
98
|
+
_context.prev = 5;
|
|
99
|
+
_iterator.s();
|
|
71
100
|
case 7:
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
101
|
+
if ((_step = _iterator.n()).done) {
|
|
102
|
+
_context.next = 16;
|
|
103
|
+
break;
|
|
104
|
+
}
|
|
105
|
+
ext = _step.value;
|
|
106
|
+
_context.next = 11;
|
|
107
|
+
return this.getDataByPath("".concat(path).concat(ext));
|
|
108
|
+
case 11:
|
|
109
|
+
data = _context.sent;
|
|
110
|
+
if (!data) {
|
|
111
|
+
_context.next = 14;
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
return _context.abrupt("break", 16);
|
|
115
|
+
case 14:
|
|
116
|
+
_context.next = 7;
|
|
117
|
+
break;
|
|
118
|
+
case 16:
|
|
119
|
+
_context.next = 21;
|
|
120
|
+
break;
|
|
121
|
+
case 18:
|
|
122
|
+
_context.prev = 18;
|
|
123
|
+
_context.t0 = _context["catch"](5);
|
|
124
|
+
_iterator.e(_context.t0);
|
|
125
|
+
case 21:
|
|
126
|
+
_context.prev = 21;
|
|
127
|
+
_iterator.f();
|
|
128
|
+
return _context.finish(21);
|
|
129
|
+
case 24:
|
|
130
|
+
if (!data) {
|
|
131
|
+
_context.next = 26;
|
|
132
|
+
break;
|
|
133
|
+
}
|
|
134
|
+
return _context.abrupt("return", Buffer.from(data));
|
|
135
|
+
case 26:
|
|
136
|
+
if (!(mode === 'raw')) {
|
|
137
|
+
_context.next = 35;
|
|
138
|
+
break;
|
|
139
|
+
}
|
|
140
|
+
_context.next = 29;
|
|
141
|
+
return this.getDataByPath("".concat(path, ".gz"));
|
|
142
|
+
case 29:
|
|
143
|
+
decompressedFile = _context.sent;
|
|
144
|
+
if (!decompressedFile) {
|
|
145
|
+
_context.next = 32;
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
return _context.abrupt("return", Buffer.from(decompressedFile));
|
|
149
|
+
case 32:
|
|
75
150
|
fileWithoutCompression = this.getFileBytes(path);
|
|
76
151
|
if (!fileWithoutCompression) {
|
|
77
|
-
_context.next =
|
|
152
|
+
_context.next = 35;
|
|
78
153
|
break;
|
|
79
154
|
}
|
|
80
|
-
return _context.abrupt("return",
|
|
81
|
-
case
|
|
155
|
+
return _context.abrupt("return", Buffer.from(fileWithoutCompression));
|
|
156
|
+
case 35:
|
|
82
157
|
throw new Error('No such file in the archieve');
|
|
83
|
-
case
|
|
158
|
+
case 36:
|
|
84
159
|
case "end":
|
|
85
160
|
return _context.stop();
|
|
86
161
|
}
|
|
87
|
-
}, _callee, this);
|
|
162
|
+
}, _callee, this, [[5, 18, 21, 24]]);
|
|
88
163
|
}));
|
|
89
164
|
function getFile(_x) {
|
|
90
165
|
return _getFile.apply(this, arguments);
|
|
91
166
|
}
|
|
92
167
|
return getFile;
|
|
93
168
|
}()
|
|
169
|
+
}, {
|
|
170
|
+
key: "getDataByPath",
|
|
171
|
+
value: function () {
|
|
172
|
+
var _getDataByPath = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(path) {
|
|
173
|
+
var data, decompressedData;
|
|
174
|
+
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
175
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
176
|
+
case 0:
|
|
177
|
+
data = this.getFileBytes(path);
|
|
178
|
+
if (data) {
|
|
179
|
+
_context2.next = 3;
|
|
180
|
+
break;
|
|
181
|
+
}
|
|
182
|
+
return _context2.abrupt("return", undefined);
|
|
183
|
+
case 3:
|
|
184
|
+
if (!/\.gz$/.test(path)) {
|
|
185
|
+
_context2.next = 8;
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
_context2.next = 6;
|
|
189
|
+
return (0, _workerUtils.processOnWorker)(_compression.CompressionWorker, data, {
|
|
190
|
+
compression: 'gzip',
|
|
191
|
+
operation: 'decompress',
|
|
192
|
+
_workerType: 'test',
|
|
193
|
+
gzip: {}
|
|
194
|
+
});
|
|
195
|
+
case 6:
|
|
196
|
+
decompressedData = _context2.sent;
|
|
197
|
+
return _context2.abrupt("return", decompressedData);
|
|
198
|
+
case 8:
|
|
199
|
+
return _context2.abrupt("return", Buffer.from(data));
|
|
200
|
+
case 9:
|
|
201
|
+
case "end":
|
|
202
|
+
return _context2.stop();
|
|
203
|
+
}
|
|
204
|
+
}, _callee2, this);
|
|
205
|
+
}));
|
|
206
|
+
function getDataByPath(_x2) {
|
|
207
|
+
return _getDataByPath.apply(this, arguments);
|
|
208
|
+
}
|
|
209
|
+
return getDataByPath;
|
|
210
|
+
}()
|
|
94
211
|
}, {
|
|
95
212
|
key: "getFileBytes",
|
|
96
213
|
value: function getFileBytes(path) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slpk-archieve.js","names":["_workerUtils","require","_md","_interopRequireDefault","_compression","_localFileHeader","SLPKArchive","slpkArchiveBuffer","hashFile","_classCallCheck2","default","_defineProperty2","slpkArchive","DataView","hashArray","parseHashFile","_createClass2","key","value","hashFileBuffer","Buffer","from","i","buffer","byteLength","offsetBuffer","slice","byteOffset","offset","getUint32","push","hash","subarray","_getFile","_asyncToGenerator2","_regenerator","mark","_callee","path","mode","fileToDecompress","decompressedData","fileWithoutCompression","_args","arguments","wrap","_callee$","_context","prev","next","length","undefined","Error","getFileBytes","concat","processOnWorker","CompressionWorker","compression","operation","_workerType","gzip","sent","abrupt","Promise","resolve","stop","getFile","_x","apply","nameHash","md5","fileInfo","find","val","compare","localFileHeader","parseZipLocalFileHeader","compressedFile","fileDataOffset","compressedSize","exports"],"sources":["../../../../../src/lib/parsers/parse-slpk/slpk-archieve.ts"],"sourcesContent":["import {processOnWorker} from '@loaders.gl/worker-utils';\nimport md5 from 'md5';\nimport {CompressionWorker} from '@loaders.gl/compression';\nimport {parseZipLocalFileHeader} from '../parse-zip/local-file-header';\n\n/** Element of hash array */\ntype HashElement = {\n /**\n * File name hash\n */\n hash: Buffer;\n /**\n * File offset in the archive\n */\n offset: number;\n};\n\n/**\n * Class for handling information about slpk file\n */\nexport class SLPKArchive {\n slpkArchive: DataView;\n hashArray: {hash: Buffer; offset: number}[];\n constructor(slpkArchiveBuffer: ArrayBuffer, hashFile: ArrayBuffer) {\n this.slpkArchive = new DataView(slpkArchiveBuffer);\n this.hashArray = this.parseHashFile(hashFile);\n }\n\n /**\n * Reads hash file from buffer and returns it in ready-to-use form\n * @param hashFile - bufer containing hash file\n * @returns Array containing file info\n */\n private parseHashFile(hashFile: ArrayBuffer): HashElement[] {\n const hashFileBuffer = Buffer.from(hashFile);\n const hashArray: HashElement[] = [];\n for (let i = 0; i < hashFileBuffer.buffer.byteLength; i = i + 24) {\n const offsetBuffer = new DataView(\n hashFileBuffer.buffer.slice(\n hashFileBuffer.byteOffset + i + 16,\n hashFileBuffer.byteOffset + i + 24\n )\n );\n const offset = offsetBuffer.getUint32(offsetBuffer.byteOffset, true);\n hashArray.push({\n hash: Buffer.from(\n hashFileBuffer.subarray(hashFileBuffer.byteOffset + i, hashFileBuffer.byteOffset + i + 16)\n ),\n offset\n });\n }\n return hashArray;\n }\n\n /**\n * Returns file with the given path from slpk archive\n * @param path - path inside the slpk\n * @param mode - currently only raw mode supported\n * @returns buffer with ready to use file\n */\n async getFile(path: string, mode: 'http' | 'raw' = 'raw'): Promise<Buffer> {\n if (mode === 'http') {\n throw new Error('http mode is not supported');\n }\n\n const fileToDecompress = this.getFileBytes(`${path}.gz`);\n\n if (fileToDecompress) {\n const decompressedData = await processOnWorker(CompressionWorker, fileToDecompress, {\n compression: 'gzip',\n operation: 'decompress',\n _workerType: 'test',\n gzip: {}\n });\n return decompressedData;\n }\n const fileWithoutCompression = this.getFileBytes(path);\n if (fileWithoutCompression) {\n return Promise.resolve(Buffer.from(fileWithoutCompression));\n }\n throw new Error('No such file in the archieve');\n }\n\n /**\n * Trying to get raw file data by adress\n * @param path - path inside the archive\n * @returns buffer with the raw file data\n */\n private getFileBytes(path: string): ArrayBuffer | undefined {\n const nameHash = Buffer.from(md5(path), 'hex');\n const fileInfo = this.hashArray.find((val) => Buffer.compare(val.hash, nameHash) === 0);\n if (!fileInfo) {\n return undefined;\n }\n\n const localFileHeader = parseZipLocalFileHeader(\n this.slpkArchive.byteOffset + fileInfo?.offset,\n this.slpkArchive\n );\n\n const compressedFile = this.slpkArchive.buffer.slice(\n localFileHeader.fileDataOffset,\n localFileHeader.fileDataOffset + localFileHeader.compressedSize\n );\n\n return compressedFile;\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"slpk-archieve.js","names":["_workerUtils","require","_md","_interopRequireDefault","_compression","_localFileHeader","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","PATH_DESCRIPTIONS","extensions","SLPKArchive","slpkArchiveBuffer","hashFile","_classCallCheck2","default","_defineProperty2","slpkArchive","DataView","hashArray","parseHashFile","_createClass2","key","hashFileBuffer","Buffer","buffer","byteLength","offsetBuffer","byteOffset","offset","getUint32","push","hash","subarray","_getFile","_asyncToGenerator2","_regenerator","mark","_callee","path","mode","_PATH_DESCRIPTIONS$fi","data","_iterator","_step","ext","decompressedFile","fileWithoutCompression","_args","arguments","wrap","_callee$","_context","prev","undefined","find","val","getDataByPath","concat","sent","abrupt","t0","finish","getFileBytes","Error","stop","getFile","_x","apply","_getDataByPath","_callee2","decompressedData","_callee2$","_context2","processOnWorker","CompressionWorker","compression","operation","_workerType","gzip","_x2","nameHash","md5","fileInfo","compare","localFileHeader","parseZipLocalFileHeader","compressedFile","fileDataOffset","compressedSize","exports"],"sources":["../../../../../src/lib/parsers/parse-slpk/slpk-archieve.ts"],"sourcesContent":["import {processOnWorker} from '@loaders.gl/worker-utils';\nimport md5 from 'md5';\nimport {CompressionWorker} from '@loaders.gl/compression';\nimport {parseZipLocalFileHeader} from '../parse-zip/local-file-header';\n\n/** Element of hash array */\ntype HashElement = {\n /**\n * File name hash\n */\n hash: Buffer;\n /**\n * File offset in the archive\n */\n offset: number;\n};\n\nconst PATH_DESCRIPTIONS: {test: RegExp; extensions: string[]}[] = [\n {\n test: /^$/,\n extensions: ['3dSceneLayer.json.gz']\n },\n {\n test: /^nodepages\\/\\d+$/,\n extensions: ['.json.gz']\n },\n {\n test: /^nodes\\/\\d+$/,\n extensions: ['/3dNodeIndexDocument.json.gz']\n },\n {\n test: /^nodes\\/\\d+\\/textures\\/.+$/,\n extensions: ['.jpg', '.png', '.bin.dds.gz', '.ktx']\n },\n {\n test: /^nodes\\/\\d+\\/geometries\\/\\d+$/,\n extensions: ['.bin.gz', '.draco.gz']\n },\n {\n test: /^nodes\\/\\d+\\/attributes\\/f_\\d+\\/\\d+$/,\n extensions: ['.bin.gz']\n },\n {\n test: /^statistics\\/f_\\d+\\/\\d+$/,\n extensions: ['.json.gz']\n },\n {\n test: /^nodes\\/\\d+\\/shared$/,\n extensions: ['/sharedResource.json.gz']\n }\n];\n\n/**\n * Class for handling information about slpk file\n */\nexport class SLPKArchive {\n slpkArchive: DataView;\n hashArray: {hash: Buffer; offset: number}[];\n constructor(slpkArchiveBuffer: ArrayBuffer, hashFile: ArrayBuffer) {\n this.slpkArchive = new DataView(slpkArchiveBuffer);\n this.hashArray = this.parseHashFile(hashFile);\n }\n\n /**\n * Reads hash file from buffer and returns it in ready-to-use form\n * @param hashFile - bufer containing hash file\n * @returns Array containing file info\n */\n private parseHashFile(hashFile: ArrayBuffer): HashElement[] {\n const hashFileBuffer = Buffer.from(hashFile);\n const hashArray: HashElement[] = [];\n for (let i = 0; i < hashFileBuffer.buffer.byteLength; i = i + 24) {\n const offsetBuffer = new DataView(\n hashFileBuffer.buffer.slice(\n hashFileBuffer.byteOffset + i + 16,\n hashFileBuffer.byteOffset + i + 24\n )\n );\n const offset = offsetBuffer.getUint32(offsetBuffer.byteOffset, true);\n hashArray.push({\n hash: Buffer.from(\n hashFileBuffer.subarray(hashFileBuffer.byteOffset + i, hashFileBuffer.byteOffset + i + 16)\n ),\n offset\n });\n }\n return hashArray;\n }\n\n /**\n * Returns file with the given path from slpk archive\n * @param path - path inside the slpk\n * @param mode - currently only raw mode supported\n * @returns buffer with ready to use file\n */\n async getFile(path: string, mode: 'http' | 'raw' = 'raw'): Promise<Buffer> {\n if (mode === 'http') {\n const extensions = PATH_DESCRIPTIONS.find((val) => val.test.test(path))?.extensions;\n if (extensions) {\n let data: ArrayBuffer | undefined;\n for (const ext of extensions) {\n data = await this.getDataByPath(`${path}${ext}`);\n if (data) {\n break;\n }\n }\n if (data) {\n return Buffer.from(data);\n }\n }\n }\n if (mode === 'raw') {\n const decompressedFile = await this.getDataByPath(`${path}.gz`);\n if (decompressedFile) {\n return Buffer.from(decompressedFile);\n }\n const fileWithoutCompression = this.getFileBytes(path);\n if (fileWithoutCompression) {\n return Buffer.from(fileWithoutCompression);\n }\n }\n\n throw new Error('No such file in the archieve');\n }\n\n /**\n * returning uncompressed data for paths that ends with .gz and raw data for all other paths\n * @param path - path inside the archive\n * @returns buffer with the file data\n */\n private async getDataByPath(path: string): Promise<ArrayBuffer | undefined> {\n const data = this.getFileBytes(path);\n if (!data) {\n return undefined;\n }\n if (/\\.gz$/.test(path)) {\n const decompressedData = await processOnWorker(CompressionWorker, data, {\n compression: 'gzip',\n operation: 'decompress',\n _workerType: 'test',\n gzip: {}\n });\n return decompressedData;\n }\n return Buffer.from(data);\n }\n\n /**\n * Trying to get raw file data by adress\n * @param path - path inside the archive\n * @returns buffer with the raw file data\n */\n private getFileBytes(path: string): ArrayBuffer | undefined {\n const nameHash = Buffer.from(md5(path), 'hex');\n const fileInfo = this.hashArray.find((val) => Buffer.compare(val.hash, nameHash) === 0);\n if (!fileInfo) {\n return undefined;\n }\n\n const localFileHeader = parseZipLocalFileHeader(\n this.slpkArchive.byteOffset + fileInfo?.offset,\n this.slpkArchive\n );\n\n const compressedFile = this.slpkArchive.buffer.slice(\n localFileHeader.fileDataOffset,\n localFileHeader.fileDataOffset + localFileHeader.compressedSize\n );\n\n return compressedFile;\n }\n}\n"],"mappings":"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"}
|
|
@@ -9,22 +9,22 @@ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"))
|
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _core = require("@loaders.gl/core");
|
|
11
11
|
var _i3sAttributeLoader = require("../../i3s-attribute-loader");
|
|
12
|
-
var _urlUtils = require("
|
|
12
|
+
var _urlUtils = require("./url-utils");
|
|
13
13
|
function customizeColors(_x, _x2, _x3, _x4, _x5) {
|
|
14
14
|
return _customizeColors.apply(this, arguments);
|
|
15
15
|
}
|
|
16
16
|
function _customizeColors() {
|
|
17
17
|
_customizeColors = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(colors, featureIds, tileOptions, tilesetOptions, options) {
|
|
18
18
|
var _options$i3s2;
|
|
19
|
-
var colorizeAttributeField, colorizeAttributeData, objectIdField, objectIdAttributeData, attributeValuesMap, i, _i,
|
|
20
|
-
return _regenerator.default.wrap(function _callee$(
|
|
21
|
-
while (1) switch (
|
|
19
|
+
var colorizeAttributeField, colorizeAttributeData, objectIdField, objectIdAttributeData, attributeValuesMap, i, _loop, _i, _ret;
|
|
20
|
+
return _regenerator.default.wrap(function _callee$(_context2) {
|
|
21
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
22
22
|
case 0:
|
|
23
23
|
if (options !== null && options !== void 0 && (_options$i3s2 = options.i3s) !== null && _options$i3s2 !== void 0 && _options$i3s2.colorsByAttribute) {
|
|
24
|
-
|
|
24
|
+
_context2.next = 2;
|
|
25
25
|
break;
|
|
26
26
|
}
|
|
27
|
-
return
|
|
27
|
+
return _context2.abrupt("return", colors);
|
|
28
28
|
case 2:
|
|
29
29
|
colorizeAttributeField = tilesetOptions.fields.find(function (_ref3) {
|
|
30
30
|
var _options$i3s3, _options$i3s3$colorsB;
|
|
@@ -32,68 +32,93 @@ function _customizeColors() {
|
|
|
32
32
|
return name === (options === null || options === void 0 ? void 0 : (_options$i3s3 = options.i3s) === null || _options$i3s3 === void 0 ? void 0 : (_options$i3s3$colorsB = _options$i3s3.colorsByAttribute) === null || _options$i3s3$colorsB === void 0 ? void 0 : _options$i3s3$colorsB.attributeName);
|
|
33
33
|
});
|
|
34
34
|
if (!(!colorizeAttributeField || !['esriFieldTypeDouble', 'esriFieldTypeInteger', 'esriFieldTypeSmallInteger'].includes(colorizeAttributeField.type))) {
|
|
35
|
-
|
|
35
|
+
_context2.next = 5;
|
|
36
36
|
break;
|
|
37
37
|
}
|
|
38
|
-
return
|
|
38
|
+
return _context2.abrupt("return", colors);
|
|
39
39
|
case 5:
|
|
40
|
-
|
|
40
|
+
_context2.next = 7;
|
|
41
41
|
return loadFeatureAttributeData(colorizeAttributeField.name, tileOptions, tilesetOptions, options);
|
|
42
42
|
case 7:
|
|
43
|
-
colorizeAttributeData =
|
|
43
|
+
colorizeAttributeData = _context2.sent;
|
|
44
44
|
if (colorizeAttributeData) {
|
|
45
|
-
|
|
45
|
+
_context2.next = 10;
|
|
46
46
|
break;
|
|
47
47
|
}
|
|
48
|
-
return
|
|
48
|
+
return _context2.abrupt("return", colors);
|
|
49
49
|
case 10:
|
|
50
50
|
objectIdField = tilesetOptions.fields.find(function (_ref4) {
|
|
51
51
|
var type = _ref4.type;
|
|
52
52
|
return type === 'esriFieldTypeOID';
|
|
53
53
|
});
|
|
54
54
|
if (objectIdField) {
|
|
55
|
-
|
|
55
|
+
_context2.next = 13;
|
|
56
56
|
break;
|
|
57
57
|
}
|
|
58
|
-
return
|
|
58
|
+
return _context2.abrupt("return", colors);
|
|
59
59
|
case 13:
|
|
60
|
-
|
|
60
|
+
_context2.next = 15;
|
|
61
61
|
return loadFeatureAttributeData(objectIdField.name, tileOptions, tilesetOptions, options);
|
|
62
62
|
case 15:
|
|
63
|
-
objectIdAttributeData =
|
|
63
|
+
objectIdAttributeData = _context2.sent;
|
|
64
64
|
if (objectIdAttributeData) {
|
|
65
|
-
|
|
65
|
+
_context2.next = 18;
|
|
66
66
|
break;
|
|
67
67
|
}
|
|
68
|
-
return
|
|
68
|
+
return _context2.abrupt("return", colors);
|
|
69
69
|
case 18:
|
|
70
70
|
attributeValuesMap = {};
|
|
71
71
|
for (i = 0; i < objectIdAttributeData[objectIdField.name].length; i++) {
|
|
72
72
|
attributeValuesMap[objectIdAttributeData[objectIdField.name][i]] = calculateColorForAttribute(colorizeAttributeData[colorizeAttributeField.name][i], options);
|
|
73
73
|
}
|
|
74
|
+
_loop = _regenerator.default.mark(function _loop(_i) {
|
|
75
|
+
var color;
|
|
76
|
+
return _regenerator.default.wrap(function _loop$(_context) {
|
|
77
|
+
while (1) switch (_context.prev = _context.next) {
|
|
78
|
+
case 0:
|
|
79
|
+
color = attributeValuesMap[featureIds.value[_i]];
|
|
80
|
+
if (color) {
|
|
81
|
+
_context.next = 3;
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
return _context.abrupt("return", "continue");
|
|
85
|
+
case 3:
|
|
86
|
+
if (options.i3s.colorsByAttribute.mode === 'multiply') {
|
|
87
|
+
color.forEach(function (colorItem, index) {
|
|
88
|
+
colors.value[_i * 4 + index] = colors.value[_i * 4 + index] * colorItem / 255;
|
|
89
|
+
});
|
|
90
|
+
} else {
|
|
91
|
+
colors.value.set(color, _i * 4);
|
|
92
|
+
}
|
|
93
|
+
case 4:
|
|
94
|
+
case "end":
|
|
95
|
+
return _context.stop();
|
|
96
|
+
}
|
|
97
|
+
}, _loop);
|
|
98
|
+
});
|
|
74
99
|
_i = 0;
|
|
75
|
-
case
|
|
100
|
+
case 22:
|
|
76
101
|
if (!(_i < featureIds.value.length)) {
|
|
77
|
-
|
|
102
|
+
_context2.next = 30;
|
|
78
103
|
break;
|
|
79
104
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
105
|
+
return _context2.delegateYield(_loop(_i), "t0", 24);
|
|
106
|
+
case 24:
|
|
107
|
+
_ret = _context2.t0;
|
|
108
|
+
if (!(_ret === "continue")) {
|
|
109
|
+
_context2.next = 27;
|
|
83
110
|
break;
|
|
84
111
|
}
|
|
85
|
-
return
|
|
86
|
-
case
|
|
87
|
-
colors.value.set(color, _i * 4);
|
|
88
|
-
case 26:
|
|
112
|
+
return _context2.abrupt("continue", 27);
|
|
113
|
+
case 27:
|
|
89
114
|
_i++;
|
|
90
|
-
|
|
115
|
+
_context2.next = 22;
|
|
91
116
|
break;
|
|
92
|
-
case 29:
|
|
93
|
-
return _context.abrupt("return", colors);
|
|
94
117
|
case 30:
|
|
118
|
+
return _context2.abrupt("return", colors);
|
|
119
|
+
case 31:
|
|
95
120
|
case "end":
|
|
96
|
-
return
|
|
121
|
+
return _context2.stop();
|
|
97
122
|
}
|
|
98
123
|
}, _callee);
|
|
99
124
|
}));
|
|
@@ -123,8 +148,8 @@ function _loadFeatureAttributeData() {
|
|
|
123
148
|
_loadFeatureAttributeData = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(attributeName, _ref, _ref2, options) {
|
|
124
149
|
var _options$i3s4;
|
|
125
150
|
var attributeUrls, attributeStorageInfo, attributeIndex, objectIdAttributeUrl, attributeType, objectIdAttributeData;
|
|
126
|
-
return _regenerator.default.wrap(function _callee2$(
|
|
127
|
-
while (1) switch (
|
|
151
|
+
return _regenerator.default.wrap(function _callee2$(_context3) {
|
|
152
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
128
153
|
case 0:
|
|
129
154
|
attributeUrls = _ref.attributeUrls;
|
|
130
155
|
attributeStorageInfo = _ref2.attributeStorageInfo;
|
|
@@ -133,27 +158,27 @@ function _loadFeatureAttributeData() {
|
|
|
133
158
|
return attributeName === name;
|
|
134
159
|
});
|
|
135
160
|
if (!(attributeIndex === -1)) {
|
|
136
|
-
|
|
161
|
+
_context3.next = 5;
|
|
137
162
|
break;
|
|
138
163
|
}
|
|
139
|
-
return
|
|
164
|
+
return _context3.abrupt("return", null);
|
|
140
165
|
case 5:
|
|
141
166
|
objectIdAttributeUrl = (0, _urlUtils.getUrlWithToken)(attributeUrls[attributeIndex], options === null || options === void 0 ? void 0 : (_options$i3s4 = options.i3s) === null || _options$i3s4 === void 0 ? void 0 : _options$i3s4.token);
|
|
142
167
|
attributeType = (0, _i3sAttributeLoader.getAttributeValueType)(attributeStorageInfo[attributeIndex]);
|
|
143
|
-
|
|
168
|
+
_context3.next = 9;
|
|
144
169
|
return (0, _core.load)(objectIdAttributeUrl, _i3sAttributeLoader.I3SAttributeLoader, {
|
|
145
170
|
attributeName: attributeName,
|
|
146
171
|
attributeType: attributeType
|
|
147
172
|
});
|
|
148
173
|
case 9:
|
|
149
|
-
objectIdAttributeData =
|
|
150
|
-
return
|
|
174
|
+
objectIdAttributeData = _context3.sent;
|
|
175
|
+
return _context3.abrupt("return", objectIdAttributeData);
|
|
151
176
|
case 11:
|
|
152
177
|
case "end":
|
|
153
|
-
return
|
|
178
|
+
return _context3.stop();
|
|
154
179
|
}
|
|
155
180
|
}, _callee2);
|
|
156
181
|
}));
|
|
157
182
|
return _loadFeatureAttributeData.apply(this, arguments);
|
|
158
183
|
}
|
|
159
|
-
//# sourceMappingURL=
|
|
184
|
+
//# sourceMappingURL=customize-сolors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customize-сolors.js","names":["_core","require","_i3sAttributeLoader","_urlUtils","customizeColors","_x","_x2","_x3","_x4","_x5","_customizeColors","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","colors","featureIds","tileOptions","tilesetOptions","options","_options$i3s2","colorizeAttributeField","colorizeAttributeData","objectIdField","objectIdAttributeData","attributeValuesMap","i","_loop","_i","_ret","wrap","_callee$","_context2","prev","next","i3s","colorsByAttribute","abrupt","fields","find","_ref3","_options$i3s3","_options$i3s3$colorsB","name","attributeName","includes","type","loadFeatureAttributeData","sent","_ref4","length","calculateColorForAttribute","color","_loop$","_context","value","mode","forEach","colorItem","index","set","stop","delegateYield","t0","attributeValue","_options$i3s","_options$i3s$colorsBy","minValue","maxValue","minColor","maxColor","rate","Math","round","_x6","_x7","_x8","_x9","_loadFeatureAttributeData","_callee2","_ref","_ref2","_options$i3s4","attributeUrls","attributeStorageInfo","attributeIndex","objectIdAttributeUrl","attributeType","_callee2$","_context3","findIndex","_ref5","getUrlWithToken","token","getAttributeValueType","load","I3SAttributeLoader"],"sources":["../../../../src/lib/utils/customize-сolors.ts"],"sourcesContent":["import type {MeshAttribute} from '@loaders.gl/schema';\nimport type {COLOR, I3STileOptions, I3STilesetOptions} from '../../types';\n\nimport {load} from '@loaders.gl/core';\nimport {getAttributeValueType, I3SAttributeLoader} from '../../i3s-attribute-loader';\nimport {I3SLoaderOptions} from '../../i3s-loader';\nimport {getUrlWithToken} from './url-utils';\n\n/**\n * Modify vertex colors array to visualize 3D objects in a attribute driven way\n * @param colors - vertex colors attribute\n * @param featureIds - feature Ids attribute\n * @param tileOptions - tile - related options\n * @param tilesetOptions - tileset-related options\n * @param options - loader options\n * @returns midified colors attribute\n */\nexport async function customizeColors(\n colors: MeshAttribute,\n featureIds: MeshAttribute,\n tileOptions: I3STileOptions,\n tilesetOptions: I3STilesetOptions,\n options?: I3SLoaderOptions\n): Promise<MeshAttribute> {\n if (!options?.i3s?.colorsByAttribute) {\n return colors;\n }\n\n const colorizeAttributeField = tilesetOptions.fields.find(\n ({name}) => name === options?.i3s?.colorsByAttribute?.attributeName\n );\n if (\n !colorizeAttributeField ||\n !['esriFieldTypeDouble', 'esriFieldTypeInteger', 'esriFieldTypeSmallInteger'].includes(\n colorizeAttributeField.type\n )\n ) {\n return colors;\n }\n\n const colorizeAttributeData = await loadFeatureAttributeData(\n colorizeAttributeField.name,\n tileOptions,\n tilesetOptions,\n options\n );\n if (!colorizeAttributeData) {\n return colors;\n }\n\n const objectIdField = tilesetOptions.fields.find(({type}) => type === 'esriFieldTypeOID');\n if (!objectIdField) {\n return colors;\n }\n\n const objectIdAttributeData = await loadFeatureAttributeData(\n objectIdField.name,\n tileOptions,\n tilesetOptions,\n options\n );\n if (!objectIdAttributeData) {\n return colors;\n }\n\n const attributeValuesMap: {[key: number]: COLOR} = {};\n // @ts-expect-error\n for (let i = 0; i < objectIdAttributeData[objectIdField.name].length; i++) {\n // @ts-expect-error\n attributeValuesMap[objectIdAttributeData[objectIdField.name][i]] = calculateColorForAttribute(\n // @ts-expect-error\n colorizeAttributeData[colorizeAttributeField.name][i] as number,\n options\n );\n }\n\n for (let i = 0; i < featureIds.value.length; i++) {\n const color = attributeValuesMap[featureIds.value[i]];\n if (!color) {\n continue; // eslint-disable-line no-continue\n }\n\n /* eslint max-statements: [\"error\", 30] */\n /* eslint complexity: [\"error\", 12] */\n if (options.i3s.colorsByAttribute.mode === 'multiply') {\n // multiplying original mesh and calculated for attribute rgba colors in range 0-255\n color.forEach((colorItem, index) => {\n colors.value[i * 4 + index] = (colors.value[i * 4 + index] * colorItem) / 255;\n });\n } else {\n colors.value.set(color, i * 4);\n }\n }\n\n return colors;\n}\n\n/**\n * Calculate rgba color from the attribute value\n * @param attributeValue - value of the attribute\n * @param options - loader options\n * @returns - color array for a specific attribute value\n */\nfunction calculateColorForAttribute(attributeValue: number, options?: I3SLoaderOptions): COLOR {\n if (!options?.i3s?.colorsByAttribute) {\n return [255, 255, 255, 255];\n }\n const {minValue, maxValue, minColor, maxColor} = options.i3s.colorsByAttribute;\n const rate = (attributeValue - minValue) / (maxValue - minValue);\n const color: COLOR = [255, 255, 255, 255];\n for (let i = 0; i < minColor.length; i++) {\n color[i] = Math.round((maxColor[i] - minColor[i]) * rate + minColor[i]);\n }\n return color;\n}\n\n/**\n * Load feature attribute data from the ArcGIS rest service\n * @param attributeName - attribute name\n * @param tileOptions - tile-related options\n * @param tilesetOptions - tileset-related options\n * @param options - loader options\n * @returns - Array-like list of the attribute values\n */\nasync function loadFeatureAttributeData(\n attributeName: string,\n {attributeUrls}: I3STileOptions,\n {attributeStorageInfo}: I3STilesetOptions,\n options?: I3SLoaderOptions\n): Promise<{[key: string]: string[] | Uint32Array | Uint16Array | Float64Array | null} | null> {\n const attributeIndex = attributeStorageInfo.findIndex(({name}) => attributeName === name);\n if (attributeIndex === -1) {\n return null;\n }\n const objectIdAttributeUrl = getUrlWithToken(attributeUrls[attributeIndex], options?.i3s?.token);\n const attributeType = getAttributeValueType(attributeStorageInfo[attributeIndex]);\n const objectIdAttributeData = await load(objectIdAttributeUrl, I3SAttributeLoader, {\n attributeName,\n attributeType\n });\n\n // @ts-expect-error TODO action engine\n return objectIdAttributeData;\n}\n"],"mappings":"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"}
|