@loaders.gl/tile-converter 4.0.0-alpha.4 → 4.0.0-alpha.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/3d-tiles-attributes-worker.d.ts +28 -0
- package/dist/3d-tiles-attributes-worker.d.ts.map +1 -0
- package/dist/3d-tiles-attributes-worker.js +3 -0
- package/dist/3d-tiles-attributes-worker.js.map +7 -0
- package/dist/3d-tiles-converter/3d-tiles-converter.d.ts +90 -0
- package/dist/3d-tiles-converter/3d-tiles-converter.d.ts.map +1 -0
- package/dist/3d-tiles-converter/3d-tiles-converter.js +273 -231
- package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts +79 -18
- package/dist/3d-tiles-converter/helpers/b3dm-converter.d.ts.map +1 -0
- package/dist/3d-tiles-converter/helpers/b3dm-converter.js +269 -236
- package/dist/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.d.ts +4 -7
- package/dist/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.d.ts.map +1 -0
- package/dist/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js +22 -9
- package/dist/3d-tiles-converter/helpers/texture-atlas.d.ts +9 -0
- package/dist/3d-tiles-converter/helpers/texture-atlas.d.ts.map +1 -0
- package/dist/3d-tiles-converter/helpers/texture-atlas.js +47 -28
- package/dist/3d-tiles-converter/json-templates/tileset.d.ts +15 -0
- package/dist/3d-tiles-converter/json-templates/tileset.d.ts.map +1 -0
- package/dist/3d-tiles-converter/json-templates/tileset.js +42 -36
- package/dist/bundle.d.ts +2 -0
- package/dist/bundle.d.ts.map +1 -0
- package/dist/bundle.js +2 -2
- package/dist/constants.d.ts +2 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +4 -0
- package/dist/converter-cli.d.ts +2 -0
- package/dist/converter-cli.d.ts.map +1 -0
- package/dist/converter-cli.js +280 -0
- package/dist/converter.min.js +186 -190
- package/dist/deps-installer/deps-installer.d.ts +11 -3
- package/dist/deps-installer/deps-installer.d.ts.map +1 -0
- package/dist/deps-installer/deps-installer.js +60 -23
- package/dist/dist.min.js +63496 -0
- package/dist/es5/3d-tiles-attributes-worker.js +25 -0
- package/dist/es5/3d-tiles-attributes-worker.js.map +1 -0
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js +470 -0
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js.map +1 -0
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js +301 -0
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -0
- package/dist/es5/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js +18 -0
- package/dist/es5/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js.map +1 -0
- package/dist/es5/3d-tiles-converter/helpers/texture-atlas.js +33 -0
- package/dist/es5/3d-tiles-converter/helpers/texture-atlas.js.map +1 -0
- package/dist/es5/3d-tiles-converter/json-templates/tileset.js +61 -0
- package/dist/es5/3d-tiles-converter/json-templates/tileset.js.map +1 -0
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/constants.js +9 -0
- package/dist/es5/constants.js.map +1 -0
- package/dist/es5/converter-cli.js +289 -0
- package/dist/es5/converter-cli.js.map +1 -0
- package/dist/es5/deps-installer/deps-installer.js +123 -0
- package/dist/es5/deps-installer/deps-installer.js.map +1 -0
- package/dist/es5/i3s-attributes-worker.js +25 -0
- package/dist/es5/i3s-attributes-worker.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js +116 -0
- package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/coordinate-converter.js +90 -0
- package/dist/es5/i3s-converter/helpers/coordinate-converter.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/create-scene-server-path.js +41 -0
- package/dist/es5/i3s-converter/helpers/create-scene-server-path.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/feature-attributes.js +174 -0
- package/dist/es5/i3s-converter/helpers/feature-attributes.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/geometry-attributes.js +213 -0
- package/dist/es5/i3s-converter/helpers/geometry-attributes.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/geometry-converter.js +1173 -0
- package/dist/es5/i3s-converter/helpers/geometry-converter.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/gltf-attributes.js +83 -0
- package/dist/es5/i3s-converter/helpers/gltf-attributes.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/node-debug.js +76 -0
- package/dist/es5/i3s-converter/helpers/node-debug.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/node-index-document.js +492 -0
- package/dist/es5/i3s-converter/helpers/node-index-document.js.map +1 -0
- package/dist/es5/i3s-converter/helpers/node-pages.js +519 -0
- package/dist/es5/i3s-converter/helpers/node-pages.js.map +1 -0
- package/dist/es5/i3s-converter/i3s-converter.js +1519 -0
- package/dist/es5/i3s-converter/i3s-converter.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/geometry-definitions.js +107 -0
- package/dist/es5/i3s-converter/json-templates/geometry-definitions.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/layers.js +163 -0
- package/dist/es5/i3s-converter/json-templates/layers.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/metadata.js +31 -0
- package/dist/es5/i3s-converter/json-templates/metadata.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/node.js +99 -0
- package/dist/es5/i3s-converter/json-templates/node.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/scene-server.js +39 -0
- package/dist/es5/i3s-converter/json-templates/scene-server.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/shared-resources.js +173 -0
- package/dist/es5/i3s-converter/json-templates/shared-resources.js.map +1 -0
- package/dist/es5/i3s-converter/json-templates/store.js +107 -0
- package/dist/es5/i3s-converter/json-templates/store.js.map +1 -0
- package/dist/es5/i3s-converter/types.js +2 -0
- package/dist/es5/i3s-converter/types.js.map +1 -0
- package/dist/es5/i3s-server/app.js +18 -0
- package/dist/es5/i3s-server/app.js.map +1 -0
- package/dist/es5/i3s-server/controllers/index-controller.js +55 -0
- package/dist/es5/i3s-server/controllers/index-controller.js.map +1 -0
- package/dist/es5/i3s-server/routes/index.js +37 -0
- package/dist/es5/i3s-server/routes/index.js.map +1 -0
- package/dist/es5/index.js +21 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/lib/utils/compress-util.js +346 -0
- package/dist/es5/lib/utils/compress-util.js.map +1 -0
- package/dist/es5/lib/utils/file-utils.js +208 -0
- package/dist/es5/lib/utils/file-utils.js.map +1 -0
- package/dist/es5/lib/utils/lod-conversion-utils.js +44 -0
- package/dist/es5/lib/utils/lod-conversion-utils.js.map +1 -0
- package/dist/es5/lib/utils/queue.js +47 -0
- package/dist/es5/lib/utils/queue.js.map +1 -0
- package/dist/es5/lib/utils/statistic-utills.d.ts +25 -0
- package/dist/es5/lib/utils/statistic-utills.js +147 -0
- package/dist/es5/lib/utils/statistic-utills.js.map +1 -0
- package/dist/es5/lib/utils/write-queue.js +214 -0
- package/dist/es5/lib/utils/write-queue.js.map +1 -0
- package/dist/es5/pgm-loader.js +41 -0
- package/dist/es5/pgm-loader.js.map +1 -0
- package/dist/es5/workers/3d-tiles-attributes-worker.js +28 -0
- package/dist/es5/workers/3d-tiles-attributes-worker.js.map +1 -0
- package/dist/es5/workers/i3s-attributes-worker.js +30 -0
- package/dist/es5/workers/i3s-attributes-worker.js.map +1 -0
- package/dist/esm/3d-tiles-attributes-worker.js +16 -0
- package/dist/esm/3d-tiles-attributes-worker.js.map +1 -0
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js +248 -0
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js.map +1 -0
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js +224 -0
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -0
- package/dist/esm/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js +10 -0
- package/dist/esm/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js.map +1 -0
- package/dist/esm/3d-tiles-converter/helpers/texture-atlas.js +27 -0
- package/dist/esm/3d-tiles-converter/helpers/texture-atlas.js.map +1 -0
- package/dist/esm/3d-tiles-converter/json-templates/tileset.js +37 -0
- package/dist/esm/3d-tiles-converter/json-templates/tileset.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/constants.js +2 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/converter-cli.js +232 -0
- package/dist/esm/converter-cli.js.map +1 -0
- package/dist/esm/deps-installer/deps-installer.js +44 -0
- package/dist/esm/deps-installer/deps-installer.js.map +1 -0
- package/dist/esm/i3s-attributes-worker.js +16 -0
- package/dist/esm/i3s-attributes-worker.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js +105 -0
- package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/coordinate-converter.js +80 -0
- package/dist/esm/i3s-converter/helpers/coordinate-converter.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/create-scene-server-path.js +16 -0
- package/dist/esm/i3s-converter/helpers/create-scene-server-path.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/feature-attributes.js +147 -0
- package/dist/esm/i3s-converter/helpers/feature-attributes.js.map +1 -0
- package/{src → dist/esm}/i3s-converter/helpers/geometry-attributes.js +80 -106
- package/dist/esm/i3s-converter/helpers/geometry-attributes.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/geometry-converter.js +887 -0
- package/dist/esm/i3s-converter/helpers/geometry-converter.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/gltf-attributes.js +76 -0
- package/dist/esm/i3s-converter/helpers/gltf-attributes.js.map +1 -0
- package/{src → dist/esm}/i3s-converter/helpers/node-debug.js +20 -41
- package/dist/esm/i3s-converter/helpers/node-debug.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/node-index-document.js +188 -0
- package/dist/esm/i3s-converter/helpers/node-index-document.js.map +1 -0
- package/dist/esm/i3s-converter/helpers/node-pages.js +206 -0
- package/dist/esm/i3s-converter/helpers/node-pages.js.map +1 -0
- package/dist/esm/i3s-converter/i3s-converter.js +771 -0
- package/dist/esm/i3s-converter/i3s-converter.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/geometry-definitions.js +89 -0
- package/dist/esm/i3s-converter/json-templates/geometry-definitions.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/layers.js +133 -0
- package/dist/esm/i3s-converter/json-templates/layers.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/metadata.js +22 -0
- package/dist/esm/i3s-converter/json-templates/metadata.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/node.js +80 -0
- package/dist/esm/i3s-converter/json-templates/node.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/scene-server.js +28 -0
- package/dist/esm/i3s-converter/json-templates/scene-server.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/shared-resources.js +123 -0
- package/dist/esm/i3s-converter/json-templates/shared-resources.js.map +1 -0
- package/dist/esm/i3s-converter/json-templates/store.js +98 -0
- package/dist/esm/i3s-converter/json-templates/store.js.map +1 -0
- package/dist/esm/i3s-converter/types.js +2 -0
- package/dist/esm/i3s-converter/types.js.map +1 -0
- package/dist/esm/i3s-server/app.js +16 -0
- package/dist/esm/i3s-server/app.js.map +1 -0
- package/dist/esm/i3s-server/bin/www +102 -0
- package/dist/esm/i3s-server/certs/cert.pem +19 -0
- package/dist/esm/i3s-server/certs/key.pem +27 -0
- package/dist/esm/i3s-server/controllers/index-controller.js +24 -0
- package/dist/esm/i3s-server/controllers/index-controller.js.map +1 -0
- package/dist/esm/i3s-server/routes/index.js +16 -0
- package/dist/esm/i3s-server/routes/index.js.map +1 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/utils/compress-util.js +168 -0
- package/dist/esm/lib/utils/compress-util.js.map +1 -0
- package/dist/esm/lib/utils/file-utils.js +87 -0
- package/dist/esm/lib/utils/file-utils.js.map +1 -0
- package/dist/esm/lib/utils/lod-conversion-utils.js +37 -0
- package/dist/esm/lib/utils/lod-conversion-utils.js.map +1 -0
- package/dist/esm/lib/utils/queue.js +15 -0
- package/dist/esm/lib/utils/queue.js.map +1 -0
- package/dist/esm/lib/utils/statistic-utills.d.ts +25 -0
- package/dist/esm/lib/utils/statistic-utills.js +62 -0
- package/dist/esm/lib/utils/statistic-utills.js.map +1 -0
- package/dist/esm/lib/utils/write-queue.js +85 -0
- package/dist/esm/lib/utils/write-queue.js.map +1 -0
- package/dist/esm/pgm-loader.js +15 -0
- package/dist/esm/pgm-loader.js.map +1 -0
- package/dist/esm/workers/3d-tiles-attributes-worker.js +8 -0
- package/dist/esm/workers/3d-tiles-attributes-worker.js.map +1 -0
- package/dist/esm/workers/i3s-attributes-worker.js +7 -0
- package/dist/esm/workers/i3s-attributes-worker.js.map +1 -0
- package/dist/i3s-attributes-worker.d.ts +37 -0
- package/dist/i3s-attributes-worker.d.ts.map +1 -0
- package/dist/i3s-attributes-worker.js +9 -0
- package/dist/i3s-attributes-worker.js.map +7 -0
- package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts +11 -0
- package/dist/i3s-converter/helpers/batch-ids-extensions.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/batch-ids-extensions.js +141 -0
- package/dist/i3s-converter/helpers/coordinate-converter.d.ts +41 -0
- package/dist/i3s-converter/helpers/coordinate-converter.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/coordinate-converter.js +120 -42
- package/dist/i3s-converter/helpers/create-scene-server-path.d.ts +9 -0
- package/dist/i3s-converter/helpers/create-scene-server-path.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/create-scene-server-path.js +27 -15
- package/dist/i3s-converter/helpers/feature-attributes.d.ts +56 -0
- package/dist/i3s-converter/helpers/feature-attributes.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/feature-attributes.js +216 -0
- package/dist/i3s-converter/helpers/geometry-attributes.d.ts +8 -0
- package/dist/i3s-converter/helpers/geometry-attributes.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/geometry-attributes.js +188 -185
- package/dist/i3s-converter/helpers/geometry-converter.d.ts +36 -35
- package/dist/i3s-converter/helpers/geometry-converter.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/geometry-converter.js +1149 -650
- package/dist/i3s-converter/helpers/gltf-attributes.d.ts +9 -0
- package/dist/i3s-converter/helpers/gltf-attributes.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/gltf-attributes.js +88 -0
- package/dist/i3s-converter/helpers/node-debug.d.ts +8 -0
- package/dist/i3s-converter/helpers/node-debug.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/node-debug.js +106 -74
- package/dist/i3s-converter/helpers/node-index-document.d.ts +95 -0
- package/dist/i3s-converter/helpers/node-index-document.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/node-index-document.js +250 -0
- package/dist/i3s-converter/helpers/node-pages.d.ts +125 -113
- package/dist/i3s-converter/helpers/node-pages.d.ts.map +1 -0
- package/dist/i3s-converter/helpers/node-pages.js +313 -133
- package/dist/i3s-converter/i3s-converter.d.ts +267 -0
- package/dist/i3s-converter/i3s-converter.d.ts.map +1 -0
- package/dist/i3s-converter/i3s-converter.js +860 -861
- package/dist/i3s-converter/json-templates/geometry-definitions.d.ts +7 -0
- package/dist/i3s-converter/json-templates/geometry-definitions.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/geometry-definitions.js +87 -0
- package/dist/i3s-converter/json-templates/layers.d.ts +70 -0
- package/dist/i3s-converter/json-templates/layers.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/layers.js +138 -190
- package/dist/i3s-converter/json-templates/metadata.d.ts +22 -0
- package/dist/i3s-converter/json-templates/metadata.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/metadata.js +25 -22
- package/dist/i3s-converter/json-templates/node.d.ts +61 -0
- package/dist/i3s-converter/json-templates/node.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/node.js +88 -79
- package/dist/i3s-converter/json-templates/scene-server.d.ts +28 -0
- package/dist/i3s-converter/json-templates/scene-server.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/scene-server.js +31 -28
- package/dist/i3s-converter/json-templates/shared-resources.d.ts +14 -0
- package/dist/i3s-converter/json-templates/shared-resources.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/shared-resources.js +124 -125
- package/dist/i3s-converter/json-templates/store.d.ts +95 -0
- package/dist/i3s-converter/json-templates/store.d.ts.map +1 -0
- package/dist/i3s-converter/json-templates/store.js +100 -95
- package/dist/i3s-converter/types.d.ts +145 -0
- package/dist/i3s-converter/types.d.ts.map +1 -0
- package/dist/i3s-converter/types.js +2 -0
- package/dist/i3s-server/app.d.ts +3 -0
- package/dist/i3s-server/app.d.ts.map +1 -0
- package/dist/i3s-server/app.js +2 -9
- package/dist/i3s-server/controllers/index-controller.d.ts +2 -0
- package/dist/i3s-server/controllers/index-controller.d.ts.map +1 -0
- package/dist/i3s-server/controllers/index-controller.js +16 -24
- package/dist/i3s-server/routes/index.d.ts +3 -0
- package/dist/i3s-server/routes/index.d.ts.map +1 -0
- package/dist/i3s-server/routes/index.js +11 -15
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -5
- package/dist/lib/utils/compress-util.d.ts +45 -0
- package/dist/lib/utils/compress-util.d.ts.map +1 -0
- package/dist/lib/utils/compress-util.js +238 -160
- package/dist/lib/utils/file-utils.d.ts +22 -14
- package/dist/lib/utils/file-utils.d.ts.map +1 -0
- package/dist/lib/utils/file-utils.js +133 -36
- package/dist/lib/utils/lod-conversion-utils.d.ts +21 -12
- package/dist/lib/utils/lod-conversion-utils.d.ts.map +1 -0
- package/dist/lib/utils/lod-conversion-utils.js +72 -39
- package/dist/lib/utils/queue.d.ts +7 -0
- package/dist/lib/utils/queue.d.ts.map +1 -0
- package/dist/lib/utils/queue.js +18 -0
- package/dist/lib/utils/statistic-utills.d.ts +3 -25
- package/dist/lib/utils/statistic-utills.d.ts.map +1 -0
- package/dist/lib/utils/statistic-utills.js +58 -67
- package/dist/lib/utils/write-queue.d.ts +39 -0
- package/dist/lib/utils/write-queue.d.ts.map +1 -0
- package/dist/lib/utils/write-queue.js +80 -0
- package/dist/pgm-loader.d.ts +6 -0
- package/dist/pgm-loader.d.ts.map +1 -0
- package/dist/pgm-loader.js +23 -14
- package/dist/workers/3d-tiles-attributes-worker.d.ts +2 -0
- package/dist/workers/3d-tiles-attributes-worker.d.ts.map +1 -0
- package/dist/workers/3d-tiles-attributes-worker.js +9 -0
- package/dist/workers/i3s-attributes-worker.d.ts +2 -0
- package/dist/workers/i3s-attributes-worker.d.ts.map +1 -0
- package/dist/workers/i3s-attributes-worker.js +5 -0
- package/package.json +35 -24
- package/src/3d-tiles-attributes-worker.ts +43 -0
- package/src/3d-tiles-converter/3d-tiles-converter.ts +124 -59
- package/src/3d-tiles-converter/helpers/{b3dm-converter.js → b3dm-converter.ts} +71 -38
- package/src/3d-tiles-converter/helpers/{i3s-obb-to-3d-tiles-obb.js → i3s-obb-to-3d-tiles-obb.ts} +16 -1
- package/src/3d-tiles-converter/helpers/texture-atlas.ts +4 -4
- package/src/3d-tiles-converter/json-templates/{tileset.js → tileset.ts} +9 -9
- package/src/constants.ts +2 -0
- package/src/converter-cli.ts +370 -0
- package/src/deps-installer/deps-installer.ts +71 -0
- package/src/i3s-attributes-worker.ts +50 -0
- package/src/i3s-converter/helpers/batch-ids-extensions.ts +206 -0
- package/src/i3s-converter/helpers/coordinate-converter.ts +87 -27
- package/src/i3s-converter/helpers/create-scene-server-path.ts +29 -0
- package/src/i3s-converter/helpers/feature-attributes.ts +247 -0
- package/src/i3s-converter/helpers/geometry-attributes.ts +267 -0
- package/src/i3s-converter/helpers/geometry-converter.ts +1608 -0
- package/src/i3s-converter/helpers/gltf-attributes.ts +103 -0
- package/src/i3s-converter/helpers/node-debug.ts +146 -0
- package/src/i3s-converter/helpers/node-index-document.ts +315 -0
- package/src/i3s-converter/helpers/node-pages.ts +344 -0
- package/src/i3s-converter/i3s-converter.ts +557 -627
- package/src/i3s-converter/json-templates/geometry-definitions.ts +83 -0
- package/src/i3s-converter/json-templates/layers.ts +137 -0
- package/src/i3s-converter/json-templates/{metadata.js → metadata.ts} +2 -2
- package/src/i3s-converter/json-templates/{node.js → node.ts} +12 -12
- package/src/i3s-converter/json-templates/{scene-server.js → scene-server.ts} +2 -2
- package/src/i3s-converter/json-templates/{shared-resources.js → shared-resources.ts} +17 -17
- package/src/i3s-converter/types.ts +165 -0
- package/src/index.ts +0 -4
- package/src/lib/utils/{compress-util.js → compress-util.ts} +105 -18
- package/src/lib/utils/file-utils.ts +139 -0
- package/src/lib/utils/{lod-conversion-utils.js → lod-conversion-utils.ts} +27 -5
- package/src/lib/utils/queue.ts +17 -0
- package/src/lib/utils/write-queue.ts +110 -0
- package/src/pgm-loader.ts +3 -3
- package/src/workers/3d-tiles-attributes-worker.ts +6 -0
- package/src/workers/i3s-attributes-worker.ts +7 -0
- package/dist/3d-tiles-converter/3d-tiles-converter.js.map +0 -1
- package/dist/3d-tiles-converter/helpers/b3dm-converter.js.map +0 -1
- package/dist/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js.map +0 -1
- package/dist/3d-tiles-converter/helpers/texture-atlas.js.map +0 -1
- package/dist/3d-tiles-converter/json-templates/tileset.js.map +0 -1
- package/dist/bundle.js.map +0 -1
- package/dist/deps-installer/deps-installer.js.map +0 -1
- package/dist/i3s-converter/helpers/coordinate-converter.js.map +0 -1
- package/dist/i3s-converter/helpers/create-scene-server-path.js.map +0 -1
- package/dist/i3s-converter/helpers/geometry-attributes.js.map +0 -1
- package/dist/i3s-converter/helpers/geometry-converter.js.map +0 -1
- package/dist/i3s-converter/helpers/node-debug.js.map +0 -1
- package/dist/i3s-converter/helpers/node-pages.js.map +0 -1
- package/dist/i3s-converter/i3s-converter.js.map +0 -1
- package/dist/i3s-converter/json-templates/layers.js.map +0 -1
- package/dist/i3s-converter/json-templates/metadata.js.map +0 -1
- package/dist/i3s-converter/json-templates/node.js.map +0 -1
- package/dist/i3s-converter/json-templates/scene-server.js.map +0 -1
- package/dist/i3s-converter/json-templates/shared-resources.js.map +0 -1
- package/dist/i3s-converter/json-templates/store.js.map +0 -1
- package/dist/i3s-server/app.js.map +0 -1
- package/dist/i3s-server/controllers/index-controller.js.map +0 -1
- package/dist/i3s-server/routes/index.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/lib/geoid-height-model.d.ts +0 -41
- package/dist/lib/geoid-height-model.js +0 -140
- package/dist/lib/geoid-height-model.js.map +0 -1
- package/dist/lib/pgm-parser.d.ts +0 -14
- package/dist/lib/pgm-parser.js +0 -183
- package/dist/lib/pgm-parser.js.map +0 -1
- package/dist/lib/utils/compress-util.js.map +0 -1
- package/dist/lib/utils/compress-utils.d.ts +0 -53
- package/dist/lib/utils/file-utils.js.map +0 -1
- package/dist/lib/utils/lod-conversion-utils.js.map +0 -1
- package/dist/lib/utils/statistic-utills.js.map +0 -1
- package/dist/pgm-loader.js.map +0 -1
- package/src/3d-tiles-converter/helpers/b3dm-converter.d.ts +0 -23
- package/src/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.d.ts +0 -16
- package/src/deps-installer/deps-installer.d.ts +0 -10
- package/src/deps-installer/deps-installer.js +0 -22
- package/src/i3s-converter/helpers/create-scene-server-path.js +0 -25
- package/src/i3s-converter/helpers/geometry-converter.d.ts +0 -40
- package/src/i3s-converter/helpers/geometry-converter.js +0 -915
- package/src/i3s-converter/helpers/node-pages.d.ts +0 -144
- package/src/i3s-converter/helpers/node-pages.js +0 -208
- package/src/i3s-converter/json-templates/layers.js +0 -199
- package/src/lib/geoid-height-model.d.ts +0 -41
- package/src/lib/geoid-height-model.js +0 -239
- package/src/lib/pgm-parser.d.ts +0 -14
- package/src/lib/pgm-parser.js +0 -179
- package/src/lib/utils/compress-utils.d.ts +0 -53
- package/src/lib/utils/file-utils.d.ts +0 -43
- package/src/lib/utils/file-utils.js +0 -38
- package/src/lib/utils/lod-conversion-utils.d.ts +0 -32
- /package/dist/{i3s-server → es5/i3s-server}/bin/www +0 -0
- /package/dist/{i3s-server → es5/i3s-server}/certs/cert.pem +0 -0
- /package/dist/{i3s-server → es5/i3s-server}/certs/key.pem +0 -0
- /package/src/i3s-converter/json-templates/{store.js → store.ts} +0 -0
- /package/src/lib/utils/{statistic-utills.js → statistic-utills.ts} +0 -0
|
@@ -1,10 +1,22 @@
|
|
|
1
|
+
import { BoundingVolumes } from '@loaders.gl/i3s';
|
|
2
|
+
import { Tile3D } from '@loaders.gl/tiles';
|
|
1
3
|
/**
|
|
2
|
-
*
|
|
3
|
-
*
|
|
4
|
+
* Do conversion from geometric error to screen threshold
|
|
5
|
+
*
|
|
6
|
+
* In 3DTiles we have HLOD logic and parent tile also has bigger lodMetric value then its children.
|
|
7
|
+
* In I3s we have reverse logic related to maxError. Parent has lower maxError than its child.
|
|
8
|
+
* In nodes where are no children tile.lodMetricValue is 0. This is because of logic of HLOD in 3DTiles
|
|
9
|
+
* 3DTiles spec:
|
|
10
|
+
* https://github.com/CesiumGS/3d-tiles/tree/master/specification#geometric-error
|
|
11
|
+
* I3S spec:
|
|
12
|
+
* https://github.com/Esri/i3s-spec/blob/master/docs/1.7/lodSelection.cmn.md
|
|
13
|
+
* To avoid infinity values when we do calculations of maxError we shold replace 0 with value which allows us
|
|
14
|
+
* to make child maxError bigger than his parent maxError.
|
|
15
|
+
*
|
|
4
16
|
* @param tile - 3d-tiles tile Object
|
|
5
17
|
* @param coordinates - node converted coordinates
|
|
6
18
|
* @returns An array of LOD metrics in format compatible with i3s 3DNodeIndexDocument.lodSelection
|
|
7
|
-
* @example
|
|
19
|
+
* @example
|
|
8
20
|
* [
|
|
9
21
|
{
|
|
10
22
|
"metricType": "maxScreenThresholdSQ",
|
|
@@ -16,17 +28,14 @@
|
|
|
16
28
|
}
|
|
17
29
|
]
|
|
18
30
|
*/
|
|
19
|
-
export function convertGeometricErrorToScreenThreshold(
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}
|
|
24
|
-
): Array<{metricType: string; maxError: number}>;
|
|
25
|
-
|
|
31
|
+
export declare function convertGeometricErrorToScreenThreshold(tile: Tile3D, coordinates: BoundingVolumes): {
|
|
32
|
+
metricType: string;
|
|
33
|
+
maxError: number;
|
|
34
|
+
}[];
|
|
26
35
|
/**
|
|
27
36
|
* Convert LOD metric from "Screen Threshold" to "Screen Space Error"
|
|
28
37
|
* @param node - i3s node data
|
|
29
38
|
* @returns lod metric in 3d-tiles format
|
|
30
|
-
* @todo implement this function
|
|
31
39
|
*/
|
|
32
|
-
export function convertScreenThresholdToGeometricError(node:
|
|
40
|
+
export declare function convertScreenThresholdToGeometricError(node: Tile3D): number;
|
|
41
|
+
//# sourceMappingURL=lod-conversion-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lod-conversion-utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/lod-conversion-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAC,MAAM,EAAC,MAAM,mBAAmB,CAAC;AAIzC;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,wBAAgB,sCAAsC,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,eAAe;gBAC9D,MAAM;cAAY,MAAM;IAqB1D;AAED;;;;GAIG;AACH,wBAAgB,sCAAsC,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAe3E"}
|
|
@@ -1,43 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.convertScreenThresholdToGeometricError = exports.convertGeometricErrorToScreenThreshold = void 0;
|
|
4
|
+
// https://cesium.com/docs/cesiumjs-ref-doc/Cesium3DTileset.html
|
|
1
5
|
const DEFAULT_MAXIMUM_SCREEN_SPACE_ERROR = 16;
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
6
|
+
/**
|
|
7
|
+
* Do conversion from geometric error to screen threshold
|
|
8
|
+
*
|
|
9
|
+
* In 3DTiles we have HLOD logic and parent tile also has bigger lodMetric value then its children.
|
|
10
|
+
* In I3s we have reverse logic related to maxError. Parent has lower maxError than its child.
|
|
11
|
+
* In nodes where are no children tile.lodMetricValue is 0. This is because of logic of HLOD in 3DTiles
|
|
12
|
+
* 3DTiles spec:
|
|
13
|
+
* https://github.com/CesiumGS/3d-tiles/tree/master/specification#geometric-error
|
|
14
|
+
* I3S spec:
|
|
15
|
+
* https://github.com/Esri/i3s-spec/blob/master/docs/1.7/lodSelection.cmn.md
|
|
16
|
+
* To avoid infinity values when we do calculations of maxError we shold replace 0 with value which allows us
|
|
17
|
+
* to make child maxError bigger than his parent maxError.
|
|
18
|
+
*
|
|
19
|
+
* @param tile - 3d-tiles tile Object
|
|
20
|
+
* @param coordinates - node converted coordinates
|
|
21
|
+
* @returns An array of LOD metrics in format compatible with i3s 3DNodeIndexDocument.lodSelection
|
|
22
|
+
* @example
|
|
23
|
+
* [
|
|
24
|
+
{
|
|
25
|
+
"metricType": "maxScreenThresholdSQ",
|
|
26
|
+
"maxError": 870638.071285568
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
"metricType": "maxScreenThreshold",
|
|
30
|
+
"maxError": 1052.8679031638949
|
|
31
|
+
}
|
|
32
|
+
]
|
|
33
|
+
*/
|
|
34
|
+
function convertGeometricErrorToScreenThreshold(tile, coordinates) {
|
|
35
|
+
const lodSelection = [];
|
|
36
|
+
const boundingVolume = tile.boundingVolume;
|
|
37
|
+
const lodMetricValue = tile.lodMetricValue || 0.1;
|
|
38
|
+
const maxScreenThreshold = {
|
|
39
|
+
metricType: 'maxScreenThreshold',
|
|
40
|
+
maxError: (coordinates.mbs[3] * 2 * DEFAULT_MAXIMUM_SCREEN_SPACE_ERROR) / lodMetricValue
|
|
41
|
+
};
|
|
42
|
+
const maxScreenThresholdSQ = {
|
|
43
|
+
metricType: 'maxScreenThresholdSQ',
|
|
44
|
+
maxError: Math.PI * 0.25 * maxScreenThreshold.maxError * maxScreenThreshold.maxError
|
|
45
|
+
};
|
|
46
|
+
if (boundingVolume.constructor.name === 'OrientedBoundingBox') {
|
|
47
|
+
lodSelection.push(maxScreenThresholdSQ);
|
|
48
|
+
lodSelection.push(maxScreenThreshold);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
lodSelection.push(maxScreenThreshold);
|
|
52
|
+
lodSelection.push(maxScreenThresholdSQ);
|
|
53
|
+
}
|
|
54
|
+
return lodSelection;
|
|
24
55
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
56
|
+
exports.convertGeometricErrorToScreenThreshold = convertGeometricErrorToScreenThreshold;
|
|
57
|
+
/**
|
|
58
|
+
* Convert LOD metric from "Screen Threshold" to "Screen Space Error"
|
|
59
|
+
* @param node - i3s node data
|
|
60
|
+
* @returns lod metric in 3d-tiles format
|
|
61
|
+
*/
|
|
62
|
+
function convertScreenThresholdToGeometricError(node) {
|
|
63
|
+
const metricData = node.header.lodSelection.maxScreenThreshold || {};
|
|
64
|
+
let maxError = metricData.maxError;
|
|
65
|
+
if (!maxError) {
|
|
66
|
+
const sqMetricData = node.header.lodSelection.maxScreenThresholdSQ;
|
|
67
|
+
if (sqMetricData) {
|
|
68
|
+
maxError = Math.sqrt(sqMetricData.maxError / (Math.PI * 0.25));
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
if (!maxError) {
|
|
72
|
+
maxError = DEFAULT_MAXIMUM_SCREEN_SPACE_ERROR;
|
|
34
73
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
if (!maxError) {
|
|
38
|
-
maxError = DEFAULT_MAXIMUM_SCREEN_SPACE_ERROR;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
return node.header.mbs[3] * 2 * DEFAULT_MAXIMUM_SCREEN_SPACE_ERROR / maxError;
|
|
74
|
+
return (node.header.mbs[3] * 2 * DEFAULT_MAXIMUM_SCREEN_SPACE_ERROR) / maxError;
|
|
42
75
|
}
|
|
43
|
-
|
|
76
|
+
exports.convertScreenThresholdToGeometricError = convertScreenThresholdToGeometricError;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/queue.ts"],"names":[],"mappings":"AAAA,qBAAa,KAAK,CAAC,CAAC,CAAE,SAAQ,KAAK,CAAC,CAAC,CAAC;IACpC,OAAO,CAAC,GAAG,EAAE,CAAC;IAId,OAAO,IAAI,CAAC,GAAG,SAAS;IAIxB,IAAI,IAAI,CAAC;IAIT,OAAO;CAGR"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Queue = void 0;
|
|
4
|
+
class Queue extends Array {
|
|
5
|
+
enqueue(val) {
|
|
6
|
+
this.push(val);
|
|
7
|
+
}
|
|
8
|
+
dequeue() {
|
|
9
|
+
return this.shift();
|
|
10
|
+
}
|
|
11
|
+
peek() {
|
|
12
|
+
return this[0];
|
|
13
|
+
}
|
|
14
|
+
isEmpty() {
|
|
15
|
+
return this.length === 0;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.Queue = Queue;
|
|
@@ -1,25 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
* @param coordinates - node converted coordinates
|
|
5
|
-
* @returns String which characterizes conversion time period
|
|
6
|
-
*/
|
|
7
|
-
export function timeConverter(time: [number, number]): String;
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Calculate files sizes after conversion.
|
|
11
|
-
* @param params - Object with params of conversion.
|
|
12
|
-
* @returns Promise with generated files size in bytes.
|
|
13
|
-
*/
|
|
14
|
-
export function calculateFilesSize(params: {
|
|
15
|
-
slpk: boolean;
|
|
16
|
-
outputPath: string;
|
|
17
|
-
tilesetName: string;
|
|
18
|
-
}): Number;
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Reqursivelly calculate files sizes in directory.
|
|
22
|
-
* @param dirPath - Directory path.
|
|
23
|
-
* @returns Promise with files size in directory.
|
|
24
|
-
*/
|
|
25
|
-
export function getTotalFilesSize(dirPath: string): Number;
|
|
1
|
+
export declare function timeConverter(time: any): string;
|
|
2
|
+
export declare function calculateFilesSize(params: any): Promise<number | null>;
|
|
3
|
+
//# sourceMappingURL=statistic-utills.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"statistic-utills.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/statistic-utills.ts"],"names":[],"mappings":"AAIA,wBAAgB,aAAa,CAAC,IAAI,KAAA,UA4BjC;AAED,wBAAsB,kBAAkB,CAAC,MAAM,KAAA,0BAkB9C"}
|
|
@@ -1,73 +1,64 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
result
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
return result;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateFilesSize = exports.timeConverter = void 0;
|
|
4
|
+
const path_1 = require("path");
|
|
5
|
+
const fs_1 = require("fs");
|
|
6
|
+
const file_utils_1 = require("./file-utils");
|
|
7
|
+
function timeConverter(time) {
|
|
8
|
+
const nanoSecondsInMillisecond = 1e6;
|
|
9
|
+
let timeInSeconds = time[0];
|
|
10
|
+
const hours = Math.floor(timeInSeconds / 3600);
|
|
11
|
+
timeInSeconds = timeInSeconds - hours * 3600;
|
|
12
|
+
const minutes = Math.floor(timeInSeconds / 60);
|
|
13
|
+
timeInSeconds = timeInSeconds - minutes * 60;
|
|
14
|
+
const seconds = Math.floor(timeInSeconds);
|
|
15
|
+
const milliseconds = time[1] / nanoSecondsInMillisecond;
|
|
16
|
+
let result = '';
|
|
17
|
+
if (hours) {
|
|
18
|
+
result += `${hours}h `;
|
|
19
|
+
}
|
|
20
|
+
if (minutes) {
|
|
21
|
+
result += `${minutes}m `;
|
|
22
|
+
}
|
|
23
|
+
if (seconds) {
|
|
24
|
+
result += `${seconds}s`;
|
|
25
|
+
}
|
|
26
|
+
if (!result) {
|
|
27
|
+
result += `${milliseconds}ms`;
|
|
28
|
+
}
|
|
29
|
+
return result;
|
|
32
30
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
slpk,
|
|
36
|
-
outputPath
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
31
|
+
exports.timeConverter = timeConverter;
|
|
32
|
+
async function calculateFilesSize(params) {
|
|
33
|
+
const { slpk, outputPath, tilesetName } = params;
|
|
34
|
+
const fullOutputPath = (0, file_utils_1.getAbsoluteFilePath)(outputPath);
|
|
35
|
+
try {
|
|
36
|
+
if (slpk) {
|
|
37
|
+
const slpkPath = (0, path_1.join)(fullOutputPath, `${tilesetName}.slpk`);
|
|
38
|
+
const stat = await fs_1.promises.stat(slpkPath);
|
|
39
|
+
return stat.size;
|
|
40
|
+
}
|
|
41
|
+
const directoryPath = (0, path_1.join)(fullOutputPath, tilesetName);
|
|
42
|
+
const totalSize = await getTotalFilesSize(directoryPath);
|
|
43
|
+
return totalSize;
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
console.log('Calculate file sizes error: ', error); // eslint-disable-line
|
|
47
|
+
return null;
|
|
46
48
|
}
|
|
47
|
-
|
|
48
|
-
const directoryPath = join(fullOutputPath, tilesetName);
|
|
49
|
-
const totalSize = await getTotalFilesSize(directoryPath);
|
|
50
|
-
return totalSize;
|
|
51
|
-
} catch (error) {
|
|
52
|
-
console.log('Calculate file sizes error: ', error);
|
|
53
|
-
return null;
|
|
54
|
-
}
|
|
55
49
|
}
|
|
56
|
-
|
|
50
|
+
exports.calculateFilesSize = calculateFilesSize;
|
|
57
51
|
async function getTotalFilesSize(dirPath) {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
52
|
+
let totalFileSize = 0;
|
|
53
|
+
const files = await fs_1.promises.readdir(dirPath);
|
|
54
|
+
for (const file of files) {
|
|
55
|
+
const fileStat = await fs_1.promises.stat((0, path_1.join)(dirPath, file));
|
|
56
|
+
if (fileStat.isDirectory()) {
|
|
57
|
+
totalFileSize += await getTotalFilesSize((0, path_1.join)(dirPath, file));
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
totalFileSize += fileStat.size;
|
|
61
|
+
}
|
|
68
62
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
return totalFileSize;
|
|
63
|
+
return totalFileSize;
|
|
72
64
|
}
|
|
73
|
-
//# sourceMappingURL=statistic-utills.js.map
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Queue } from './queue';
|
|
2
|
+
export type WriteQueueItem = {
|
|
3
|
+
archiveKey?: string;
|
|
4
|
+
/**
|
|
5
|
+
* writePromise() returns a Promise that will be awaited in Promise.allSettled(promises);
|
|
6
|
+
* Arguments for this call are specified in writeQueue.enqueue call like this:
|
|
7
|
+
* await writeQueue.enqueue({
|
|
8
|
+
* archiveKey: `nodePages/xxx.json.gz`,
|
|
9
|
+
* writePromise: () => writeFileForSlpk(slpkPath, data, `xxx.json`)
|
|
10
|
+
* });
|
|
11
|
+
* Note, a function like writeFileForSlpk should NOT be called when initializing the object for enqueue().
|
|
12
|
+
* If he function is called, the promise will be created
|
|
13
|
+
* and the function will allocate resources (file descriptors) for file writing.
|
|
14
|
+
* It will be done for ALL items in the queue, which is not supposed to happen.
|
|
15
|
+
* That's why the function should be passed as
|
|
16
|
+
* writePromise: () => writeFileForSlpk(slpkPath, content, `xxx.json`)
|
|
17
|
+
* instead of
|
|
18
|
+
* writePromise: writeFileForSlpk(slpkPath, content, `xxx.json`) // INCORRECT !
|
|
19
|
+
*/
|
|
20
|
+
writePromise: () => Promise<string | null>;
|
|
21
|
+
};
|
|
22
|
+
export default class WriteQueue<T extends WriteQueueItem> extends Queue<T> {
|
|
23
|
+
private intervalId?;
|
|
24
|
+
writePromise: Promise<void> | null;
|
|
25
|
+
fileMap: {
|
|
26
|
+
[key: string]: string;
|
|
27
|
+
};
|
|
28
|
+
listeningInterval: number;
|
|
29
|
+
writeConcurrency: number;
|
|
30
|
+
constructor(listeningInterval?: number, writeConcurrency?: number);
|
|
31
|
+
enqueue(val: T, writeImmediately?: boolean): Promise<void>;
|
|
32
|
+
startListening(): void;
|
|
33
|
+
stopListening(): void;
|
|
34
|
+
startWrite(): Promise<void>;
|
|
35
|
+
finalize(): Promise<void>;
|
|
36
|
+
private doWrite;
|
|
37
|
+
private updateFileMap;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=write-queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write-queue.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/write-queue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,EAAC,MAAM,SAAS,CAAC;AAM9B,MAAM,MAAM,cAAc,GAAG;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB;;;;;;;;;;;;;;;OAeG;IACH,YAAY,EAAE,MAAM,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CAC5C,CAAC;AAEF,MAAM,CAAC,OAAO,OAAO,UAAU,CAAC,CAAC,SAAS,cAAc,CAAE,SAAQ,KAAK,CAAC,CAAC,CAAC;IACxE,OAAO,CAAC,UAAU,CAAC,CAAiB;IAC7B,YAAY,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAQ;IAC1C,OAAO,EAAE;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAC,CAAM;IACtC,iBAAiB,EAAE,MAAM,CAAC;IAC1B,gBAAgB,EAAE,MAAM,CAAC;gBAEpB,iBAAiB,GAAE,MAAa,EAAE,gBAAgB,GAAE,MAAY;IAMtE,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,gBAAgB,GAAE,OAAe;IAgBvD,cAAc;IAId,aAAa;IAMP,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ3B,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;YAKjB,OAAO;IAmBrB,OAAO,CAAC,aAAa;CAWtB"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const queue_1 = require("./queue");
|
|
7
|
+
const process_1 = __importDefault(require("process"));
|
|
8
|
+
/** Memory limit size is based on testing */
|
|
9
|
+
const MEMORY_LIMIT = 4 * 1024 * 1024 * 1024; // 4GB
|
|
10
|
+
class WriteQueue extends queue_1.Queue {
|
|
11
|
+
constructor(listeningInterval = 2000, writeConcurrency = 400) {
|
|
12
|
+
super();
|
|
13
|
+
this.writePromise = null;
|
|
14
|
+
this.fileMap = {};
|
|
15
|
+
this.listeningInterval = listeningInterval;
|
|
16
|
+
this.writeConcurrency = writeConcurrency;
|
|
17
|
+
}
|
|
18
|
+
async enqueue(val, writeImmediately = false) {
|
|
19
|
+
if (writeImmediately) {
|
|
20
|
+
const { archiveKey, writePromise } = val;
|
|
21
|
+
const result = await writePromise();
|
|
22
|
+
if (archiveKey && result) {
|
|
23
|
+
this.fileMap[archiveKey] = result;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
super.enqueue(val);
|
|
28
|
+
/** https://nodejs.org/docs/latest-v14.x/api/process.html#process_process_memoryusage */
|
|
29
|
+
if (process_1.default.memoryUsage().rss > MEMORY_LIMIT) {
|
|
30
|
+
await this.startWrite();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
startListening() {
|
|
35
|
+
this.intervalId = setInterval(this.startWrite.bind(this), this.listeningInterval);
|
|
36
|
+
}
|
|
37
|
+
stopListening() {
|
|
38
|
+
if (this.intervalId) {
|
|
39
|
+
clearInterval(this.intervalId);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async startWrite() {
|
|
43
|
+
if (!this.writePromise) {
|
|
44
|
+
this.writePromise = this.doWrite();
|
|
45
|
+
}
|
|
46
|
+
await this.writePromise;
|
|
47
|
+
this.writePromise = null;
|
|
48
|
+
}
|
|
49
|
+
async finalize() {
|
|
50
|
+
this.stopListening();
|
|
51
|
+
await this.startWrite();
|
|
52
|
+
}
|
|
53
|
+
async doWrite() {
|
|
54
|
+
while (this.length) {
|
|
55
|
+
const promises = [];
|
|
56
|
+
const archiveKeys = [];
|
|
57
|
+
for (let i = 0; i < this.writeConcurrency; i++) {
|
|
58
|
+
const item = this.dequeue();
|
|
59
|
+
if (!item) {
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
const { archiveKey, writePromise } = item;
|
|
63
|
+
archiveKeys.push(archiveKey);
|
|
64
|
+
const promise = writePromise();
|
|
65
|
+
promises.push(promise);
|
|
66
|
+
}
|
|
67
|
+
const writeResults = await Promise.allSettled(promises);
|
|
68
|
+
this.updateFileMap(archiveKeys, writeResults);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
updateFileMap(archiveKeys, writeResults) {
|
|
72
|
+
for (let i = 0; i < archiveKeys.length; i++) {
|
|
73
|
+
const archiveKey = archiveKeys[i];
|
|
74
|
+
if (archiveKey && 'value' in writeResults[i]) {
|
|
75
|
+
this.fileMap[archiveKey] = writeResults[i].value;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
exports.default = WriteQueue;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pgm-loader.d.ts","sourceRoot":"","sources":["../src/pgm-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAO/D;;GAEG;AACH,eAAO,MAAM,SAAS,EAAE,gBAavB,CAAC"}
|
package/dist/pgm-loader.js
CHANGED
|
@@ -1,15 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PGMLoader = void 0;
|
|
4
|
+
const geoid_1 = require("@math.gl/geoid");
|
|
5
|
+
// __VERSION__ is injected by babel-plugin-version-inline
|
|
6
|
+
// @ts-ignore TS2304: Cannot find name '__VERSION__'.
|
|
7
|
+
const VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';
|
|
8
|
+
/**
|
|
9
|
+
* Loader for PGM - Netpbm grayscale image format
|
|
10
|
+
*/
|
|
11
|
+
exports.PGMLoader = {
|
|
12
|
+
name: 'PGM - Netpbm grayscale image format',
|
|
13
|
+
id: 'pgm',
|
|
14
|
+
module: 'tile-converter',
|
|
15
|
+
version: VERSION,
|
|
16
|
+
mimeTypes: ['image/x-portable-graymap'],
|
|
17
|
+
// @ts-expect-error LoaderOptions does not have cubic parameter
|
|
18
|
+
parse: async (arrayBuffer, options) => (0, geoid_1.parsePGM)(new Uint8Array(arrayBuffer), options),
|
|
19
|
+
extensions: ['pgm'],
|
|
20
|
+
options: {
|
|
21
|
+
// TODO - use pgm namespace
|
|
22
|
+
cubic: false
|
|
23
|
+
}
|
|
14
24
|
};
|
|
15
|
-
//# sourceMappingURL=pgm-loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3d-tiles-attributes-worker.d.ts","sourceRoot":"","sources":["../../src/workers/3d-tiles-attributes-worker.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const worker_utils_1 = require("@loaders.gl/worker-utils");
|
|
7
|
+
const b3dm_converter_1 = __importDefault(require("../3d-tiles-converter/helpers/b3dm-converter"));
|
|
8
|
+
const b3dmConverter = new b3dm_converter_1.default();
|
|
9
|
+
(0, worker_utils_1.createWorker)(async (data, options = {}) => b3dmConverter.convert(data, options.featureAttributes));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"i3s-attributes-worker.d.ts","sourceRoot":"","sources":["../../src/workers/i3s-attributes-worker.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const worker_utils_1 = require("@loaders.gl/worker-utils");
|
|
4
|
+
const geometry_converter_1 = require("../i3s-converter/helpers/geometry-converter");
|
|
5
|
+
(0, worker_utils_1.createWorker)(async (data, options = {}) => await (0, geometry_converter_1.convertAttributes)(data, options.materialAndTextureList, options.useCartesianPositions));
|