@loaders.gl/tile-converter 3.1.0-alpha.5 → 3.1.0-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bundle.js +86025 -0
- package/dist/converter.min.js +22 -22
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js +2 -2
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/geometry-converter.js +2 -18
- package/dist/es5/i3s-converter/helpers/geometry-converter.js.map +1 -1
- package/dist/es5/pgm-loader.js +1 -1
- package/dist/es5/pgm-loader.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js +1 -1
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/geometry-converter.js +2 -18
- package/dist/esm/i3s-converter/helpers/geometry-converter.js.map +1 -1
- package/dist/esm/pgm-loader.js +1 -1
- package/dist/esm/pgm-loader.js.map +1 -1
- package/package.json +18 -17
- package/src/3d-tiles-converter/helpers/b3dm-converter.js +1 -1
- package/src/i3s-converter/helpers/geometry-converter.js +5 -13
- package/dist/dist.min.js +0 -94
- package/dist/dist.min.js.map +0 -1
|
@@ -15,10 +15,10 @@ var _images = require("@loaders.gl/images");
|
|
|
15
15
|
|
|
16
16
|
var _core2 = require("@math.gl/core");
|
|
17
17
|
|
|
18
|
-
var _textureAtlas = require("./texture-atlas");
|
|
19
|
-
|
|
20
18
|
var _geospatial = require("@math.gl/geospatial");
|
|
21
19
|
|
|
20
|
+
var _textureAtlas = require("./texture-atlas");
|
|
21
|
+
|
|
22
22
|
const Z_UP_TO_Y_UP_MATRIX = new _core2.Matrix4([1, 0, 0, 0, 0, 0, -1, 0, 0, 1, 0, 0, 0, 0, 0, 1]);
|
|
23
23
|
const scratchVector = new _core2.Vector3();
|
|
24
24
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/3d-tiles-converter/helpers/b3dm-converter.js"],"names":["Z_UP_TO_Y_UP_MATRIX","Matrix4","scratchVector","Vector3","B3dmConverter","convert","i3sTile","attributes","gltf","buildGltf","b3dm","gltfEncoded","Uint8Array","type","featuresLength","_getFeaturesLength","batchTable","Tile3DWriter","material","indices","originalIndices","cartesianOrigin","cartographicOrigin","modelMatrix","content","gltfBuilder","GLTFScenegraph","textureIndex","_addI3sTextureToGltf","pbrMaterialInfo","_convertI3sMaterialToGltfMaterial","materialIndex","addMaterial","positions","positionsValue","value","uvRegions","texCoords","_normalizePositions","normals","_checkNormals","_generateSynteticIndices","length","size","meshIndex","addMesh","transformMatrix","_generateTransformMatrix","nodeIndex","addNode","matrix","sceneIndex","addScene","nodeIndices","setDefaultScene","createBinaryChunk","gltfBuffer","GLTFWriter","texture","header","textureFormat","selectedTexture","pbrMetallicRoughness","baseColorTexture","source","image","mimeType","_deduceMimeTypeFromFormat","imageBuffer","ImageWriter","imageIndex","addImage","addTexture","colors","newPositionsValue","Float32Array","index","vertex","subarray","cartesianOriginVector","vertexVector","Array","from","transform","add","Ellipsoid","WGS84","cartographicToCartesian","subtract","set","translateOriginMatrix","translate","result","multiplyLeft","_generateBatchId","faceRanges","batchIdArraySize","batchId","rangeIndex","currentBatchId","fromIndex","untilPosition","fill","vertexCount","Uint32Array","format","console","warn","isTextureIndexExists","alphaMode","doubleSided","metallicFactor","roughnessFactor","texCoord","baseColorFactor","_setGltfTexture","materialDefinition","emissiveTexture","metallicRoughnessTexture","normalTexture","occlusionTexture","firstKey","Object","keys","find"],"mappings":"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","sourcesContent":["import {encode, encodeSync} from '@loaders.gl/core';\nimport {GLTFScenegraph, GLTFWriter} from '@loaders.gl/gltf';\nimport {Tile3DWriter} from '@loaders.gl/3d-tiles';\nimport {ImageWriter} from '@loaders.gl/images';\nimport {Matrix4, Vector3} from '@math.gl/core';\nimport {convertTextureAtlas} from './texture-atlas';\nimport {Ellipsoid} from '@math.gl/geospatial';\n\nconst Z_UP_TO_Y_UP_MATRIX = new Matrix4([1, 0, 0, 0, 0, 0, -1, 0, 0, 1, 0, 0, 0, 0, 0, 1]);\nconst scratchVector = new Vector3();\n\nexport default class B3dmConverter {\n async convert(i3sTile, attributes = null) {\n this.i3sTile = i3sTile;\n const gltf = await this.buildGltf(i3sTile);\n const b3dm = encodeSync(\n {\n gltfEncoded: new Uint8Array(gltf),\n type: 'b3dm',\n featuresLength: this._getFeaturesLength(attributes),\n batchTable: attributes\n },\n Tile3DWriter\n );\n return b3dm;\n }\n\n async buildGltf(i3sTile) {\n const {\n material,\n attributes,\n indices: originalIndices,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n } = i3sTile.content;\n const gltfBuilder = new GLTFScenegraph();\n\n const textureIndex = await this._addI3sTextureToGltf(i3sTile, gltfBuilder);\n const pbrMaterialInfo = this._convertI3sMaterialToGltfMaterial(material, textureIndex);\n const materialIndex = gltfBuilder.addMaterial(pbrMaterialInfo);\n\n const positions = attributes.positions;\n const positionsValue = positions.value;\n\n if (attributes.uvRegions && attributes.texCoords) {\n attributes.texCoords.value = convertTextureAtlas(\n attributes.texCoords.value,\n attributes.uvRegions.value\n );\n }\n\n attributes.positions.value = this._normalizePositions(\n positionsValue,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n );\n if (attributes.normals && !this._checkNormals(attributes.normals.value)) {\n delete attributes.normals;\n }\n const indices =\n originalIndices || this._generateSynteticIndices(positionsValue.length / positions.size);\n const meshIndex = gltfBuilder.addMesh({\n attributes,\n indices,\n material: materialIndex\n });\n const transformMatrix = this._generateTransformMatrix(cartesianOrigin);\n const nodeIndex = gltfBuilder.addNode({meshIndex, matrix: transformMatrix});\n const sceneIndex = gltfBuilder.addScene({nodeIndices: [nodeIndex]});\n gltfBuilder.setDefaultScene(sceneIndex);\n\n gltfBuilder.createBinaryChunk();\n\n const gltfBuffer = encodeSync(gltfBuilder.gltf, GLTFWriter);\n\n return gltfBuffer;\n }\n\n /**\n * Update gltfBuilder with texture from I3S tile\n * @param {object} i3sTile - Tile3D object\n * @param {GLTFScenegraph} gltfBuilder - gltfScenegraph instance to construct GLTF\n * @returns {Promise<number | null>} - GLTF texture index\n */\n async _addI3sTextureToGltf(i3sTile, gltfBuilder) {\n const {\n content: {texture, material, attributes},\n header: {textureFormat}\n } = i3sTile;\n let textureIndex = null;\n let selectedTexture = texture;\n if (!texture && material) {\n selectedTexture =\n material.pbrMetallicRoughness &&\n material.pbrMetallicRoughness.baseColorTexture &&\n material.pbrMetallicRoughness.baseColorTexture.texture.source.image;\n }\n if (selectedTexture) {\n const mimeType = this._deduceMimeTypeFromFormat(textureFormat);\n const imageBuffer = await encode(selectedTexture, ImageWriter);\n const imageIndex = gltfBuilder.addImage(imageBuffer, mimeType);\n textureIndex = gltfBuilder.addTexture({imageIndex});\n delete attributes.colors;\n }\n return textureIndex;\n }\n\n /**\n * Generate a positions array which is correct for 3DTiles/GLTF format\n * @param {Float64Array} positionsValue - the input geometry positions array\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @param {number[]} cartographicOrigin - the tile center in the cartographic coordinate system\n * @param {number[]} modelMatrix - the model matrix of geometry\n * @returns {Float32Array} - the output geometry positions array\n */\n _normalizePositions(positionsValue, cartesianOrigin, cartographicOrigin, modelMatrix) {\n const newPositionsValue = new Float32Array(positionsValue.length);\n for (let index = 0; index < positionsValue.length; index += 3) {\n const vertex = positionsValue.subarray(index, index + 3);\n const cartesianOriginVector = new Vector3(cartesianOrigin);\n let vertexVector = new Vector3(Array.from(vertex))\n .transform(modelMatrix)\n .add(cartographicOrigin);\n Ellipsoid.WGS84.cartographicToCartesian(vertexVector, scratchVector);\n vertexVector = scratchVector.subtract(cartesianOriginVector);\n newPositionsValue.set(vertexVector, index);\n }\n return newPositionsValue;\n }\n\n /**\n * Generate the transformation matrix for GLTF node:\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-node\n * 1. Create the translate transformation from cartesianOrigin (the positions array stores offsets from this cartesianOrigin)\n * 2. Create the rotation transformation to rotate model from z-up coordinates (I3S specific) to y-up coordinates (GLTF specific)\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @returns {Matrix4} - an array of 16 numbers (4x4 matrix)\n */\n _generateTransformMatrix(cartesianOrigin) {\n const translateOriginMatrix = new Matrix4().translate(cartesianOrigin);\n const result = translateOriginMatrix.multiplyLeft(Z_UP_TO_Y_UP_MATRIX);\n return result;\n }\n\n /**\n * Generate batchId attribute from faceRanges.\n * @param {Uint32Array} faceRanges - the source array\n * @returns {Float32Array} batchId list.\n */\n _generateBatchId(faceRanges) {\n const batchIdArraySize = (faceRanges[faceRanges.length - 1] + 1) * 3;\n const batchId = new Float32Array(batchIdArraySize);\n let rangeIndex = 0;\n let currentBatchId = 0;\n\n for (let index = 0; index < faceRanges.length / 2; index++) {\n const fromIndex = faceRanges[rangeIndex] * 3;\n const untilPosition = (faceRanges[rangeIndex + 1] + 1) * 3;\n\n batchId.fill(currentBatchId, fromIndex, untilPosition);\n rangeIndex += 2;\n currentBatchId += 1;\n }\n return batchId;\n }\n\n /**\n * luma.gl can not work without indices now:\n * https://github.com/visgl/luma.gl/blob/d8cad75b9f8ca3e578cf078ed9d19e619c2ddbc9/modules/experimental/src/gltf/gltf-instantiator.js#L115\n * This method generates syntetic indices array: [0, 1, 2, 3, .... , vertexCount-1]\n * @param {number} vertexCount - vertex count in the geometry\n * @returns {Uint32Array} indices array.\n */\n _generateSynteticIndices(vertexCount) {\n const result = new Uint32Array(vertexCount);\n for (let index = 0; index < vertexCount; index++) {\n result.set([index], index);\n }\n return result;\n }\n\n /**\n * Deduce mime type by format from `textureSetDefinition.formats[0].format`\n * https://github.com/Esri/i3s-spec/blob/master/docs/1.7/textureSetDefinitionFormat.cmn.md\n * @param {string} format - format name\n * @returns {string} mime type.\n */\n _deduceMimeTypeFromFormat(format) {\n switch (format) {\n case 'jpg':\n return 'image/jpeg';\n case 'png':\n return 'image/png';\n default:\n console.warn(`Unexpected texture format in I3S: ${format}`); // eslint-disable-line no-console, no-undef\n return 'image/jpeg';\n }\n }\n\n /**\n * Convert i3s material to GLTF compatible material\n * @param {object} material - i3s material definition\n * @param {number | null} textureIndex - texture index in GLTF\n * @returns {object} GLTF material\n */\n _convertI3sMaterialToGltfMaterial(material, textureIndex) {\n const isTextureIndexExists = textureIndex !== null;\n\n if (!material) {\n material = {\n alphaMode: 'OPAQUE',\n doubleSided: false,\n pbrMetallicRoughness: {\n metallicFactor: 0,\n roughnessFactor: 1\n }\n };\n\n if (isTextureIndexExists) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else {\n material.pbrMetallicRoughness.baseColorFactor = [1, 1, 1, 1];\n }\n\n return material;\n }\n\n if (textureIndex !== null) {\n material = this._setGltfTexture(material, textureIndex);\n }\n\n return material;\n }\n\n /**\n * Set texture properties in material with GLTF textureIndex\n * @param {object} materialDefinition - i3s material definition\n * @param {number} textureIndex - texture index in GLTF\n * @returns {void}\n */\n _setGltfTexture(materialDefinition, textureIndex) {\n const material = {\n ...materialDefinition,\n pbrMetallicRoughness: {...materialDefinition.pbrMetallicRoughness}\n };\n // I3SLoader now support loading only one texture. This elseif sequence will assign this texture to one of\n // properties defined in materialDefinition\n if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.baseColorTexture\n ) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.emissiveTexture) {\n material.emissiveTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.metallicRoughnessTexture\n ) {\n material.pbrMetallicRoughness.metallicRoughnessTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.normalTexture) {\n material.normalTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.occlusionTexture) {\n material.occlusionTexture = {\n index: textureIndex,\n texCoord: 0\n };\n }\n return material;\n }\n\n /*\n * Returns Features length based on attribute array in attribute object.\n * @param {Object} attributes\n * @returns {Number} Features length .\n */\n _getFeaturesLength(attributes) {\n if (!attributes) {\n return 0;\n }\n const firstKey = Object.keys(attributes)[0];\n return firstKey ? attributes[firstKey].length : 0;\n }\n\n /* Checks that normals buffer is correct\n * @param {TypedArray} normals\n * @returns {boolean} true - normals are correct; false - normals are incorrect\n */\n _checkNormals(normals) {\n // If all normals === 0, the resulting tileset is all in black colors on Cesium\n return normals.find((value) => value);\n }\n}\n"],"file":"b3dm-converter.js"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/3d-tiles-converter/helpers/b3dm-converter.js"],"names":["Z_UP_TO_Y_UP_MATRIX","Matrix4","scratchVector","Vector3","B3dmConverter","convert","i3sTile","attributes","gltf","buildGltf","b3dm","gltfEncoded","Uint8Array","type","featuresLength","_getFeaturesLength","batchTable","Tile3DWriter","material","indices","originalIndices","cartesianOrigin","cartographicOrigin","modelMatrix","content","gltfBuilder","GLTFScenegraph","textureIndex","_addI3sTextureToGltf","pbrMaterialInfo","_convertI3sMaterialToGltfMaterial","materialIndex","addMaterial","positions","positionsValue","value","uvRegions","texCoords","_normalizePositions","normals","_checkNormals","_generateSynteticIndices","length","size","meshIndex","addMesh","transformMatrix","_generateTransformMatrix","nodeIndex","addNode","matrix","sceneIndex","addScene","nodeIndices","setDefaultScene","createBinaryChunk","gltfBuffer","GLTFWriter","texture","header","textureFormat","selectedTexture","pbrMetallicRoughness","baseColorTexture","source","image","mimeType","_deduceMimeTypeFromFormat","imageBuffer","ImageWriter","imageIndex","addImage","addTexture","colors","newPositionsValue","Float32Array","index","vertex","subarray","cartesianOriginVector","vertexVector","Array","from","transform","add","Ellipsoid","WGS84","cartographicToCartesian","subtract","set","translateOriginMatrix","translate","result","multiplyLeft","_generateBatchId","faceRanges","batchIdArraySize","batchId","rangeIndex","currentBatchId","fromIndex","untilPosition","fill","vertexCount","Uint32Array","format","console","warn","isTextureIndexExists","alphaMode","doubleSided","metallicFactor","roughnessFactor","texCoord","baseColorFactor","_setGltfTexture","materialDefinition","emissiveTexture","metallicRoughnessTexture","normalTexture","occlusionTexture","firstKey","Object","keys","find"],"mappings":"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","sourcesContent":["import {encode, encodeSync} from '@loaders.gl/core';\nimport {GLTFScenegraph, GLTFWriter} from '@loaders.gl/gltf';\nimport {Tile3DWriter} from '@loaders.gl/3d-tiles';\nimport {ImageWriter} from '@loaders.gl/images';\nimport {Matrix4, Vector3} from '@math.gl/core';\nimport {Ellipsoid} from '@math.gl/geospatial';\nimport {convertTextureAtlas} from './texture-atlas';\n\nconst Z_UP_TO_Y_UP_MATRIX = new Matrix4([1, 0, 0, 0, 0, 0, -1, 0, 0, 1, 0, 0, 0, 0, 0, 1]);\nconst scratchVector = new Vector3();\n\nexport default class B3dmConverter {\n async convert(i3sTile, attributes = null) {\n this.i3sTile = i3sTile;\n const gltf = await this.buildGltf(i3sTile);\n const b3dm = encodeSync(\n {\n gltfEncoded: new Uint8Array(gltf),\n type: 'b3dm',\n featuresLength: this._getFeaturesLength(attributes),\n batchTable: attributes\n },\n Tile3DWriter\n );\n return b3dm;\n }\n\n async buildGltf(i3sTile) {\n const {\n material,\n attributes,\n indices: originalIndices,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n } = i3sTile.content;\n const gltfBuilder = new GLTFScenegraph();\n\n const textureIndex = await this._addI3sTextureToGltf(i3sTile, gltfBuilder);\n const pbrMaterialInfo = this._convertI3sMaterialToGltfMaterial(material, textureIndex);\n const materialIndex = gltfBuilder.addMaterial(pbrMaterialInfo);\n\n const positions = attributes.positions;\n const positionsValue = positions.value;\n\n if (attributes.uvRegions && attributes.texCoords) {\n attributes.texCoords.value = convertTextureAtlas(\n attributes.texCoords.value,\n attributes.uvRegions.value\n );\n }\n\n attributes.positions.value = this._normalizePositions(\n positionsValue,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n );\n if (attributes.normals && !this._checkNormals(attributes.normals.value)) {\n delete attributes.normals;\n }\n const indices =\n originalIndices || this._generateSynteticIndices(positionsValue.length / positions.size);\n const meshIndex = gltfBuilder.addMesh({\n attributes,\n indices,\n material: materialIndex\n });\n const transformMatrix = this._generateTransformMatrix(cartesianOrigin);\n const nodeIndex = gltfBuilder.addNode({meshIndex, matrix: transformMatrix});\n const sceneIndex = gltfBuilder.addScene({nodeIndices: [nodeIndex]});\n gltfBuilder.setDefaultScene(sceneIndex);\n\n gltfBuilder.createBinaryChunk();\n\n const gltfBuffer = encodeSync(gltfBuilder.gltf, GLTFWriter);\n\n return gltfBuffer;\n }\n\n /**\n * Update gltfBuilder with texture from I3S tile\n * @param {object} i3sTile - Tile3D object\n * @param {GLTFScenegraph} gltfBuilder - gltfScenegraph instance to construct GLTF\n * @returns {Promise<number | null>} - GLTF texture index\n */\n async _addI3sTextureToGltf(i3sTile, gltfBuilder) {\n const {\n content: {texture, material, attributes},\n header: {textureFormat}\n } = i3sTile;\n let textureIndex = null;\n let selectedTexture = texture;\n if (!texture && material) {\n selectedTexture =\n material.pbrMetallicRoughness &&\n material.pbrMetallicRoughness.baseColorTexture &&\n material.pbrMetallicRoughness.baseColorTexture.texture.source.image;\n }\n if (selectedTexture) {\n const mimeType = this._deduceMimeTypeFromFormat(textureFormat);\n const imageBuffer = await encode(selectedTexture, ImageWriter);\n const imageIndex = gltfBuilder.addImage(imageBuffer, mimeType);\n textureIndex = gltfBuilder.addTexture({imageIndex});\n delete attributes.colors;\n }\n return textureIndex;\n }\n\n /**\n * Generate a positions array which is correct for 3DTiles/GLTF format\n * @param {Float64Array} positionsValue - the input geometry positions array\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @param {number[]} cartographicOrigin - the tile center in the cartographic coordinate system\n * @param {number[]} modelMatrix - the model matrix of geometry\n * @returns {Float32Array} - the output geometry positions array\n */\n _normalizePositions(positionsValue, cartesianOrigin, cartographicOrigin, modelMatrix) {\n const newPositionsValue = new Float32Array(positionsValue.length);\n for (let index = 0; index < positionsValue.length; index += 3) {\n const vertex = positionsValue.subarray(index, index + 3);\n const cartesianOriginVector = new Vector3(cartesianOrigin);\n let vertexVector = new Vector3(Array.from(vertex))\n .transform(modelMatrix)\n .add(cartographicOrigin);\n Ellipsoid.WGS84.cartographicToCartesian(vertexVector, scratchVector);\n vertexVector = scratchVector.subtract(cartesianOriginVector);\n newPositionsValue.set(vertexVector, index);\n }\n return newPositionsValue;\n }\n\n /**\n * Generate the transformation matrix for GLTF node:\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-node\n * 1. Create the translate transformation from cartesianOrigin (the positions array stores offsets from this cartesianOrigin)\n * 2. Create the rotation transformation to rotate model from z-up coordinates (I3S specific) to y-up coordinates (GLTF specific)\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @returns {Matrix4} - an array of 16 numbers (4x4 matrix)\n */\n _generateTransformMatrix(cartesianOrigin) {\n const translateOriginMatrix = new Matrix4().translate(cartesianOrigin);\n const result = translateOriginMatrix.multiplyLeft(Z_UP_TO_Y_UP_MATRIX);\n return result;\n }\n\n /**\n * Generate batchId attribute from faceRanges.\n * @param {Uint32Array} faceRanges - the source array\n * @returns {Float32Array} batchId list.\n */\n _generateBatchId(faceRanges) {\n const batchIdArraySize = (faceRanges[faceRanges.length - 1] + 1) * 3;\n const batchId = new Float32Array(batchIdArraySize);\n let rangeIndex = 0;\n let currentBatchId = 0;\n\n for (let index = 0; index < faceRanges.length / 2; index++) {\n const fromIndex = faceRanges[rangeIndex] * 3;\n const untilPosition = (faceRanges[rangeIndex + 1] + 1) * 3;\n\n batchId.fill(currentBatchId, fromIndex, untilPosition);\n rangeIndex += 2;\n currentBatchId += 1;\n }\n return batchId;\n }\n\n /**\n * luma.gl can not work without indices now:\n * https://github.com/visgl/luma.gl/blob/d8cad75b9f8ca3e578cf078ed9d19e619c2ddbc9/modules/experimental/src/gltf/gltf-instantiator.js#L115\n * This method generates syntetic indices array: [0, 1, 2, 3, .... , vertexCount-1]\n * @param {number} vertexCount - vertex count in the geometry\n * @returns {Uint32Array} indices array.\n */\n _generateSynteticIndices(vertexCount) {\n const result = new Uint32Array(vertexCount);\n for (let index = 0; index < vertexCount; index++) {\n result.set([index], index);\n }\n return result;\n }\n\n /**\n * Deduce mime type by format from `textureSetDefinition.formats[0].format`\n * https://github.com/Esri/i3s-spec/blob/master/docs/1.7/textureSetDefinitionFormat.cmn.md\n * @param {string} format - format name\n * @returns {string} mime type.\n */\n _deduceMimeTypeFromFormat(format) {\n switch (format) {\n case 'jpg':\n return 'image/jpeg';\n case 'png':\n return 'image/png';\n default:\n console.warn(`Unexpected texture format in I3S: ${format}`); // eslint-disable-line no-console, no-undef\n return 'image/jpeg';\n }\n }\n\n /**\n * Convert i3s material to GLTF compatible material\n * @param {object} material - i3s material definition\n * @param {number | null} textureIndex - texture index in GLTF\n * @returns {object} GLTF material\n */\n _convertI3sMaterialToGltfMaterial(material, textureIndex) {\n const isTextureIndexExists = textureIndex !== null;\n\n if (!material) {\n material = {\n alphaMode: 'OPAQUE',\n doubleSided: false,\n pbrMetallicRoughness: {\n metallicFactor: 0,\n roughnessFactor: 1\n }\n };\n\n if (isTextureIndexExists) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else {\n material.pbrMetallicRoughness.baseColorFactor = [1, 1, 1, 1];\n }\n\n return material;\n }\n\n if (textureIndex !== null) {\n material = this._setGltfTexture(material, textureIndex);\n }\n\n return material;\n }\n\n /**\n * Set texture properties in material with GLTF textureIndex\n * @param {object} materialDefinition - i3s material definition\n * @param {number} textureIndex - texture index in GLTF\n * @returns {void}\n */\n _setGltfTexture(materialDefinition, textureIndex) {\n const material = {\n ...materialDefinition,\n pbrMetallicRoughness: {...materialDefinition.pbrMetallicRoughness}\n };\n // I3SLoader now support loading only one texture. This elseif sequence will assign this texture to one of\n // properties defined in materialDefinition\n if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.baseColorTexture\n ) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.emissiveTexture) {\n material.emissiveTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.metallicRoughnessTexture\n ) {\n material.pbrMetallicRoughness.metallicRoughnessTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.normalTexture) {\n material.normalTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.occlusionTexture) {\n material.occlusionTexture = {\n index: textureIndex,\n texCoord: 0\n };\n }\n return material;\n }\n\n /*\n * Returns Features length based on attribute array in attribute object.\n * @param {Object} attributes\n * @returns {Number} Features length .\n */\n _getFeaturesLength(attributes) {\n if (!attributes) {\n return 0;\n }\n const firstKey = Object.keys(attributes)[0];\n return firstKey ? attributes[firstKey].length : 0;\n }\n\n /* Checks that normals buffer is correct\n * @param {TypedArray} normals\n * @returns {boolean} true - normals are correct; false - normals are incorrect\n */\n _checkNormals(normals) {\n // If all normals === 0, the resulting tileset is all in black colors on Cesium\n return normals.find((value) => value);\n }\n}\n"],"file":"b3dm-converter.js"}
|
|
@@ -166,24 +166,6 @@ function convertAttributes(tileContent) {
|
|
|
166
166
|
continue;
|
|
167
167
|
}
|
|
168
168
|
|
|
169
|
-
const vertexCount = attributes.positions.length / VALUES_PER_VERTEX;
|
|
170
|
-
|
|
171
|
-
if (!attributes.colors.length) {
|
|
172
|
-
attributes.colors = new Uint8Array(vertexCount * VALUES_PER_COLOR_ELEMENT);
|
|
173
|
-
|
|
174
|
-
for (let index = 0; index < attributes.colors.length; index += 4) {
|
|
175
|
-
attributes.colors.set([255, 255, 255, 255], index);
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
if (!attributes.texCoords.length) {
|
|
180
|
-
attributes.texCoords = new Float32Array(vertexCount * VALUES_PER_TEX_COORD);
|
|
181
|
-
|
|
182
|
-
for (let index = 0; index < attributes.texCoords.length; index += 2) {
|
|
183
|
-
attributes.texCoords.set([1, 1], index);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
|
|
187
169
|
attributes.featureIndices = attributes.featureIndices.reduce((acc, value) => acc.concat(value));
|
|
188
170
|
}
|
|
189
171
|
|
|
@@ -306,6 +288,7 @@ function flattenTexCoords(texCoords, indices) {
|
|
|
306
288
|
const newTexCoords = new Float32Array(indices.length * VALUES_PER_TEX_COORD);
|
|
307
289
|
|
|
308
290
|
if (!texCoords) {
|
|
291
|
+
newTexCoords.fill(1);
|
|
309
292
|
return newTexCoords;
|
|
310
293
|
}
|
|
311
294
|
|
|
@@ -324,6 +307,7 @@ function flattenColors(colorsAttribute, indices) {
|
|
|
324
307
|
const newColors = new Uint8Array(indices.length * components);
|
|
325
308
|
|
|
326
309
|
if (!colorsAttribute) {
|
|
310
|
+
newColors.fill(255);
|
|
327
311
|
return newColors;
|
|
328
312
|
}
|
|
329
313
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/i3s-converter/helpers/geometry-converter.js"],"names":["VALUES_PER_VERTEX","VALUES_PER_TEX_COORD","VALUES_PER_COLOR_ELEMENT","STRING_TYPE","SHORT_INT_TYPE","DOUBLE_TYPE","OBJECT_ID_TYPE","BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES","convertB3dmToI3sGeometry","tileContent","nodeId","featuresHashArray","attributeStorageInfo","draco","materialAndTextureList","convertMaterials","convertedAttributesMap","convertAttributes","has","push","material","getDefaultMaterial","result","nodesCounter","materials","gltf","length","id","i","sourceMaterial","convertedAttributes","get","texture","_makeNodeResources","vertexCount","positions","triangleCount","faceRange","featureIds","normals","colors","texCoords","featureCount","batchTableJson","makeFeatureIdsUnique","featureIndices","header","Uint32Array","typedFeatureIds","generateBigUint64Array","set","fileBuffer","Uint8Array","buffer","ArrayBuffer","compressedGeometry","generateCompressedGeometry","Float32Array","attributes","convertBatchTableToAttributeBuffers","geometry","sharedResources","getSharedResources","meshMaterial","attributesMap","Map","nodes","scene","scenes","convertNodes","attrKey","keys","delete","index","reduce","acc","value","concat","matrix","Matrix4","node","convertNode","nodeMatrix","compositeMatrix","multiplyRight","mesh","convertMesh","children","content","primitive","primitives","outputAttributes","transformVertexArray","vertices","POSITION","cartographicOrigin","cartesianModelMatrix","indices","attributeSpecificTransformation","transformVertexPositions","NORMAL","transformVertexNormals","flattenTexCoords","TEXCOORD_0","flattenColors","COLOR_0","flattenBatchIds","getBatchIdsByAttributeName","args","newVertices","coordIndex","vertex","subarray","vertexVector","Vector3","Array","from","x","y","z","calleeArgs","transform","Ellipsoid","WGS84","cartesianToCartographic","subtract","transformAsVector","newTexCoords","texCoord","colorsAttribute","components","newColors","colorIndex","color","colorUint8","j","batchedIds","newBatchIds","batchIds","possibleBatchIdAttributeName","sourceMaterials","convertMaterial","doubleSided","emissiveFactor","map","c","Math","round","alphaMode","toLowerCase","pbrMetallicRoughness","roughnessFactor","metallicFactor","baseColorTexture","source","textureSetDefinitionId","emissiveTexture","baseColorFactor","undefined","gltfMaterials","i3sResources","materialDefinitionInfos","gltfMaterial","materialDefinitionInfo","textureDefinitionInfo","convertGLTFMaterialToI3sSharedResources","textureDefinitionInfos","extractSharedResourcesTextureInfo","colorFactor","extractSharedResourcesMaterialInfo","matDielectricColorComponent","black","Vector4","unitVector","dielectricSpecular","baseColorVector","firstOperand","multiply","diffuse","lerp","specular","toArray","encoding","mimeType","images","generateImageId","size","image","width","data","height","levelCountOfTexture","indexOfLevel","indexOfTextureInStore","zerosCount","toString","rightHalf","repeat","shiftedLevelCountOfTexture","shiftedIndexOfLevel","shiftedWidth","shiftedHeight","leftHalf","imageId","BigInt","batchTable","replaceMap","getFeaturesReplaceMap","replaceIndicesByUnique","featureMap","oldFeatureId","uniqueFeatureId","getOrCreateUniqueFeatureId","generateStringFromBatchTableByIndex","str","key","batchTableStr","hash","includes","indexOf","indicesArray","attributeBuffers","batchTableWithFeatureIds","OBJECTID","type","getAttributeType","attributeBuffer","generateShortIntegerAttributeBuffer","generateDoubleAttributeBuffer","generateStringAttributeBuffer","attribute","find","attr","name","attributeValues","valueType","count","valuesArray","padding","Float64Array","batchAttributes","stringCountArray","totalNumberOfBytes","stringSizesArray","stringBufferArray","currentString","String","currentStringBuffer","Buffer","currentStringSize","totalBytes","BigUint64Array","featureIndex","generateFeatureIndexAttribute","compressedAttributes","attributesMetadata","Int32Array","DracoWriter","method","orderedFeatureIndices","fillIndex","startIndex","endIndex","fill"],"mappings":"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","sourcesContent":["import {Vector3, Matrix4, Vector4} from '@math.gl/core';\nimport {Ellipsoid} from '@math.gl/geospatial';\n\nimport {DracoWriter} from '@loaders.gl/draco';\nimport {encode, assert} from '@loaders.gl/core';\nimport {concatenateArrayBuffers, concatenateTypedArrays} from '@loaders.gl/loader-utils';\nimport md5 from 'md5';\nimport {generateAttributes} from './geometry-attributes';\n\nconst VALUES_PER_VERTEX = 3;\nconst VALUES_PER_TEX_COORD = 2;\nconst VALUES_PER_COLOR_ELEMENT = 4;\n\nconst STRING_TYPE = 'string';\nconst SHORT_INT_TYPE = 'Int32';\nconst DOUBLE_TYPE = 'Float64';\nconst OBJECT_ID_TYPE = 'Oid32';\n/*\n * 'CUSTOM_ATTRIBUTE_2' - Attribute name which includes batch info and used by New York map.\n * _BATCHID - Default attribute name which includes batch info.\n * BATCHID - Legacy attribute name which includes batch info.\n */\nconst BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES = ['CUSTOM_ATTRIBUTE_2', '_BATCHID', 'BATCHID'];\n\nexport default async function convertB3dmToI3sGeometry(\n tileContent,\n nodeId,\n featuresHashArray,\n attributeStorageInfo,\n draco\n) {\n const materialAndTextureList = convertMaterials(tileContent);\n const convertedAttributesMap = convertAttributes(tileContent);\n\n if (convertedAttributesMap.has('default')) {\n materialAndTextureList.push({\n material: getDefaultMaterial()\n });\n }\n\n const result = [];\n let nodesCounter = nodeId;\n let {materials = []} = tileContent.gltf;\n if (!materials.length === 0) {\n materials.push({id: 'default'});\n }\n for (let i = 0; i < materials.length; i++) {\n const sourceMaterial = materials[i];\n if (!convertedAttributesMap.has(sourceMaterial.id)) {\n continue; // eslint-disable-line no-continue\n }\n const convertedAttributes = convertedAttributesMap.get(sourceMaterial.id);\n const {material, texture} = materialAndTextureList[i];\n result.push(\n await _makeNodeResources({\n convertedAttributes,\n material,\n texture,\n tileContent,\n nodeId: nodesCounter,\n featuresHashArray,\n attributeStorageInfo,\n draco\n })\n );\n nodesCounter++;\n }\n\n if (!result.length) {\n return null;\n }\n return result;\n}\n\nasync function _makeNodeResources({\n convertedAttributes,\n material,\n texture,\n tileContent,\n nodeId,\n featuresHashArray,\n attributeStorageInfo,\n draco\n}) {\n const vertexCount = convertedAttributes.positions.length / VALUES_PER_VERTEX;\n const triangleCount = vertexCount / 3;\n const {faceRange, featureIds, positions, normals, colors, texCoords, featureCount} =\n generateAttributes({triangleCount, ...convertedAttributes});\n\n if (tileContent.batchTableJson) {\n makeFeatureIdsUnique(\n featureIds,\n convertedAttributes.featureIndices,\n featuresHashArray,\n tileContent.batchTableJson\n );\n }\n\n const header = new Uint32Array(2);\n const typedFeatureIds = generateBigUint64Array(featureIds);\n\n header.set([vertexCount, featureCount], 0);\n const fileBuffer = new Uint8Array(\n concatenateArrayBuffers(\n header.buffer,\n positions.buffer,\n normals.buffer,\n texture ? texCoords.buffer : new ArrayBuffer(0),\n colors.buffer,\n typedFeatureIds.buffer,\n faceRange.buffer\n )\n );\n const compressedGeometry = draco\n ? await generateCompressedGeometry(vertexCount, convertedAttributes, {\n positions,\n normals,\n texCoords: texture ? texCoords : new Float32Array(0),\n colors,\n featureIds,\n faceRange\n })\n : null;\n\n const attributes = convertBatchTableToAttributeBuffers(\n tileContent.batchTableJson,\n featureIds,\n attributeStorageInfo\n );\n\n return {\n geometry: fileBuffer,\n compressedGeometry,\n texture,\n sharedResources: getSharedResources(tileContent, nodeId),\n meshMaterial: material,\n vertexCount,\n attributes,\n featureCount\n };\n}\n\n/**\n * Convert attributes from the gltf nodes tree to i3s plain geometry\n * @param {Object} tileContent - 3d tile content\n * @returns {Map}\n * Map<{\n * positions: Float32Array,\n * normals: Float32Array,\n * colors: Uint8Array,\n * texCoords: Float32Array\n * }>\n * @todo implement colors support (if applicable for gltf format)\n */\nfunction convertAttributes(tileContent) {\n const attributesMap = new Map();\n\n for (const material of tileContent.gltf.materials || [{id: 'default'}]) {\n attributesMap.set(material.id, {\n positions: new Float32Array(0),\n normals: new Float32Array(0),\n texCoords: new Float32Array(0),\n colors: new Uint8Array(0),\n featureIndices: []\n });\n }\n\n const nodes = (tileContent.gltf.scene || tileContent.gltf.scenes?.[0] || tileContent.gltf).nodes;\n convertNodes(nodes, tileContent, attributesMap);\n\n for (const attrKey of attributesMap.keys()) {\n const attributes = attributesMap.get(attrKey);\n if (attributes.positions.length === 0) {\n attributesMap.delete(attrKey);\n continue; // eslint-disable-line no-continue\n }\n const vertexCount = attributes.positions.length / VALUES_PER_VERTEX;\n if (!attributes.colors.length) {\n attributes.colors = new Uint8Array(vertexCount * VALUES_PER_COLOR_ELEMENT);\n for (let index = 0; index < attributes.colors.length; index += 4) {\n attributes.colors.set([255, 255, 255, 255], index);\n }\n }\n if (!attributes.texCoords.length) {\n attributes.texCoords = new Float32Array(vertexCount * VALUES_PER_TEX_COORD);\n for (let index = 0; index < attributes.texCoords.length; index += 2) {\n attributes.texCoords.set([1, 1], index);\n }\n }\n attributes.featureIndices = attributes.featureIndices.reduce((acc, value) => acc.concat(value));\n }\n\n return attributesMap;\n}\n\n/**\n * Gltf has hierarchical structure of nodes. This function converts nodes starting from those which are in gltf scene object.\n * The goal is applying tranformation matrix for all children. Functions \"convertNodes\" and \"convertNode\" work together recursively.\n * @param {Object[]} nodes - gltf nodes array\n * @param {Object} tileContent - 3d tile content\n * @param {Map} attributesMap Map<{positions: Float32Array, normals: Float32Array, texCoords: Float32Array, colors: UInt8Array, featureIndices: Array}> - for recursive concatenation of\n * attributes\n * @param {Matrix4} matrix - transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @returns {void}\n */\nfunction convertNodes(\n nodes,\n tileContent,\n attributesMap,\n matrix = new Matrix4([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])\n) {\n if (nodes) {\n for (const node of nodes) {\n convertNode(node, tileContent, attributesMap, matrix);\n }\n }\n}\n\n/**\n * Convert all primitives of node and all children nodes\n * @param {Object} node - gltf node\n * @param {Object} tileContent - 3d tile content\n * @param {Map} attributesMap Map<{positions: Float32Array, normals: Float32Array, texCoords: Float32Array, colors: Uint8Array, featureIndices: Array}> - for recursive concatenation of\n * attributes\n * @param {Matrix4} matrix - transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @todo: optimize arrays concatenation\n */\nfunction convertNode(\n node,\n tileContent,\n attributesMap,\n matrix = new Matrix4([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])\n) {\n const nodeMatrix = node.matrix;\n const compositeMatrix = nodeMatrix ? matrix.multiplyRight(nodeMatrix) : matrix;\n\n const mesh = node.mesh;\n if (mesh) {\n convertMesh(mesh, tileContent, attributesMap, compositeMatrix);\n }\n\n convertNodes(node.children, tileContent, attributesMap, compositeMatrix);\n}\n\n/**\n * Convert all primitives of node and all children nodes\n * @param {Object} mesh - gltf node\n * @param {Object} content - 3d tile content\n * @param {Map} attributesMap Map<{positions: Float32Array, normals: Float32Array, texCoords: Float32Array, colors: Uint8Array, featureIndices: Array}> - for recursive concatenation of\n * attributes\n * @param {Matrix4} matrix - transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @todo: optimize arrays concatenation\n */\nfunction convertMesh(\n mesh,\n content,\n attributesMap,\n matrix = new Matrix4([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])\n) {\n for (const primitive of mesh.primitives) {\n let outputAttributes = null;\n if (primitive.material) {\n outputAttributes = attributesMap.get(primitive.material.id);\n } else if (attributesMap.has('default')) {\n outputAttributes = attributesMap.get('default');\n }\n assert(outputAttributes !== null, 'Primitive - material mapping failed');\n const attributes = primitive.attributes;\n\n outputAttributes.positions = concatenateTypedArrays(\n outputAttributes.positions,\n transformVertexArray({\n vertices: attributes.POSITION.value,\n cartographicOrigin: content.cartographicOrigin,\n cartesianModelMatrix: content.cartesianModelMatrix,\n nodeMatrix: matrix,\n indices: primitive.indices.value,\n attributeSpecificTransformation: transformVertexPositions\n })\n );\n outputAttributes.normals = concatenateTypedArrays(\n outputAttributes.normals,\n transformVertexArray({\n vertices: attributes.NORMAL && attributes.NORMAL.value,\n cartographicOrigin: content.cartographicOrigin,\n cartesianModelMatrix: content.cartesianModelMatrix,\n nodeMatrix: matrix,\n indices: primitive.indices.value,\n attributeSpecificTransformation: transformVertexNormals\n })\n );\n outputAttributes.texCoords = concatenateTypedArrays(\n outputAttributes.texCoords,\n flattenTexCoords(\n attributes.TEXCOORD_0 && attributes.TEXCOORD_0.value,\n primitive.indices.value\n )\n );\n\n outputAttributes.colors = concatenateTypedArrays(\n outputAttributes.colors,\n flattenColors(attributes.COLOR_0, primitive.indices.value)\n );\n\n outputAttributes.featureIndices.push(\n flattenBatchIds(getBatchIdsByAttributeName(attributes), primitive.indices.value)\n );\n }\n}\n\n/**\n * Convert vertices attributes (POSITIONS or NORMALS) to i3s compatible format\n * @param {object} args - source tile (3DTile)\n * @param {Float32Array} args.vertices - gltf primitive POSITION or NORMAL attribute\n * @param {Object} args.cartographicOrigin - cartographic origin coordinates\n * @param {Object} args.cartesianModelMatrix - a cartesian model matrix to transform coordnates from cartesian to cartographic format\n * @param {Matrix4} args.nodeMatrix - a gltf node transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @param {Uint8Array} args.indices - gltf primitive indices\n * @param {Function} args.attributeSpecificTransformation - function to do attribute - specific transformations\n * @returns {Float32Array}\n */\nfunction transformVertexArray(args) {\n const {vertices, indices, attributeSpecificTransformation} = args;\n const newVertices = new Float32Array(indices.length * VALUES_PER_VERTEX);\n if (!vertices) {\n return newVertices;\n }\n for (let i = 0; i < indices.length; i++) {\n const coordIndex = indices[i] * VALUES_PER_VERTEX;\n const vertex = vertices.subarray(coordIndex, coordIndex + VALUES_PER_VERTEX);\n let vertexVector = new Vector3(Array.from(vertex));\n\n vertexVector = attributeSpecificTransformation(vertexVector, args);\n\n newVertices[i * VALUES_PER_VERTEX] = vertexVector.x;\n newVertices[i * VALUES_PER_VERTEX + 1] = vertexVector.y;\n newVertices[i * VALUES_PER_VERTEX + 2] = vertexVector.z;\n }\n return newVertices;\n}\n\nfunction transformVertexPositions(vertexVector, calleeArgs) {\n const {cartesianModelMatrix, cartographicOrigin, nodeMatrix} = calleeArgs;\n\n if (nodeMatrix) {\n vertexVector = vertexVector.transform(nodeMatrix);\n }\n\n vertexVector = vertexVector.transform(cartesianModelMatrix);\n Ellipsoid.WGS84.cartesianToCartographic(\n [vertexVector[0], vertexVector[1], vertexVector[2]],\n vertexVector\n );\n vertexVector = vertexVector.subtract(cartographicOrigin);\n return vertexVector;\n}\n\nfunction transformVertexNormals(vertexVector, calleeArgs) {\n const {cartesianModelMatrix, nodeMatrix} = calleeArgs;\n\n if (nodeMatrix) {\n vertexVector = vertexVector.transformAsVector(nodeMatrix);\n }\n\n vertexVector = vertexVector.transformAsVector(cartesianModelMatrix);\n return vertexVector;\n}\n\n/**\n * Convert uv0 (texture coordinates) from coords based on indices to plain arrays, compatible with i3s\n * @param {Float32Array} texCoords - gltf primitive TEXCOORD_0 attribute\n * @param {Uint8Array} indices - gltf primitive indices\n * @returns {Float32Array}\n */\nfunction flattenTexCoords(texCoords, indices) {\n const newTexCoords = new Float32Array(indices.length * VALUES_PER_TEX_COORD);\n if (!texCoords) {\n return newTexCoords;\n }\n for (let i = 0; i < indices.length; i++) {\n const coordIndex = indices[i] * VALUES_PER_TEX_COORD;\n const texCoord = texCoords.subarray(coordIndex, coordIndex + VALUES_PER_TEX_COORD);\n newTexCoords[i * VALUES_PER_TEX_COORD] = texCoord[0];\n newTexCoords[i * VALUES_PER_TEX_COORD + 1] = texCoord[1];\n }\n return newTexCoords;\n}\n\n/**\n * Convert color from COLOR_0 based on indices to plain arrays, compatible with i3s\n * @param {object} colorsAttribute - gltf primitive COLOR_0 attribute\n * @param {Uint8Array} indices - gltf primitive indices\n * @returns {Uint8Array}\n */\nfunction flattenColors(colorsAttribute, indices) {\n const components = colorsAttribute?.components || VALUES_PER_COLOR_ELEMENT;\n const newColors = new Uint8Array(indices.length * components);\n if (!colorsAttribute) {\n return newColors;\n }\n const colors = colorsAttribute.value;\n for (let i = 0; i < indices.length; i++) {\n const colorIndex = indices[i] * components;\n const color = colors.subarray(colorIndex, colorIndex + components);\n const colorUint8 = new Uint8Array(components);\n for (let j = 0; j < color.length; j++) {\n colorUint8[j] = color[j] * 255;\n }\n newColors.set(colorUint8, i * components);\n }\n return newColors;\n}\n\n/**\n * Flatten batchedIds list based on indices to right ordered array, compatible with i3s\n * @param {Array} batchedIds - gltf primitive\n * @param {Uint8Array} indices - gltf primitive indices\n * @returns {Array}\n */\nfunction flattenBatchIds(batchedIds, indices) {\n if (!batchedIds.length || !indices.length) {\n return [];\n }\n const newBatchIds = [];\n for (let i = 0; i < indices.length; i++) {\n const coordIndex = indices[i];\n newBatchIds.push(batchedIds[coordIndex]);\n }\n return newBatchIds;\n}\n/**\n * Return batchIds based on possible attribute names for different kind of maps.\n * @param {Object} attributes {attributeName: Float32Array}\n * @returns {Array}\n */\nfunction getBatchIdsByAttributeName(attributes) {\n let batchIds = [];\n\n for (let index = 0; index < BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES.length; index++) {\n const possibleBatchIdAttributeName = BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES[index];\n if (\n attributes[possibleBatchIdAttributeName] &&\n attributes[possibleBatchIdAttributeName].value\n ) {\n batchIds = attributes[possibleBatchIdAttributeName].value;\n break;\n }\n }\n\n return batchIds;\n}\n\nfunction convertMaterials(tileContent) {\n const result = [];\n const sourceMaterials = tileContent.gltf.materials || [];\n for (const sourceMaterial of sourceMaterials) {\n result.push(convertMaterial(sourceMaterial));\n }\n return result;\n}\n\n/**\n * Convert texture and material from gltf 2.0 material object\n * @param {Object} sourceMaterial - material object\n * @returns {Object}\n */\nfunction convertMaterial(sourceMaterial) {\n const material = {\n doubleSided: sourceMaterial.doubleSided,\n emissiveFactor: sourceMaterial.emissiveFactor.map((c) => Math.round(c * 255)),\n // It is in upper case in GLTF: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#alpha-coverage\n // But it is in lower case in I3S: https://github.com/Esri/i3s-spec/blob/master/docs/1.7/materialDefinitions.cmn.md\n alphaMode: (sourceMaterial.alphaMode || 'OPAQUE').toLowerCase(),\n pbrMetallicRoughness: {\n roughnessFactor: sourceMaterial.pbrMetallicRoughness.roughnessFactor,\n metallicFactor: sourceMaterial.pbrMetallicRoughness.metallicFactor\n }\n };\n\n let texture;\n if (sourceMaterial.pbrMetallicRoughness.baseColorTexture) {\n texture = sourceMaterial.pbrMetallicRoughness.baseColorTexture.texture.source;\n material.pbrMetallicRoughness.baseColorTexture = {\n textureSetDefinitionId: 0\n };\n } else if (sourceMaterial.emissiveTexture) {\n texture = sourceMaterial.emissiveTexture.texture.source;\n // ArcGIS webscene doesn't show emissiveTexture but shows baseColorTexture\n material.pbrMetallicRoughness.baseColorTexture = {\n textureSetDefinitionId: 0\n };\n }\n\n if (!texture) {\n // Should use default baseColorFactor if it is not present in source material\n // https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-pbrmetallicroughness\n const baseColorFactor = sourceMaterial.pbrMetallicRoughness.baseColorFactor;\n material.pbrMetallicRoughness.baseColorFactor =\n (baseColorFactor && baseColorFactor.map((c) => Math.round(c * 255))) || undefined;\n }\n\n return {material, texture};\n}\n\nfunction getDefaultMaterial() {\n return {\n alphaMode: 'opaque',\n pbrMetallicRoughness: {}\n };\n}\n\n/**\n * Form \"sharedResources\" from gltf materials array\n * @param {Object} tileContent - 3d tile content\n * @returns {Object} {materialDefinitionInfos: Object[], textureDefinitionInfos: Object[]} -\n * 2 arrays in format of i3s sharedResources data https://github.com/Esri/i3s-spec/blob/master/docs/1.7/sharedResource.cmn.md\n */\nfunction getSharedResources(tileContent, nodeId) {\n const gltfMaterials = tileContent.gltf.materials;\n const i3sResources = {};\n\n if (!gltfMaterials || !gltfMaterials.length) {\n return i3sResources;\n }\n\n i3sResources.materialDefinitionInfos = [];\n for (const gltfMaterial of gltfMaterials) {\n const {materialDefinitionInfo, textureDefinitionInfo} = convertGLTFMaterialToI3sSharedResources(\n gltfMaterial,\n nodeId\n );\n i3sResources.materialDefinitionInfos.push(materialDefinitionInfo);\n if (textureDefinitionInfo) {\n i3sResources.textureDefinitionInfos = i3sResources.textureDefinitionInfos || [];\n i3sResources.textureDefinitionInfos.push(textureDefinitionInfo);\n }\n }\n return i3sResources;\n}\n\n/**\n * Convert gltf material into I3S sharedResources data\n * @param {Object} gltfMaterial - gltf material data\n * @returns {Object} - Couple {materialDefinitionInfo, textureDefinitionInfo} extracted from gltf material data\n */\nfunction convertGLTFMaterialToI3sSharedResources(gltfMaterial, nodeId) {\n const texture =\n gltfMaterial.pbrMetallicRoughness.baseColorTexture || gltfMaterial.emissiveTexture;\n let textureDefinitionInfo = null;\n if (texture) {\n textureDefinitionInfo = extractSharedResourcesTextureInfo(texture.texture, nodeId);\n }\n const {baseColorFactor, metallicFactor} = gltfMaterial.pbrMetallicRoughness;\n let colorFactor = baseColorFactor;\n // If alpha channel is 0 try to get emissive factor from gltf material.\n if ((!baseColorFactor || baseColorFactor[3] === 0) && gltfMaterial.emissiveFactor) {\n colorFactor = gltfMaterial.emissiveFactor;\n colorFactor[3] = colorFactor[3] || 1;\n }\n\n return {\n materialDefinitionInfo: extractSharedResourcesMaterialInfo(colorFactor, metallicFactor),\n textureDefinitionInfo\n };\n}\n\n/**\n * Form \"materialDefinition\" which is part of \"sharedResouces\"\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#materials\n * See formulas in appendix \"Appendix B: BRDF Implementation\":\n * const dielectricSpecular = rgb(0.04, 0.04, 0.04)\n * const black = rgb(0, 0, 0)\n * cdiff = lerp(baseColor.rgb * (1 - dielectricSpecular.r), black, metallic)\n * F0 = lerp(dieletricSpecular, baseColor.rgb, metallic)\n *\n * Assumption: F0 - specular in i3s (\"specular reflection\" <-> \"reflectance value at normal incidence\")\n * cdiff - diffuse in i3s (\"Diffuse color\" <-> \"'c' diffuse\" (c means color?))\n * @param {number[]} baseColorFactor - RGBA color in 0..1 format\n * @param {number} metallicFactor - \"metallicFactor\" attribute of gltf material object\n * @returns {Object}\n */\nfunction extractSharedResourcesMaterialInfo(baseColorFactor, metallicFactor = 0) {\n const matDielectricColorComponent = 0.04 / 255; // Color from rgb (255) to 0..1 resolution\n // All color resolutions are 0..1\n const black = new Vector4(0, 0, 0, 1);\n const unitVector = new Vector4(1, 1, 1, 1);\n const dielectricSpecular = new Vector4(\n matDielectricColorComponent,\n matDielectricColorComponent,\n matDielectricColorComponent,\n 0\n );\n const baseColorVector = new Vector4(baseColorFactor);\n // https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#metallic-roughness-material\n // Formulas for Cdiff & F0\n const firstOperand = unitVector.subtract(dielectricSpecular).multiply(baseColorVector);\n const diffuse = firstOperand.lerp(firstOperand, black, metallicFactor);\n dielectricSpecular[3] = 1;\n const specular = dielectricSpecular.lerp(dielectricSpecular, baseColorVector, metallicFactor);\n return {\n diffuse: diffuse.toArray(),\n specular: specular.toArray()\n };\n}\n\n/**\n * Form \"textureDefinition\" which is part of \"sharedResouces\"\n * @param {Object} texture - texture image info\n * @returns {Object}\n */\nfunction extractSharedResourcesTextureInfo(texture, nodeId) {\n return {\n encoding: [texture.source.mimeType],\n images: [\n {\n // 'i3s' has just size which is width of the image. Images are supposed to be square.\n // https://github.com/Esri/i3s-spec/blob/master/docs/1.7/image.cmn.md\n id: generateImageId(texture, nodeId),\n size: texture.source.image.width,\n length: [texture.source.image.data.length]\n }\n ]\n };\n}\n/*\n * Formula for counting imageId:\n * https://github.com/Esri/i3s-spec/blob/0a6366a9249b831db8436c322f8d27521e86cf07/format/Indexed%203d%20Scene%20Layer%20Format%20Specification.md#generating-image-ids\n * @param {Object} texture - texture image info\n * @returns {string}\n */\nfunction generateImageId(texture, nodeId) {\n const {width, height} = texture.source.image;\n const levelCountOfTexture = 1;\n const indexOfLevel = 0;\n const indexOfTextureInStore = nodeId + 1;\n\n const zerosCount = 32 - indexOfTextureInStore.toString(2).length;\n const rightHalf = '0'.repeat(zerosCount).concat(indexOfTextureInStore.toString(2));\n\n const shiftedLevelCountOfTexture = levelCountOfTexture << 28;\n const shiftedIndexOfLevel = indexOfLevel << 24;\n const shiftedWidth = (width - 1) << 12;\n const shiftedHeight = (height - 1) << 0;\n\n const leftHalf = shiftedLevelCountOfTexture + shiftedIndexOfLevel + shiftedWidth + shiftedHeight;\n const imageId = BigInt(`0b${leftHalf.toString(2)}${rightHalf}`);\n return imageId.toString();\n}\n\n/**\n * Make all feature ids unique through all nodes in layout.\n * @param {Array} featureIds\n * @param {Array} featureIndices\n * @param {Array} featuresHashArray\n * @param {Object} batchTable\n * @returns {void}\n */\nfunction makeFeatureIdsUnique(featureIds, featureIndices, featuresHashArray, batchTable) {\n const replaceMap = getFeaturesReplaceMap(featureIds, batchTable, featuresHashArray);\n replaceIndicesByUnique(featureIndices, replaceMap);\n replaceIndicesByUnique(featureIds, replaceMap);\n}\n\n/**\n * Generate replace map to make featureIds unique.\n * @param {Array} featureIds\n * @param {Object} batchTable\n * @param {Array} featuresHashArray\n * @returns {Object}\n */\nfunction getFeaturesReplaceMap(featureIds, batchTable, featuresHashArray) {\n const featureMap = {};\n\n for (let index = 0; index < featureIds.length; index++) {\n const oldFeatureId = featureIds[index];\n const uniqueFeatureId = getOrCreateUniqueFeatureId(index, batchTable, featuresHashArray);\n featureMap[oldFeatureId.toString()] = uniqueFeatureId;\n }\n\n return featureMap;\n}\n\n/**\n * Generates string for unique batch id creation.\n * @param {Object} batchTable\n * @param {Number} index\n * @returns {String}\n */\nfunction generateStringFromBatchTableByIndex(batchTable, index) {\n let str = '';\n for (const key in batchTable) {\n str += batchTable[key][index];\n }\n return str;\n}\n\n/**\n * Return already exited featureId or creates and returns new to support unique feature ids throw nodes.\n * @param {Number} index\n * @param {Object} batchTable\n * @param {Array} featuresHashArray\n * @returns {Number}\n */\nfunction getOrCreateUniqueFeatureId(index, batchTable, featuresHashArray) {\n const batchTableStr = generateStringFromBatchTableByIndex(batchTable, index);\n const hash = md5(batchTableStr);\n\n if (featuresHashArray.includes(hash)) {\n return featuresHashArray.indexOf(hash);\n }\n return featuresHashArray.push(hash) - 1;\n}\n\n/**\n * Do replacement of indices for making them unique through all nodes.\n * @param {Array} indicesArray\n * @param {Object} featureMap\n * @returns {void}\n */\nfunction replaceIndicesByUnique(indicesArray, featureMap) {\n for (let index = 0; index < indicesArray.length; index++) {\n indicesArray[index] = featureMap[indicesArray[index]];\n }\n}\n\n/**\n * Convert batch table data to attribute buffers.\n * @param {Object} batchTable - table with metadata for particular feature.\n * @param {Array} featureIds\n * @param {Array} attributeStorageInfo\n * @returns {Array} - Array of file buffers.\n */\nfunction convertBatchTableToAttributeBuffers(batchTable, featureIds, attributeStorageInfo) {\n const attributeBuffers = [];\n\n if (batchTable) {\n const batchTableWithFeatureIds = {\n OBJECTID: featureIds,\n ...batchTable\n };\n\n for (const key in batchTableWithFeatureIds) {\n const type = getAttributeType(key, attributeStorageInfo);\n\n let attributeBuffer = null;\n\n switch (type) {\n case OBJECT_ID_TYPE:\n case SHORT_INT_TYPE:\n attributeBuffer = generateShortIntegerAttributeBuffer(batchTableWithFeatureIds[key]);\n break;\n case DOUBLE_TYPE:\n attributeBuffer = generateDoubleAttributeBuffer(batchTableWithFeatureIds[key]);\n break;\n case STRING_TYPE:\n attributeBuffer = generateStringAttributeBuffer(batchTableWithFeatureIds[key]);\n break;\n default:\n attributeBuffer = generateStringAttributeBuffer(batchTableWithFeatureIds[key]);\n }\n\n attributeBuffers.push(attributeBuffer);\n }\n }\n\n return attributeBuffers;\n}\n/**\n * Return attribute type.\n * @param {String} key\n * @param {Array} attributeStorageInfo\n * @returns {String} attribute type.\n */\nfunction getAttributeType(key, attributeStorageInfo) {\n const attribute = attributeStorageInfo.find((attr) => attr.name === key);\n return attribute.attributeValues.valueType;\n}\n\n/**\n * Convert short integer to attribute arrayBuffer.\n * @param {Array} featureIds\n * @returns {ArrayBuffer} - Buffer with objectId data.\n */\nfunction generateShortIntegerAttributeBuffer(featureIds) {\n const count = new Uint32Array([featureIds.length]);\n const valuesArray = new Uint32Array(featureIds);\n return concatenateArrayBuffers(count.buffer, valuesArray.buffer);\n}\n\n/**\n * Convert double to attribute arrayBuffer.\n * @param {Array} featureIds\n * @returns {ArrayBuffer} - Buffer with objectId data.\n */\nfunction generateDoubleAttributeBuffer(featureIds) {\n const count = new Uint32Array([featureIds.length]);\n const padding = new Uint8Array(4);\n const valuesArray = new Float64Array(featureIds);\n\n return concatenateArrayBuffers(count.buffer, padding.buffer, valuesArray.buffer);\n}\n\n/**\n * Convert batch table attributes to array buffer with batch table data.\n * @param {Array} batchAttributes\n * @returns {ArrayBuffer} - Buffer with batch table data.\n */\nfunction generateStringAttributeBuffer(batchAttributes) {\n const stringCountArray = new Uint32Array([batchAttributes.length]);\n let totalNumberOfBytes = 0;\n const stringSizesArray = new Uint32Array(batchAttributes.length);\n const stringBufferArray = [];\n\n for (let index = 0; index < batchAttributes.length; index++) {\n const currentString = `${String(batchAttributes[index])}\\0`;\n const currentStringBuffer = Buffer.from(currentString);\n const currentStringSize = currentStringBuffer.length;\n totalNumberOfBytes += currentStringSize;\n stringSizesArray[index] = currentStringSize;\n stringBufferArray.push(currentStringBuffer);\n }\n\n const totalBytes = new Uint32Array([totalNumberOfBytes]);\n\n return concatenateArrayBuffers(\n stringCountArray.buffer,\n totalBytes.buffer,\n stringSizesArray.buffer,\n ...stringBufferArray\n );\n}\n\n/**\n * Convert featureIds to BigUint64Array.\n * @param {Array} featureIds\n * @returns {BigUint64Array} - Array of feature ids in BigUint64 format.\n */\nfunction generateBigUint64Array(featureIds) {\n const typedFeatureIds = new BigUint64Array(featureIds.length);\n for (let index = 0; index < featureIds.length; index++) {\n typedFeatureIds[index] = BigInt(featureIds[index]);\n }\n return typedFeatureIds;\n}\n\n/**\n * Generates draco compressed geometry\n * @param {Number} vertexCount\n * @param {Object} convertedAttributes\n * @returns {Promise<object>} - COmpressed geometry.\n */\nasync function generateCompressedGeometry(vertexCount, convertedAttributes, attributes) {\n const {positions, normals, texCoords, colors, featureIds, faceRange} = attributes;\n const indices = new Uint32Array(vertexCount);\n\n for (let index = 0; index < indices.length; index++) {\n indices.set([index], index);\n }\n\n const featureIndices = new Uint32Array(\n convertedAttributes.featureIndices.length ? convertedAttributes.featureIndices : vertexCount\n );\n\n const featureIndex = generateFeatureIndexAttribute(featureIndices, faceRange);\n\n const compressedAttributes = {\n positions,\n normals,\n colors,\n 'feature-index': featureIndex\n };\n\n if (texCoords.length) {\n compressedAttributes.texCoords = texCoords;\n }\n\n const attributesMetadata = {\n 'feature-index': {\n 'i3s-attribute-type': 'feature-index',\n 'i3s-feature-ids': new Int32Array(featureIds)\n }\n };\n\n return new Uint8Array(\n await encode({attributes: compressedAttributes, indices}, DracoWriter, {\n draco: {\n method: 'MESH_SEQUENTIAL_ENCODING',\n attributesMetadata\n }\n })\n );\n}\n\n/**\n * Generates ordered feature indices based on face range\n * @param {Uint32Array} featureIndex\n * @param {Uint32Array} faceRange\n * @returns {Uint32Array}\n */\nfunction generateFeatureIndexAttribute(featureIndex, faceRange) {\n const orderedFeatureIndices = new Uint32Array(featureIndex.length);\n let fillIndex = 0;\n let startIndex = 0;\n\n for (let index = 1; index < faceRange.length; index += 2) {\n const endIndex = (faceRange[index] + 1) * VALUES_PER_VERTEX;\n\n orderedFeatureIndices.fill(fillIndex, startIndex, endIndex);\n\n fillIndex++;\n startIndex = endIndex + 1;\n }\n\n return orderedFeatureIndices;\n}\n"],"file":"geometry-converter.js"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/i3s-converter/helpers/geometry-converter.js"],"names":["VALUES_PER_VERTEX","VALUES_PER_TEX_COORD","VALUES_PER_COLOR_ELEMENT","STRING_TYPE","SHORT_INT_TYPE","DOUBLE_TYPE","OBJECT_ID_TYPE","BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES","convertB3dmToI3sGeometry","tileContent","nodeId","featuresHashArray","attributeStorageInfo","draco","materialAndTextureList","convertMaterials","convertedAttributesMap","convertAttributes","has","push","material","getDefaultMaterial","result","nodesCounter","materials","gltf","length","id","i","sourceMaterial","convertedAttributes","get","texture","_makeNodeResources","vertexCount","positions","triangleCount","faceRange","featureIds","normals","colors","texCoords","featureCount","batchTableJson","makeFeatureIdsUnique","featureIndices","header","Uint32Array","typedFeatureIds","generateBigUint64Array","set","fileBuffer","Uint8Array","buffer","ArrayBuffer","compressedGeometry","generateCompressedGeometry","Float32Array","attributes","convertBatchTableToAttributeBuffers","geometry","sharedResources","getSharedResources","meshMaterial","attributesMap","Map","nodes","scene","scenes","convertNodes","attrKey","keys","delete","reduce","acc","value","concat","matrix","Matrix4","node","convertNode","nodeMatrix","compositeMatrix","multiplyRight","mesh","convertMesh","children","content","primitive","primitives","outputAttributes","transformVertexArray","vertices","POSITION","cartographicOrigin","cartesianModelMatrix","indices","attributeSpecificTransformation","transformVertexPositions","NORMAL","transformVertexNormals","flattenTexCoords","TEXCOORD_0","flattenColors","COLOR_0","flattenBatchIds","getBatchIdsByAttributeName","args","newVertices","coordIndex","vertex","subarray","vertexVector","Vector3","Array","from","x","y","z","calleeArgs","transform","Ellipsoid","WGS84","cartesianToCartographic","subtract","transformAsVector","newTexCoords","fill","texCoord","colorsAttribute","components","newColors","colorIndex","color","colorUint8","j","batchedIds","newBatchIds","batchIds","index","possibleBatchIdAttributeName","sourceMaterials","convertMaterial","doubleSided","emissiveFactor","map","c","Math","round","alphaMode","toLowerCase","pbrMetallicRoughness","roughnessFactor","metallicFactor","baseColorTexture","source","textureSetDefinitionId","emissiveTexture","baseColorFactor","undefined","gltfMaterials","i3sResources","materialDefinitionInfos","gltfMaterial","materialDefinitionInfo","textureDefinitionInfo","convertGLTFMaterialToI3sSharedResources","textureDefinitionInfos","extractSharedResourcesTextureInfo","colorFactor","extractSharedResourcesMaterialInfo","matDielectricColorComponent","black","Vector4","unitVector","dielectricSpecular","baseColorVector","firstOperand","multiply","diffuse","lerp","specular","toArray","encoding","mimeType","images","generateImageId","size","image","width","data","height","levelCountOfTexture","indexOfLevel","indexOfTextureInStore","zerosCount","toString","rightHalf","repeat","shiftedLevelCountOfTexture","shiftedIndexOfLevel","shiftedWidth","shiftedHeight","leftHalf","imageId","BigInt","batchTable","replaceMap","getFeaturesReplaceMap","replaceIndicesByUnique","featureMap","oldFeatureId","uniqueFeatureId","getOrCreateUniqueFeatureId","generateStringFromBatchTableByIndex","str","key","batchTableStr","hash","includes","indexOf","indicesArray","attributeBuffers","batchTableWithFeatureIds","OBJECTID","type","getAttributeType","attributeBuffer","generateShortIntegerAttributeBuffer","generateDoubleAttributeBuffer","generateStringAttributeBuffer","attribute","find","attr","name","attributeValues","valueType","count","valuesArray","padding","Float64Array","batchAttributes","stringCountArray","totalNumberOfBytes","stringSizesArray","stringBufferArray","currentString","String","currentStringBuffer","Buffer","currentStringSize","totalBytes","BigUint64Array","featureIndex","generateFeatureIndexAttribute","compressedAttributes","attributesMetadata","Int32Array","DracoWriter","method","orderedFeatureIndices","fillIndex","startIndex","endIndex"],"mappings":"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","sourcesContent":["import {Vector3, Matrix4, Vector4} from '@math.gl/core';\nimport {Ellipsoid} from '@math.gl/geospatial';\n\nimport {DracoWriter} from '@loaders.gl/draco';\nimport {encode, assert} from '@loaders.gl/core';\nimport {concatenateArrayBuffers, concatenateTypedArrays} from '@loaders.gl/loader-utils';\nimport md5 from 'md5';\nimport {generateAttributes} from './geometry-attributes';\n\nconst VALUES_PER_VERTEX = 3;\nconst VALUES_PER_TEX_COORD = 2;\nconst VALUES_PER_COLOR_ELEMENT = 4;\n\nconst STRING_TYPE = 'string';\nconst SHORT_INT_TYPE = 'Int32';\nconst DOUBLE_TYPE = 'Float64';\nconst OBJECT_ID_TYPE = 'Oid32';\n/*\n * 'CUSTOM_ATTRIBUTE_2' - Attribute name which includes batch info and used by New York map.\n * _BATCHID - Default attribute name which includes batch info.\n * BATCHID - Legacy attribute name which includes batch info.\n */\nconst BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES = ['CUSTOM_ATTRIBUTE_2', '_BATCHID', 'BATCHID'];\n\nexport default async function convertB3dmToI3sGeometry(\n tileContent,\n nodeId,\n featuresHashArray,\n attributeStorageInfo,\n draco\n) {\n const materialAndTextureList = convertMaterials(tileContent);\n const convertedAttributesMap = convertAttributes(tileContent);\n\n if (convertedAttributesMap.has('default')) {\n materialAndTextureList.push({\n material: getDefaultMaterial()\n });\n }\n\n const result = [];\n let nodesCounter = nodeId;\n let {materials = []} = tileContent.gltf;\n if (!materials.length === 0) {\n materials.push({id: 'default'});\n }\n for (let i = 0; i < materials.length; i++) {\n const sourceMaterial = materials[i];\n if (!convertedAttributesMap.has(sourceMaterial.id)) {\n continue; // eslint-disable-line no-continue\n }\n const convertedAttributes = convertedAttributesMap.get(sourceMaterial.id);\n const {material, texture} = materialAndTextureList[i];\n result.push(\n await _makeNodeResources({\n convertedAttributes,\n material,\n texture,\n tileContent,\n nodeId: nodesCounter,\n featuresHashArray,\n attributeStorageInfo,\n draco\n })\n );\n nodesCounter++;\n }\n\n if (!result.length) {\n return null;\n }\n return result;\n}\n\nasync function _makeNodeResources({\n convertedAttributes,\n material,\n texture,\n tileContent,\n nodeId,\n featuresHashArray,\n attributeStorageInfo,\n draco\n}) {\n const vertexCount = convertedAttributes.positions.length / VALUES_PER_VERTEX;\n const triangleCount = vertexCount / 3;\n const {faceRange, featureIds, positions, normals, colors, texCoords, featureCount} =\n generateAttributes({triangleCount, ...convertedAttributes});\n\n if (tileContent.batchTableJson) {\n makeFeatureIdsUnique(\n featureIds,\n convertedAttributes.featureIndices,\n featuresHashArray,\n tileContent.batchTableJson\n );\n }\n\n const header = new Uint32Array(2);\n const typedFeatureIds = generateBigUint64Array(featureIds);\n\n header.set([vertexCount, featureCount], 0);\n const fileBuffer = new Uint8Array(\n concatenateArrayBuffers(\n header.buffer,\n positions.buffer,\n normals.buffer,\n texture ? texCoords.buffer : new ArrayBuffer(0),\n colors.buffer,\n typedFeatureIds.buffer,\n faceRange.buffer\n )\n );\n const compressedGeometry = draco\n ? await generateCompressedGeometry(vertexCount, convertedAttributes, {\n positions,\n normals,\n texCoords: texture ? texCoords : new Float32Array(0),\n colors,\n featureIds,\n faceRange\n })\n : null;\n\n const attributes = convertBatchTableToAttributeBuffers(\n tileContent.batchTableJson,\n featureIds,\n attributeStorageInfo\n );\n\n return {\n geometry: fileBuffer,\n compressedGeometry,\n texture,\n sharedResources: getSharedResources(tileContent, nodeId),\n meshMaterial: material,\n vertexCount,\n attributes,\n featureCount\n };\n}\n\n/**\n * Convert attributes from the gltf nodes tree to i3s plain geometry\n * @param {Object} tileContent - 3d tile content\n * @returns {Map}\n * Map<{\n * positions: Float32Array,\n * normals: Float32Array,\n * colors: Uint8Array,\n * texCoords: Float32Array\n * }>\n * @todo implement colors support (if applicable for gltf format)\n */\nfunction convertAttributes(tileContent) {\n const attributesMap = new Map();\n\n for (const material of tileContent.gltf.materials || [{id: 'default'}]) {\n attributesMap.set(material.id, {\n positions: new Float32Array(0),\n normals: new Float32Array(0),\n texCoords: new Float32Array(0),\n colors: new Uint8Array(0),\n featureIndices: []\n });\n }\n\n const nodes = (tileContent.gltf.scene || tileContent.gltf.scenes?.[0] || tileContent.gltf).nodes;\n convertNodes(nodes, tileContent, attributesMap);\n\n for (const attrKey of attributesMap.keys()) {\n const attributes = attributesMap.get(attrKey);\n if (attributes.positions.length === 0) {\n attributesMap.delete(attrKey);\n continue; // eslint-disable-line no-continue\n }\n attributes.featureIndices = attributes.featureIndices.reduce((acc, value) => acc.concat(value));\n }\n\n return attributesMap;\n}\n\n/**\n * Gltf has hierarchical structure of nodes. This function converts nodes starting from those which are in gltf scene object.\n * The goal is applying tranformation matrix for all children. Functions \"convertNodes\" and \"convertNode\" work together recursively.\n * @param {Object[]} nodes - gltf nodes array\n * @param {Object} tileContent - 3d tile content\n * @param {Map} attributesMap Map<{positions: Float32Array, normals: Float32Array, texCoords: Float32Array, colors: UInt8Array, featureIndices: Array}> - for recursive concatenation of\n * attributes\n * @param {Matrix4} matrix - transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @returns {void}\n */\nfunction convertNodes(\n nodes,\n tileContent,\n attributesMap,\n matrix = new Matrix4([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])\n) {\n if (nodes) {\n for (const node of nodes) {\n convertNode(node, tileContent, attributesMap, matrix);\n }\n }\n}\n\n/**\n * Convert all primitives of node and all children nodes\n * @param {Object} node - gltf node\n * @param {Object} tileContent - 3d tile content\n * @param {Map} attributesMap Map<{positions: Float32Array, normals: Float32Array, texCoords: Float32Array, colors: Uint8Array, featureIndices: Array}> - for recursive concatenation of\n * attributes\n * @param {Matrix4} matrix - transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @todo: optimize arrays concatenation\n */\nfunction convertNode(\n node,\n tileContent,\n attributesMap,\n matrix = new Matrix4([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])\n) {\n const nodeMatrix = node.matrix;\n const compositeMatrix = nodeMatrix ? matrix.multiplyRight(nodeMatrix) : matrix;\n\n const mesh = node.mesh;\n if (mesh) {\n convertMesh(mesh, tileContent, attributesMap, compositeMatrix);\n }\n\n convertNodes(node.children, tileContent, attributesMap, compositeMatrix);\n}\n\n/**\n * Convert all primitives of node and all children nodes\n * @param {Object} mesh - gltf node\n * @param {Object} content - 3d tile content\n * @param {Map} attributesMap Map<{positions: Float32Array, normals: Float32Array, texCoords: Float32Array, colors: Uint8Array, featureIndices: Array}> - for recursive concatenation of\n * attributes\n * @param {Matrix4} matrix - transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @todo: optimize arrays concatenation\n */\nfunction convertMesh(\n mesh,\n content,\n attributesMap,\n matrix = new Matrix4([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])\n) {\n for (const primitive of mesh.primitives) {\n let outputAttributes = null;\n if (primitive.material) {\n outputAttributes = attributesMap.get(primitive.material.id);\n } else if (attributesMap.has('default')) {\n outputAttributes = attributesMap.get('default');\n }\n assert(outputAttributes !== null, 'Primitive - material mapping failed');\n const attributes = primitive.attributes;\n\n outputAttributes.positions = concatenateTypedArrays(\n outputAttributes.positions,\n transformVertexArray({\n vertices: attributes.POSITION.value,\n cartographicOrigin: content.cartographicOrigin,\n cartesianModelMatrix: content.cartesianModelMatrix,\n nodeMatrix: matrix,\n indices: primitive.indices.value,\n attributeSpecificTransformation: transformVertexPositions\n })\n );\n outputAttributes.normals = concatenateTypedArrays(\n outputAttributes.normals,\n transformVertexArray({\n vertices: attributes.NORMAL && attributes.NORMAL.value,\n cartographicOrigin: content.cartographicOrigin,\n cartesianModelMatrix: content.cartesianModelMatrix,\n nodeMatrix: matrix,\n indices: primitive.indices.value,\n attributeSpecificTransformation: transformVertexNormals\n })\n );\n outputAttributes.texCoords = concatenateTypedArrays(\n outputAttributes.texCoords,\n flattenTexCoords(\n attributes.TEXCOORD_0 && attributes.TEXCOORD_0.value,\n primitive.indices.value\n )\n );\n\n outputAttributes.colors = concatenateTypedArrays(\n outputAttributes.colors,\n flattenColors(attributes.COLOR_0, primitive.indices.value)\n );\n\n outputAttributes.featureIndices.push(\n flattenBatchIds(getBatchIdsByAttributeName(attributes), primitive.indices.value)\n );\n }\n}\n\n/**\n * Convert vertices attributes (POSITIONS or NORMALS) to i3s compatible format\n * @param {object} args - source tile (3DTile)\n * @param {Float32Array} args.vertices - gltf primitive POSITION or NORMAL attribute\n * @param {Object} args.cartographicOrigin - cartographic origin coordinates\n * @param {Object} args.cartesianModelMatrix - a cartesian model matrix to transform coordnates from cartesian to cartographic format\n * @param {Matrix4} args.nodeMatrix - a gltf node transformation matrix - cumulative transformation matrix formed from all parent node matrices\n * @param {Uint8Array} args.indices - gltf primitive indices\n * @param {Function} args.attributeSpecificTransformation - function to do attribute - specific transformations\n * @returns {Float32Array}\n */\nfunction transformVertexArray(args) {\n const {vertices, indices, attributeSpecificTransformation} = args;\n const newVertices = new Float32Array(indices.length * VALUES_PER_VERTEX);\n if (!vertices) {\n return newVertices;\n }\n for (let i = 0; i < indices.length; i++) {\n const coordIndex = indices[i] * VALUES_PER_VERTEX;\n const vertex = vertices.subarray(coordIndex, coordIndex + VALUES_PER_VERTEX);\n let vertexVector = new Vector3(Array.from(vertex));\n\n vertexVector = attributeSpecificTransformation(vertexVector, args);\n\n newVertices[i * VALUES_PER_VERTEX] = vertexVector.x;\n newVertices[i * VALUES_PER_VERTEX + 1] = vertexVector.y;\n newVertices[i * VALUES_PER_VERTEX + 2] = vertexVector.z;\n }\n return newVertices;\n}\n\nfunction transformVertexPositions(vertexVector, calleeArgs) {\n const {cartesianModelMatrix, cartographicOrigin, nodeMatrix} = calleeArgs;\n\n if (nodeMatrix) {\n vertexVector = vertexVector.transform(nodeMatrix);\n }\n\n vertexVector = vertexVector.transform(cartesianModelMatrix);\n Ellipsoid.WGS84.cartesianToCartographic(\n [vertexVector[0], vertexVector[1], vertexVector[2]],\n vertexVector\n );\n vertexVector = vertexVector.subtract(cartographicOrigin);\n return vertexVector;\n}\n\nfunction transformVertexNormals(vertexVector, calleeArgs) {\n const {cartesianModelMatrix, nodeMatrix} = calleeArgs;\n\n if (nodeMatrix) {\n vertexVector = vertexVector.transformAsVector(nodeMatrix);\n }\n\n vertexVector = vertexVector.transformAsVector(cartesianModelMatrix);\n return vertexVector;\n}\n\n/**\n * Convert uv0 (texture coordinates) from coords based on indices to plain arrays, compatible with i3s\n * @param {Float32Array} texCoords - gltf primitive TEXCOORD_0 attribute\n * @param {Uint8Array} indices - gltf primitive indices\n * @returns {Float32Array}\n */\nfunction flattenTexCoords(texCoords, indices) {\n const newTexCoords = new Float32Array(indices.length * VALUES_PER_TEX_COORD);\n if (!texCoords) {\n // We need dummy UV0s because it is required in 1.6\n // https://github.com/Esri/i3s-spec/blob/master/docs/1.6/vertexAttribute.cmn.md\n newTexCoords.fill(1);\n return newTexCoords;\n }\n for (let i = 0; i < indices.length; i++) {\n const coordIndex = indices[i] * VALUES_PER_TEX_COORD;\n const texCoord = texCoords.subarray(coordIndex, coordIndex + VALUES_PER_TEX_COORD);\n newTexCoords[i * VALUES_PER_TEX_COORD] = texCoord[0];\n newTexCoords[i * VALUES_PER_TEX_COORD + 1] = texCoord[1];\n }\n return newTexCoords;\n}\n\n/**\n * Convert color from COLOR_0 based on indices to plain arrays, compatible with i3s\n * @param {object} colorsAttribute - gltf primitive COLOR_0 attribute\n * @param {Uint8Array} indices - gltf primitive indices\n * @returns {Uint8Array}\n */\nfunction flattenColors(colorsAttribute, indices) {\n const components = colorsAttribute?.components || VALUES_PER_COLOR_ELEMENT;\n const newColors = new Uint8Array(indices.length * components);\n if (!colorsAttribute) {\n // Vertex color multiplies by material color so it must be normalized 1 by default\n newColors.fill(255);\n return newColors;\n }\n const colors = colorsAttribute.value;\n for (let i = 0; i < indices.length; i++) {\n const colorIndex = indices[i] * components;\n const color = colors.subarray(colorIndex, colorIndex + components);\n const colorUint8 = new Uint8Array(components);\n for (let j = 0; j < color.length; j++) {\n colorUint8[j] = color[j] * 255;\n }\n newColors.set(colorUint8, i * components);\n }\n return newColors;\n}\n\n/**\n * Flatten batchedIds list based on indices to right ordered array, compatible with i3s\n * @param {Array} batchedIds - gltf primitive\n * @param {Uint8Array} indices - gltf primitive indices\n * @returns {Array}\n */\nfunction flattenBatchIds(batchedIds, indices) {\n if (!batchedIds.length || !indices.length) {\n return [];\n }\n const newBatchIds = [];\n for (let i = 0; i < indices.length; i++) {\n const coordIndex = indices[i];\n newBatchIds.push(batchedIds[coordIndex]);\n }\n return newBatchIds;\n}\n/**\n * Return batchIds based on possible attribute names for different kind of maps.\n * @param {Object} attributes {attributeName: Float32Array}\n * @returns {Array}\n */\nfunction getBatchIdsByAttributeName(attributes) {\n let batchIds = [];\n\n for (let index = 0; index < BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES.length; index++) {\n const possibleBatchIdAttributeName = BATCHED_ID_POSSIBLE_ATTRIBUTE_NAMES[index];\n if (\n attributes[possibleBatchIdAttributeName] &&\n attributes[possibleBatchIdAttributeName].value\n ) {\n batchIds = attributes[possibleBatchIdAttributeName].value;\n break;\n }\n }\n\n return batchIds;\n}\n\nfunction convertMaterials(tileContent) {\n const result = [];\n const sourceMaterials = tileContent.gltf.materials || [];\n for (const sourceMaterial of sourceMaterials) {\n result.push(convertMaterial(sourceMaterial));\n }\n return result;\n}\n\n/**\n * Convert texture and material from gltf 2.0 material object\n * @param {Object} sourceMaterial - material object\n * @returns {Object}\n */\nfunction convertMaterial(sourceMaterial) {\n const material = {\n doubleSided: sourceMaterial.doubleSided,\n emissiveFactor: sourceMaterial.emissiveFactor.map((c) => Math.round(c * 255)),\n // It is in upper case in GLTF: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#alpha-coverage\n // But it is in lower case in I3S: https://github.com/Esri/i3s-spec/blob/master/docs/1.7/materialDefinitions.cmn.md\n alphaMode: (sourceMaterial.alphaMode || 'OPAQUE').toLowerCase(),\n pbrMetallicRoughness: {\n roughnessFactor: sourceMaterial.pbrMetallicRoughness.roughnessFactor,\n metallicFactor: sourceMaterial.pbrMetallicRoughness.metallicFactor\n }\n };\n\n let texture;\n if (sourceMaterial.pbrMetallicRoughness.baseColorTexture) {\n texture = sourceMaterial.pbrMetallicRoughness.baseColorTexture.texture.source;\n material.pbrMetallicRoughness.baseColorTexture = {\n textureSetDefinitionId: 0\n };\n } else if (sourceMaterial.emissiveTexture) {\n texture = sourceMaterial.emissiveTexture.texture.source;\n // ArcGIS webscene doesn't show emissiveTexture but shows baseColorTexture\n material.pbrMetallicRoughness.baseColorTexture = {\n textureSetDefinitionId: 0\n };\n }\n\n if (!texture) {\n // Should use default baseColorFactor if it is not present in source material\n // https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-pbrmetallicroughness\n const baseColorFactor = sourceMaterial.pbrMetallicRoughness.baseColorFactor;\n material.pbrMetallicRoughness.baseColorFactor =\n (baseColorFactor && baseColorFactor.map((c) => Math.round(c * 255))) || undefined;\n }\n\n return {material, texture};\n}\n\nfunction getDefaultMaterial() {\n return {\n alphaMode: 'opaque',\n pbrMetallicRoughness: {}\n };\n}\n\n/**\n * Form \"sharedResources\" from gltf materials array\n * @param {Object} tileContent - 3d tile content\n * @returns {Object} {materialDefinitionInfos: Object[], textureDefinitionInfos: Object[]} -\n * 2 arrays in format of i3s sharedResources data https://github.com/Esri/i3s-spec/blob/master/docs/1.7/sharedResource.cmn.md\n */\nfunction getSharedResources(tileContent, nodeId) {\n const gltfMaterials = tileContent.gltf.materials;\n const i3sResources = {};\n\n if (!gltfMaterials || !gltfMaterials.length) {\n return i3sResources;\n }\n\n i3sResources.materialDefinitionInfos = [];\n for (const gltfMaterial of gltfMaterials) {\n const {materialDefinitionInfo, textureDefinitionInfo} = convertGLTFMaterialToI3sSharedResources(\n gltfMaterial,\n nodeId\n );\n i3sResources.materialDefinitionInfos.push(materialDefinitionInfo);\n if (textureDefinitionInfo) {\n i3sResources.textureDefinitionInfos = i3sResources.textureDefinitionInfos || [];\n i3sResources.textureDefinitionInfos.push(textureDefinitionInfo);\n }\n }\n return i3sResources;\n}\n\n/**\n * Convert gltf material into I3S sharedResources data\n * @param {Object} gltfMaterial - gltf material data\n * @returns {Object} - Couple {materialDefinitionInfo, textureDefinitionInfo} extracted from gltf material data\n */\nfunction convertGLTFMaterialToI3sSharedResources(gltfMaterial, nodeId) {\n const texture =\n gltfMaterial.pbrMetallicRoughness.baseColorTexture || gltfMaterial.emissiveTexture;\n let textureDefinitionInfo = null;\n if (texture) {\n textureDefinitionInfo = extractSharedResourcesTextureInfo(texture.texture, nodeId);\n }\n const {baseColorFactor, metallicFactor} = gltfMaterial.pbrMetallicRoughness;\n let colorFactor = baseColorFactor;\n // If alpha channel is 0 try to get emissive factor from gltf material.\n if ((!baseColorFactor || baseColorFactor[3] === 0) && gltfMaterial.emissiveFactor) {\n colorFactor = gltfMaterial.emissiveFactor;\n colorFactor[3] = colorFactor[3] || 1;\n }\n\n return {\n materialDefinitionInfo: extractSharedResourcesMaterialInfo(colorFactor, metallicFactor),\n textureDefinitionInfo\n };\n}\n\n/**\n * Form \"materialDefinition\" which is part of \"sharedResouces\"\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#materials\n * See formulas in appendix \"Appendix B: BRDF Implementation\":\n * const dielectricSpecular = rgb(0.04, 0.04, 0.04)\n * const black = rgb(0, 0, 0)\n * cdiff = lerp(baseColor.rgb * (1 - dielectricSpecular.r), black, metallic)\n * F0 = lerp(dieletricSpecular, baseColor.rgb, metallic)\n *\n * Assumption: F0 - specular in i3s (\"specular reflection\" <-> \"reflectance value at normal incidence\")\n * cdiff - diffuse in i3s (\"Diffuse color\" <-> \"'c' diffuse\" (c means color?))\n * @param {number[]} baseColorFactor - RGBA color in 0..1 format\n * @param {number} metallicFactor - \"metallicFactor\" attribute of gltf material object\n * @returns {Object}\n */\nfunction extractSharedResourcesMaterialInfo(baseColorFactor, metallicFactor = 0) {\n const matDielectricColorComponent = 0.04 / 255; // Color from rgb (255) to 0..1 resolution\n // All color resolutions are 0..1\n const black = new Vector4(0, 0, 0, 1);\n const unitVector = new Vector4(1, 1, 1, 1);\n const dielectricSpecular = new Vector4(\n matDielectricColorComponent,\n matDielectricColorComponent,\n matDielectricColorComponent,\n 0\n );\n const baseColorVector = new Vector4(baseColorFactor);\n // https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#metallic-roughness-material\n // Formulas for Cdiff & F0\n const firstOperand = unitVector.subtract(dielectricSpecular).multiply(baseColorVector);\n const diffuse = firstOperand.lerp(firstOperand, black, metallicFactor);\n dielectricSpecular[3] = 1;\n const specular = dielectricSpecular.lerp(dielectricSpecular, baseColorVector, metallicFactor);\n return {\n diffuse: diffuse.toArray(),\n specular: specular.toArray()\n };\n}\n\n/**\n * Form \"textureDefinition\" which is part of \"sharedResouces\"\n * @param {Object} texture - texture image info\n * @returns {Object}\n */\nfunction extractSharedResourcesTextureInfo(texture, nodeId) {\n return {\n encoding: [texture.source.mimeType],\n images: [\n {\n // 'i3s' has just size which is width of the image. Images are supposed to be square.\n // https://github.com/Esri/i3s-spec/blob/master/docs/1.7/image.cmn.md\n id: generateImageId(texture, nodeId),\n size: texture.source.image.width,\n length: [texture.source.image.data.length]\n }\n ]\n };\n}\n/*\n * Formula for counting imageId:\n * https://github.com/Esri/i3s-spec/blob/0a6366a9249b831db8436c322f8d27521e86cf07/format/Indexed%203d%20Scene%20Layer%20Format%20Specification.md#generating-image-ids\n * @param {Object} texture - texture image info\n * @returns {string}\n */\nfunction generateImageId(texture, nodeId) {\n const {width, height} = texture.source.image;\n const levelCountOfTexture = 1;\n const indexOfLevel = 0;\n const indexOfTextureInStore = nodeId + 1;\n\n const zerosCount = 32 - indexOfTextureInStore.toString(2).length;\n const rightHalf = '0'.repeat(zerosCount).concat(indexOfTextureInStore.toString(2));\n\n const shiftedLevelCountOfTexture = levelCountOfTexture << 28;\n const shiftedIndexOfLevel = indexOfLevel << 24;\n const shiftedWidth = (width - 1) << 12;\n const shiftedHeight = (height - 1) << 0;\n\n const leftHalf = shiftedLevelCountOfTexture + shiftedIndexOfLevel + shiftedWidth + shiftedHeight;\n const imageId = BigInt(`0b${leftHalf.toString(2)}${rightHalf}`);\n return imageId.toString();\n}\n\n/**\n * Make all feature ids unique through all nodes in layout.\n * @param {Array} featureIds\n * @param {Array} featureIndices\n * @param {Array} featuresHashArray\n * @param {Object} batchTable\n * @returns {void}\n */\nfunction makeFeatureIdsUnique(featureIds, featureIndices, featuresHashArray, batchTable) {\n const replaceMap = getFeaturesReplaceMap(featureIds, batchTable, featuresHashArray);\n replaceIndicesByUnique(featureIndices, replaceMap);\n replaceIndicesByUnique(featureIds, replaceMap);\n}\n\n/**\n * Generate replace map to make featureIds unique.\n * @param {Array} featureIds\n * @param {Object} batchTable\n * @param {Array} featuresHashArray\n * @returns {Object}\n */\nfunction getFeaturesReplaceMap(featureIds, batchTable, featuresHashArray) {\n const featureMap = {};\n\n for (let index = 0; index < featureIds.length; index++) {\n const oldFeatureId = featureIds[index];\n const uniqueFeatureId = getOrCreateUniqueFeatureId(index, batchTable, featuresHashArray);\n featureMap[oldFeatureId.toString()] = uniqueFeatureId;\n }\n\n return featureMap;\n}\n\n/**\n * Generates string for unique batch id creation.\n * @param {Object} batchTable\n * @param {Number} index\n * @returns {String}\n */\nfunction generateStringFromBatchTableByIndex(batchTable, index) {\n let str = '';\n for (const key in batchTable) {\n str += batchTable[key][index];\n }\n return str;\n}\n\n/**\n * Return already exited featureId or creates and returns new to support unique feature ids throw nodes.\n * @param {Number} index\n * @param {Object} batchTable\n * @param {Array} featuresHashArray\n * @returns {Number}\n */\nfunction getOrCreateUniqueFeatureId(index, batchTable, featuresHashArray) {\n const batchTableStr = generateStringFromBatchTableByIndex(batchTable, index);\n const hash = md5(batchTableStr);\n\n if (featuresHashArray.includes(hash)) {\n return featuresHashArray.indexOf(hash);\n }\n return featuresHashArray.push(hash) - 1;\n}\n\n/**\n * Do replacement of indices for making them unique through all nodes.\n * @param {Array} indicesArray\n * @param {Object} featureMap\n * @returns {void}\n */\nfunction replaceIndicesByUnique(indicesArray, featureMap) {\n for (let index = 0; index < indicesArray.length; index++) {\n indicesArray[index] = featureMap[indicesArray[index]];\n }\n}\n\n/**\n * Convert batch table data to attribute buffers.\n * @param {Object} batchTable - table with metadata for particular feature.\n * @param {Array} featureIds\n * @param {Array} attributeStorageInfo\n * @returns {Array} - Array of file buffers.\n */\nfunction convertBatchTableToAttributeBuffers(batchTable, featureIds, attributeStorageInfo) {\n const attributeBuffers = [];\n\n if (batchTable) {\n const batchTableWithFeatureIds = {\n OBJECTID: featureIds,\n ...batchTable\n };\n\n for (const key in batchTableWithFeatureIds) {\n const type = getAttributeType(key, attributeStorageInfo);\n\n let attributeBuffer = null;\n\n switch (type) {\n case OBJECT_ID_TYPE:\n case SHORT_INT_TYPE:\n attributeBuffer = generateShortIntegerAttributeBuffer(batchTableWithFeatureIds[key]);\n break;\n case DOUBLE_TYPE:\n attributeBuffer = generateDoubleAttributeBuffer(batchTableWithFeatureIds[key]);\n break;\n case STRING_TYPE:\n attributeBuffer = generateStringAttributeBuffer(batchTableWithFeatureIds[key]);\n break;\n default:\n attributeBuffer = generateStringAttributeBuffer(batchTableWithFeatureIds[key]);\n }\n\n attributeBuffers.push(attributeBuffer);\n }\n }\n\n return attributeBuffers;\n}\n/**\n * Return attribute type.\n * @param {String} key\n * @param {Array} attributeStorageInfo\n * @returns {String} attribute type.\n */\nfunction getAttributeType(key, attributeStorageInfo) {\n const attribute = attributeStorageInfo.find((attr) => attr.name === key);\n return attribute.attributeValues.valueType;\n}\n\n/**\n * Convert short integer to attribute arrayBuffer.\n * @param {Array} featureIds\n * @returns {ArrayBuffer} - Buffer with objectId data.\n */\nfunction generateShortIntegerAttributeBuffer(featureIds) {\n const count = new Uint32Array([featureIds.length]);\n const valuesArray = new Uint32Array(featureIds);\n return concatenateArrayBuffers(count.buffer, valuesArray.buffer);\n}\n\n/**\n * Convert double to attribute arrayBuffer.\n * @param {Array} featureIds\n * @returns {ArrayBuffer} - Buffer with objectId data.\n */\nfunction generateDoubleAttributeBuffer(featureIds) {\n const count = new Uint32Array([featureIds.length]);\n const padding = new Uint8Array(4);\n const valuesArray = new Float64Array(featureIds);\n\n return concatenateArrayBuffers(count.buffer, padding.buffer, valuesArray.buffer);\n}\n\n/**\n * Convert batch table attributes to array buffer with batch table data.\n * @param {Array} batchAttributes\n * @returns {ArrayBuffer} - Buffer with batch table data.\n */\nfunction generateStringAttributeBuffer(batchAttributes) {\n const stringCountArray = new Uint32Array([batchAttributes.length]);\n let totalNumberOfBytes = 0;\n const stringSizesArray = new Uint32Array(batchAttributes.length);\n const stringBufferArray = [];\n\n for (let index = 0; index < batchAttributes.length; index++) {\n const currentString = `${String(batchAttributes[index])}\\0`;\n const currentStringBuffer = Buffer.from(currentString);\n const currentStringSize = currentStringBuffer.length;\n totalNumberOfBytes += currentStringSize;\n stringSizesArray[index] = currentStringSize;\n stringBufferArray.push(currentStringBuffer);\n }\n\n const totalBytes = new Uint32Array([totalNumberOfBytes]);\n\n return concatenateArrayBuffers(\n stringCountArray.buffer,\n totalBytes.buffer,\n stringSizesArray.buffer,\n ...stringBufferArray\n );\n}\n\n/**\n * Convert featureIds to BigUint64Array.\n * @param {Array} featureIds\n * @returns {BigUint64Array} - Array of feature ids in BigUint64 format.\n */\nfunction generateBigUint64Array(featureIds) {\n const typedFeatureIds = new BigUint64Array(featureIds.length);\n for (let index = 0; index < featureIds.length; index++) {\n typedFeatureIds[index] = BigInt(featureIds[index]);\n }\n return typedFeatureIds;\n}\n\n/**\n * Generates draco compressed geometry\n * @param {Number} vertexCount\n * @param {Object} convertedAttributes\n * @returns {Promise<object>} - COmpressed geometry.\n */\nasync function generateCompressedGeometry(vertexCount, convertedAttributes, attributes) {\n const {positions, normals, texCoords, colors, featureIds, faceRange} = attributes;\n const indices = new Uint32Array(vertexCount);\n\n for (let index = 0; index < indices.length; index++) {\n indices.set([index], index);\n }\n\n const featureIndices = new Uint32Array(\n convertedAttributes.featureIndices.length ? convertedAttributes.featureIndices : vertexCount\n );\n\n const featureIndex = generateFeatureIndexAttribute(featureIndices, faceRange);\n\n const compressedAttributes = {\n positions,\n normals,\n colors,\n 'feature-index': featureIndex\n };\n\n if (texCoords.length) {\n compressedAttributes.texCoords = texCoords;\n }\n\n const attributesMetadata = {\n 'feature-index': {\n 'i3s-attribute-type': 'feature-index',\n 'i3s-feature-ids': new Int32Array(featureIds)\n }\n };\n\n return new Uint8Array(\n await encode({attributes: compressedAttributes, indices}, DracoWriter, {\n draco: {\n method: 'MESH_SEQUENTIAL_ENCODING',\n attributesMetadata\n }\n })\n );\n}\n\n/**\n * Generates ordered feature indices based on face range\n * @param {Uint32Array} featureIndex\n * @param {Uint32Array} faceRange\n * @returns {Uint32Array}\n */\nfunction generateFeatureIndexAttribute(featureIndex, faceRange) {\n const orderedFeatureIndices = new Uint32Array(featureIndex.length);\n let fillIndex = 0;\n let startIndex = 0;\n\n for (let index = 1; index < faceRange.length; index += 2) {\n const endIndex = (faceRange[index] + 1) * VALUES_PER_VERTEX;\n\n orderedFeatureIndices.fill(fillIndex, startIndex, endIndex);\n\n fillIndex++;\n startIndex = endIndex + 1;\n }\n\n return orderedFeatureIndices;\n}\n"],"file":"geometry-converter.js"}
|
package/dist/es5/pgm-loader.js
CHANGED
|
@@ -7,7 +7,7 @@ exports.PGMLoader = void 0;
|
|
|
7
7
|
|
|
8
8
|
var _pgmParser = require("./lib/pgm-parser");
|
|
9
9
|
|
|
10
|
-
const VERSION = typeof "3.1.0-
|
|
10
|
+
const VERSION = typeof "3.1.0-beta.7" !== 'undefined' ? "3.1.0-beta.7" : 'latest';
|
|
11
11
|
const PGMLoader = {
|
|
12
12
|
name: 'PGM - Netpbm grayscale image format',
|
|
13
13
|
id: 'pgm',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/pgm-loader.ts"],"names":["VERSION","PGMLoader","name","id","module","version","mimeTypes","parse","arrayBuffer","options","Uint8Array","extensions","cubic"],"mappings":";;;;;;;AAMA;;AAFA,MAAMA,OAAO,GAAG,
|
|
1
|
+
{"version":3,"sources":["../../src/pgm-loader.ts"],"names":["VERSION","PGMLoader","name","id","module","version","mimeTypes","parse","arrayBuffer","options","Uint8Array","extensions","cubic"],"mappings":";;;;;;;AAMA;;AAFA,MAAMA,OAAO,GAAG,0BAAuB,WAAvB,oBAAmD,QAAnE;AAOO,MAAMC,SAA2B,GAAG;AACzCC,EAAAA,IAAI,EAAE,qCADmC;AAEzCC,EAAAA,EAAE,EAAE,KAFqC;AAGzCC,EAAAA,MAAM,EAAE,gBAHiC;AAIzCC,EAAAA,OAAO,EAAEL,OAJgC;AAKzCM,EAAAA,SAAS,EAAE,CAAC,0BAAD,CAL8B;AAMzCC,EAAAA,KAAK,EAAE,CAACC,WAAD,EAAcC,OAAd,KAA0B,yBAAS,IAAIC,UAAJ,CAAeF,WAAf,CAAT,EAAsCC,OAAtC,CANQ;AAOzCE,EAAAA,UAAU,EAAE,CAAC,KAAD,CAP6B;AAQzCF,EAAAA,OAAO,EAAE;AAEPG,IAAAA,KAAK,EAAE;AAFA;AARgC,CAApC","sourcesContent":["import type {LoaderWithParser} from '@loaders.gl/loader-utils';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nimport {parsePgm} from './lib/pgm-parser';\n\n/**\n * Loader for PGM - Netpbm grayscale image format\n */\nexport const PGMLoader: LoaderWithParser = {\n name: 'PGM - Netpbm grayscale image format',\n id: 'pgm',\n module: 'tile-converter',\n version: VERSION,\n mimeTypes: ['image/x-portable-graymap'],\n parse: (arrayBuffer, options) => parsePgm(new Uint8Array(arrayBuffer), options),\n extensions: ['pgm'],\n options: {\n // TODO - use pgm namespace\n cubic: false\n }\n};\n"],"file":"pgm-loader.js"}
|
|
@@ -3,8 +3,8 @@ import { GLTFScenegraph, GLTFWriter } from '@loaders.gl/gltf';
|
|
|
3
3
|
import { Tile3DWriter } from '@loaders.gl/3d-tiles';
|
|
4
4
|
import { ImageWriter } from '@loaders.gl/images';
|
|
5
5
|
import { Matrix4, Vector3 } from '@math.gl/core';
|
|
6
|
-
import { convertTextureAtlas } from './texture-atlas';
|
|
7
6
|
import { Ellipsoid } from '@math.gl/geospatial';
|
|
7
|
+
import { convertTextureAtlas } from './texture-atlas';
|
|
8
8
|
const Z_UP_TO_Y_UP_MATRIX = new Matrix4([1, 0, 0, 0, 0, 0, -1, 0, 0, 1, 0, 0, 0, 0, 0, 1]);
|
|
9
9
|
const scratchVector = new Vector3();
|
|
10
10
|
export default class B3dmConverter {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/3d-tiles-converter/helpers/b3dm-converter.js"],"names":["encode","encodeSync","GLTFScenegraph","GLTFWriter","Tile3DWriter","ImageWriter","Matrix4","Vector3","convertTextureAtlas","Ellipsoid","Z_UP_TO_Y_UP_MATRIX","scratchVector","B3dmConverter","convert","i3sTile","attributes","gltf","buildGltf","b3dm","gltfEncoded","Uint8Array","type","featuresLength","_getFeaturesLength","batchTable","material","indices","originalIndices","cartesianOrigin","cartographicOrigin","modelMatrix","content","gltfBuilder","textureIndex","_addI3sTextureToGltf","pbrMaterialInfo","_convertI3sMaterialToGltfMaterial","materialIndex","addMaterial","positions","positionsValue","value","uvRegions","texCoords","_normalizePositions","normals","_checkNormals","_generateSynteticIndices","length","size","meshIndex","addMesh","transformMatrix","_generateTransformMatrix","nodeIndex","addNode","matrix","sceneIndex","addScene","nodeIndices","setDefaultScene","createBinaryChunk","gltfBuffer","texture","header","textureFormat","selectedTexture","pbrMetallicRoughness","baseColorTexture","source","image","mimeType","_deduceMimeTypeFromFormat","imageBuffer","imageIndex","addImage","addTexture","colors","newPositionsValue","Float32Array","index","vertex","subarray","cartesianOriginVector","vertexVector","Array","from","transform","add","WGS84","cartographicToCartesian","subtract","set","translateOriginMatrix","translate","result","multiplyLeft","_generateBatchId","faceRanges","batchIdArraySize","batchId","rangeIndex","currentBatchId","fromIndex","untilPosition","fill","vertexCount","Uint32Array","format","console","warn","isTextureIndexExists","alphaMode","doubleSided","metallicFactor","roughnessFactor","texCoord","baseColorFactor","_setGltfTexture","materialDefinition","emissiveTexture","metallicRoughnessTexture","normalTexture","occlusionTexture","firstKey","Object","keys","find"],"mappings":"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","sourcesContent":["import {encode, encodeSync} from '@loaders.gl/core';\nimport {GLTFScenegraph, GLTFWriter} from '@loaders.gl/gltf';\nimport {Tile3DWriter} from '@loaders.gl/3d-tiles';\nimport {ImageWriter} from '@loaders.gl/images';\nimport {Matrix4, Vector3} from '@math.gl/core';\nimport {convertTextureAtlas} from './texture-atlas';\nimport {Ellipsoid} from '@math.gl/geospatial';\n\nconst Z_UP_TO_Y_UP_MATRIX = new Matrix4([1, 0, 0, 0, 0, 0, -1, 0, 0, 1, 0, 0, 0, 0, 0, 1]);\nconst scratchVector = new Vector3();\n\nexport default class B3dmConverter {\n async convert(i3sTile, attributes = null) {\n this.i3sTile = i3sTile;\n const gltf = await this.buildGltf(i3sTile);\n const b3dm = encodeSync(\n {\n gltfEncoded: new Uint8Array(gltf),\n type: 'b3dm',\n featuresLength: this._getFeaturesLength(attributes),\n batchTable: attributes\n },\n Tile3DWriter\n );\n return b3dm;\n }\n\n async buildGltf(i3sTile) {\n const {\n material,\n attributes,\n indices: originalIndices,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n } = i3sTile.content;\n const gltfBuilder = new GLTFScenegraph();\n\n const textureIndex = await this._addI3sTextureToGltf(i3sTile, gltfBuilder);\n const pbrMaterialInfo = this._convertI3sMaterialToGltfMaterial(material, textureIndex);\n const materialIndex = gltfBuilder.addMaterial(pbrMaterialInfo);\n\n const positions = attributes.positions;\n const positionsValue = positions.value;\n\n if (attributes.uvRegions && attributes.texCoords) {\n attributes.texCoords.value = convertTextureAtlas(\n attributes.texCoords.value,\n attributes.uvRegions.value\n );\n }\n\n attributes.positions.value = this._normalizePositions(\n positionsValue,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n );\n if (attributes.normals && !this._checkNormals(attributes.normals.value)) {\n delete attributes.normals;\n }\n const indices =\n originalIndices || this._generateSynteticIndices(positionsValue.length / positions.size);\n const meshIndex = gltfBuilder.addMesh({\n attributes,\n indices,\n material: materialIndex\n });\n const transformMatrix = this._generateTransformMatrix(cartesianOrigin);\n const nodeIndex = gltfBuilder.addNode({meshIndex, matrix: transformMatrix});\n const sceneIndex = gltfBuilder.addScene({nodeIndices: [nodeIndex]});\n gltfBuilder.setDefaultScene(sceneIndex);\n\n gltfBuilder.createBinaryChunk();\n\n const gltfBuffer = encodeSync(gltfBuilder.gltf, GLTFWriter);\n\n return gltfBuffer;\n }\n\n /**\n * Update gltfBuilder with texture from I3S tile\n * @param {object} i3sTile - Tile3D object\n * @param {GLTFScenegraph} gltfBuilder - gltfScenegraph instance to construct GLTF\n * @returns {Promise<number | null>} - GLTF texture index\n */\n async _addI3sTextureToGltf(i3sTile, gltfBuilder) {\n const {\n content: {texture, material, attributes},\n header: {textureFormat}\n } = i3sTile;\n let textureIndex = null;\n let selectedTexture = texture;\n if (!texture && material) {\n selectedTexture =\n material.pbrMetallicRoughness &&\n material.pbrMetallicRoughness.baseColorTexture &&\n material.pbrMetallicRoughness.baseColorTexture.texture.source.image;\n }\n if (selectedTexture) {\n const mimeType = this._deduceMimeTypeFromFormat(textureFormat);\n const imageBuffer = await encode(selectedTexture, ImageWriter);\n const imageIndex = gltfBuilder.addImage(imageBuffer, mimeType);\n textureIndex = gltfBuilder.addTexture({imageIndex});\n delete attributes.colors;\n }\n return textureIndex;\n }\n\n /**\n * Generate a positions array which is correct for 3DTiles/GLTF format\n * @param {Float64Array} positionsValue - the input geometry positions array\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @param {number[]} cartographicOrigin - the tile center in the cartographic coordinate system\n * @param {number[]} modelMatrix - the model matrix of geometry\n * @returns {Float32Array} - the output geometry positions array\n */\n _normalizePositions(positionsValue, cartesianOrigin, cartographicOrigin, modelMatrix) {\n const newPositionsValue = new Float32Array(positionsValue.length);\n for (let index = 0; index < positionsValue.length; index += 3) {\n const vertex = positionsValue.subarray(index, index + 3);\n const cartesianOriginVector = new Vector3(cartesianOrigin);\n let vertexVector = new Vector3(Array.from(vertex))\n .transform(modelMatrix)\n .add(cartographicOrigin);\n Ellipsoid.WGS84.cartographicToCartesian(vertexVector, scratchVector);\n vertexVector = scratchVector.subtract(cartesianOriginVector);\n newPositionsValue.set(vertexVector, index);\n }\n return newPositionsValue;\n }\n\n /**\n * Generate the transformation matrix for GLTF node:\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-node\n * 1. Create the translate transformation from cartesianOrigin (the positions array stores offsets from this cartesianOrigin)\n * 2. Create the rotation transformation to rotate model from z-up coordinates (I3S specific) to y-up coordinates (GLTF specific)\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @returns {Matrix4} - an array of 16 numbers (4x4 matrix)\n */\n _generateTransformMatrix(cartesianOrigin) {\n const translateOriginMatrix = new Matrix4().translate(cartesianOrigin);\n const result = translateOriginMatrix.multiplyLeft(Z_UP_TO_Y_UP_MATRIX);\n return result;\n }\n\n /**\n * Generate batchId attribute from faceRanges.\n * @param {Uint32Array} faceRanges - the source array\n * @returns {Float32Array} batchId list.\n */\n _generateBatchId(faceRanges) {\n const batchIdArraySize = (faceRanges[faceRanges.length - 1] + 1) * 3;\n const batchId = new Float32Array(batchIdArraySize);\n let rangeIndex = 0;\n let currentBatchId = 0;\n\n for (let index = 0; index < faceRanges.length / 2; index++) {\n const fromIndex = faceRanges[rangeIndex] * 3;\n const untilPosition = (faceRanges[rangeIndex + 1] + 1) * 3;\n\n batchId.fill(currentBatchId, fromIndex, untilPosition);\n rangeIndex += 2;\n currentBatchId += 1;\n }\n return batchId;\n }\n\n /**\n * luma.gl can not work without indices now:\n * https://github.com/visgl/luma.gl/blob/d8cad75b9f8ca3e578cf078ed9d19e619c2ddbc9/modules/experimental/src/gltf/gltf-instantiator.js#L115\n * This method generates syntetic indices array: [0, 1, 2, 3, .... , vertexCount-1]\n * @param {number} vertexCount - vertex count in the geometry\n * @returns {Uint32Array} indices array.\n */\n _generateSynteticIndices(vertexCount) {\n const result = new Uint32Array(vertexCount);\n for (let index = 0; index < vertexCount; index++) {\n result.set([index], index);\n }\n return result;\n }\n\n /**\n * Deduce mime type by format from `textureSetDefinition.formats[0].format`\n * https://github.com/Esri/i3s-spec/blob/master/docs/1.7/textureSetDefinitionFormat.cmn.md\n * @param {string} format - format name\n * @returns {string} mime type.\n */\n _deduceMimeTypeFromFormat(format) {\n switch (format) {\n case 'jpg':\n return 'image/jpeg';\n case 'png':\n return 'image/png';\n default:\n console.warn(`Unexpected texture format in I3S: ${format}`); // eslint-disable-line no-console, no-undef\n return 'image/jpeg';\n }\n }\n\n /**\n * Convert i3s material to GLTF compatible material\n * @param {object} material - i3s material definition\n * @param {number | null} textureIndex - texture index in GLTF\n * @returns {object} GLTF material\n */\n _convertI3sMaterialToGltfMaterial(material, textureIndex) {\n const isTextureIndexExists = textureIndex !== null;\n\n if (!material) {\n material = {\n alphaMode: 'OPAQUE',\n doubleSided: false,\n pbrMetallicRoughness: {\n metallicFactor: 0,\n roughnessFactor: 1\n }\n };\n\n if (isTextureIndexExists) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else {\n material.pbrMetallicRoughness.baseColorFactor = [1, 1, 1, 1];\n }\n\n return material;\n }\n\n if (textureIndex !== null) {\n material = this._setGltfTexture(material, textureIndex);\n }\n\n return material;\n }\n\n /**\n * Set texture properties in material with GLTF textureIndex\n * @param {object} materialDefinition - i3s material definition\n * @param {number} textureIndex - texture index in GLTF\n * @returns {void}\n */\n _setGltfTexture(materialDefinition, textureIndex) {\n const material = {\n ...materialDefinition,\n pbrMetallicRoughness: {...materialDefinition.pbrMetallicRoughness}\n };\n // I3SLoader now support loading only one texture. This elseif sequence will assign this texture to one of\n // properties defined in materialDefinition\n if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.baseColorTexture\n ) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.emissiveTexture) {\n material.emissiveTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.metallicRoughnessTexture\n ) {\n material.pbrMetallicRoughness.metallicRoughnessTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.normalTexture) {\n material.normalTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.occlusionTexture) {\n material.occlusionTexture = {\n index: textureIndex,\n texCoord: 0\n };\n }\n return material;\n }\n\n /*\n * Returns Features length based on attribute array in attribute object.\n * @param {Object} attributes\n * @returns {Number} Features length .\n */\n _getFeaturesLength(attributes) {\n if (!attributes) {\n return 0;\n }\n const firstKey = Object.keys(attributes)[0];\n return firstKey ? attributes[firstKey].length : 0;\n }\n\n /* Checks that normals buffer is correct\n * @param {TypedArray} normals\n * @returns {boolean} true - normals are correct; false - normals are incorrect\n */\n _checkNormals(normals) {\n // If all normals === 0, the resulting tileset is all in black colors on Cesium\n return normals.find((value) => value);\n }\n}\n"],"file":"b3dm-converter.js"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/3d-tiles-converter/helpers/b3dm-converter.js"],"names":["encode","encodeSync","GLTFScenegraph","GLTFWriter","Tile3DWriter","ImageWriter","Matrix4","Vector3","Ellipsoid","convertTextureAtlas","Z_UP_TO_Y_UP_MATRIX","scratchVector","B3dmConverter","convert","i3sTile","attributes","gltf","buildGltf","b3dm","gltfEncoded","Uint8Array","type","featuresLength","_getFeaturesLength","batchTable","material","indices","originalIndices","cartesianOrigin","cartographicOrigin","modelMatrix","content","gltfBuilder","textureIndex","_addI3sTextureToGltf","pbrMaterialInfo","_convertI3sMaterialToGltfMaterial","materialIndex","addMaterial","positions","positionsValue","value","uvRegions","texCoords","_normalizePositions","normals","_checkNormals","_generateSynteticIndices","length","size","meshIndex","addMesh","transformMatrix","_generateTransformMatrix","nodeIndex","addNode","matrix","sceneIndex","addScene","nodeIndices","setDefaultScene","createBinaryChunk","gltfBuffer","texture","header","textureFormat","selectedTexture","pbrMetallicRoughness","baseColorTexture","source","image","mimeType","_deduceMimeTypeFromFormat","imageBuffer","imageIndex","addImage","addTexture","colors","newPositionsValue","Float32Array","index","vertex","subarray","cartesianOriginVector","vertexVector","Array","from","transform","add","WGS84","cartographicToCartesian","subtract","set","translateOriginMatrix","translate","result","multiplyLeft","_generateBatchId","faceRanges","batchIdArraySize","batchId","rangeIndex","currentBatchId","fromIndex","untilPosition","fill","vertexCount","Uint32Array","format","console","warn","isTextureIndexExists","alphaMode","doubleSided","metallicFactor","roughnessFactor","texCoord","baseColorFactor","_setGltfTexture","materialDefinition","emissiveTexture","metallicRoughnessTexture","normalTexture","occlusionTexture","firstKey","Object","keys","find"],"mappings":"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","sourcesContent":["import {encode, encodeSync} from '@loaders.gl/core';\nimport {GLTFScenegraph, GLTFWriter} from '@loaders.gl/gltf';\nimport {Tile3DWriter} from '@loaders.gl/3d-tiles';\nimport {ImageWriter} from '@loaders.gl/images';\nimport {Matrix4, Vector3} from '@math.gl/core';\nimport {Ellipsoid} from '@math.gl/geospatial';\nimport {convertTextureAtlas} from './texture-atlas';\n\nconst Z_UP_TO_Y_UP_MATRIX = new Matrix4([1, 0, 0, 0, 0, 0, -1, 0, 0, 1, 0, 0, 0, 0, 0, 1]);\nconst scratchVector = new Vector3();\n\nexport default class B3dmConverter {\n async convert(i3sTile, attributes = null) {\n this.i3sTile = i3sTile;\n const gltf = await this.buildGltf(i3sTile);\n const b3dm = encodeSync(\n {\n gltfEncoded: new Uint8Array(gltf),\n type: 'b3dm',\n featuresLength: this._getFeaturesLength(attributes),\n batchTable: attributes\n },\n Tile3DWriter\n );\n return b3dm;\n }\n\n async buildGltf(i3sTile) {\n const {\n material,\n attributes,\n indices: originalIndices,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n } = i3sTile.content;\n const gltfBuilder = new GLTFScenegraph();\n\n const textureIndex = await this._addI3sTextureToGltf(i3sTile, gltfBuilder);\n const pbrMaterialInfo = this._convertI3sMaterialToGltfMaterial(material, textureIndex);\n const materialIndex = gltfBuilder.addMaterial(pbrMaterialInfo);\n\n const positions = attributes.positions;\n const positionsValue = positions.value;\n\n if (attributes.uvRegions && attributes.texCoords) {\n attributes.texCoords.value = convertTextureAtlas(\n attributes.texCoords.value,\n attributes.uvRegions.value\n );\n }\n\n attributes.positions.value = this._normalizePositions(\n positionsValue,\n cartesianOrigin,\n cartographicOrigin,\n modelMatrix\n );\n if (attributes.normals && !this._checkNormals(attributes.normals.value)) {\n delete attributes.normals;\n }\n const indices =\n originalIndices || this._generateSynteticIndices(positionsValue.length / positions.size);\n const meshIndex = gltfBuilder.addMesh({\n attributes,\n indices,\n material: materialIndex\n });\n const transformMatrix = this._generateTransformMatrix(cartesianOrigin);\n const nodeIndex = gltfBuilder.addNode({meshIndex, matrix: transformMatrix});\n const sceneIndex = gltfBuilder.addScene({nodeIndices: [nodeIndex]});\n gltfBuilder.setDefaultScene(sceneIndex);\n\n gltfBuilder.createBinaryChunk();\n\n const gltfBuffer = encodeSync(gltfBuilder.gltf, GLTFWriter);\n\n return gltfBuffer;\n }\n\n /**\n * Update gltfBuilder with texture from I3S tile\n * @param {object} i3sTile - Tile3D object\n * @param {GLTFScenegraph} gltfBuilder - gltfScenegraph instance to construct GLTF\n * @returns {Promise<number | null>} - GLTF texture index\n */\n async _addI3sTextureToGltf(i3sTile, gltfBuilder) {\n const {\n content: {texture, material, attributes},\n header: {textureFormat}\n } = i3sTile;\n let textureIndex = null;\n let selectedTexture = texture;\n if (!texture && material) {\n selectedTexture =\n material.pbrMetallicRoughness &&\n material.pbrMetallicRoughness.baseColorTexture &&\n material.pbrMetallicRoughness.baseColorTexture.texture.source.image;\n }\n if (selectedTexture) {\n const mimeType = this._deduceMimeTypeFromFormat(textureFormat);\n const imageBuffer = await encode(selectedTexture, ImageWriter);\n const imageIndex = gltfBuilder.addImage(imageBuffer, mimeType);\n textureIndex = gltfBuilder.addTexture({imageIndex});\n delete attributes.colors;\n }\n return textureIndex;\n }\n\n /**\n * Generate a positions array which is correct for 3DTiles/GLTF format\n * @param {Float64Array} positionsValue - the input geometry positions array\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @param {number[]} cartographicOrigin - the tile center in the cartographic coordinate system\n * @param {number[]} modelMatrix - the model matrix of geometry\n * @returns {Float32Array} - the output geometry positions array\n */\n _normalizePositions(positionsValue, cartesianOrigin, cartographicOrigin, modelMatrix) {\n const newPositionsValue = new Float32Array(positionsValue.length);\n for (let index = 0; index < positionsValue.length; index += 3) {\n const vertex = positionsValue.subarray(index, index + 3);\n const cartesianOriginVector = new Vector3(cartesianOrigin);\n let vertexVector = new Vector3(Array.from(vertex))\n .transform(modelMatrix)\n .add(cartographicOrigin);\n Ellipsoid.WGS84.cartographicToCartesian(vertexVector, scratchVector);\n vertexVector = scratchVector.subtract(cartesianOriginVector);\n newPositionsValue.set(vertexVector, index);\n }\n return newPositionsValue;\n }\n\n /**\n * Generate the transformation matrix for GLTF node:\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-node\n * 1. Create the translate transformation from cartesianOrigin (the positions array stores offsets from this cartesianOrigin)\n * 2. Create the rotation transformation to rotate model from z-up coordinates (I3S specific) to y-up coordinates (GLTF specific)\n * @param {number[]} cartesianOrigin - the tile center in the cartesian coordinate system\n * @returns {Matrix4} - an array of 16 numbers (4x4 matrix)\n */\n _generateTransformMatrix(cartesianOrigin) {\n const translateOriginMatrix = new Matrix4().translate(cartesianOrigin);\n const result = translateOriginMatrix.multiplyLeft(Z_UP_TO_Y_UP_MATRIX);\n return result;\n }\n\n /**\n * Generate batchId attribute from faceRanges.\n * @param {Uint32Array} faceRanges - the source array\n * @returns {Float32Array} batchId list.\n */\n _generateBatchId(faceRanges) {\n const batchIdArraySize = (faceRanges[faceRanges.length - 1] + 1) * 3;\n const batchId = new Float32Array(batchIdArraySize);\n let rangeIndex = 0;\n let currentBatchId = 0;\n\n for (let index = 0; index < faceRanges.length / 2; index++) {\n const fromIndex = faceRanges[rangeIndex] * 3;\n const untilPosition = (faceRanges[rangeIndex + 1] + 1) * 3;\n\n batchId.fill(currentBatchId, fromIndex, untilPosition);\n rangeIndex += 2;\n currentBatchId += 1;\n }\n return batchId;\n }\n\n /**\n * luma.gl can not work without indices now:\n * https://github.com/visgl/luma.gl/blob/d8cad75b9f8ca3e578cf078ed9d19e619c2ddbc9/modules/experimental/src/gltf/gltf-instantiator.js#L115\n * This method generates syntetic indices array: [0, 1, 2, 3, .... , vertexCount-1]\n * @param {number} vertexCount - vertex count in the geometry\n * @returns {Uint32Array} indices array.\n */\n _generateSynteticIndices(vertexCount) {\n const result = new Uint32Array(vertexCount);\n for (let index = 0; index < vertexCount; index++) {\n result.set([index], index);\n }\n return result;\n }\n\n /**\n * Deduce mime type by format from `textureSetDefinition.formats[0].format`\n * https://github.com/Esri/i3s-spec/blob/master/docs/1.7/textureSetDefinitionFormat.cmn.md\n * @param {string} format - format name\n * @returns {string} mime type.\n */\n _deduceMimeTypeFromFormat(format) {\n switch (format) {\n case 'jpg':\n return 'image/jpeg';\n case 'png':\n return 'image/png';\n default:\n console.warn(`Unexpected texture format in I3S: ${format}`); // eslint-disable-line no-console, no-undef\n return 'image/jpeg';\n }\n }\n\n /**\n * Convert i3s material to GLTF compatible material\n * @param {object} material - i3s material definition\n * @param {number | null} textureIndex - texture index in GLTF\n * @returns {object} GLTF material\n */\n _convertI3sMaterialToGltfMaterial(material, textureIndex) {\n const isTextureIndexExists = textureIndex !== null;\n\n if (!material) {\n material = {\n alphaMode: 'OPAQUE',\n doubleSided: false,\n pbrMetallicRoughness: {\n metallicFactor: 0,\n roughnessFactor: 1\n }\n };\n\n if (isTextureIndexExists) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else {\n material.pbrMetallicRoughness.baseColorFactor = [1, 1, 1, 1];\n }\n\n return material;\n }\n\n if (textureIndex !== null) {\n material = this._setGltfTexture(material, textureIndex);\n }\n\n return material;\n }\n\n /**\n * Set texture properties in material with GLTF textureIndex\n * @param {object} materialDefinition - i3s material definition\n * @param {number} textureIndex - texture index in GLTF\n * @returns {void}\n */\n _setGltfTexture(materialDefinition, textureIndex) {\n const material = {\n ...materialDefinition,\n pbrMetallicRoughness: {...materialDefinition.pbrMetallicRoughness}\n };\n // I3SLoader now support loading only one texture. This elseif sequence will assign this texture to one of\n // properties defined in materialDefinition\n if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.baseColorTexture\n ) {\n material.pbrMetallicRoughness.baseColorTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.emissiveTexture) {\n material.emissiveTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (\n materialDefinition.pbrMetallicRoughness &&\n materialDefinition.pbrMetallicRoughness.metallicRoughnessTexture\n ) {\n material.pbrMetallicRoughness.metallicRoughnessTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.normalTexture) {\n material.normalTexture = {\n index: textureIndex,\n texCoord: 0\n };\n } else if (materialDefinition.occlusionTexture) {\n material.occlusionTexture = {\n index: textureIndex,\n texCoord: 0\n };\n }\n return material;\n }\n\n /*\n * Returns Features length based on attribute array in attribute object.\n * @param {Object} attributes\n * @returns {Number} Features length .\n */\n _getFeaturesLength(attributes) {\n if (!attributes) {\n return 0;\n }\n const firstKey = Object.keys(attributes)[0];\n return firstKey ? attributes[firstKey].length : 0;\n }\n\n /* Checks that normals buffer is correct\n * @param {TypedArray} normals\n * @returns {boolean} true - normals are correct; false - normals are incorrect\n */\n _checkNormals(normals) {\n // If all normals === 0, the resulting tileset is all in black colors on Cesium\n return normals.find((value) => value);\n }\n}\n"],"file":"b3dm-converter.js"}
|