@loaders.gl/tile-converter 3.3.0-alpha.5 → 3.3.0-alpha.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/3d-tiles-attributes-worker.js +2 -3
- package/dist/3d-tiles-attributes-worker.js.map +3 -3
- package/dist/converter-cli.js +15 -2
- package/dist/converter.min.js +23 -20
- package/dist/dist.min.js +38236 -46911
- package/dist/es5/3d-tiles-attributes-worker.js +3 -6
- package/dist/es5/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js +12 -111
- package/dist/es5/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js +32 -72
- package/dist/es5/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/es5/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js +0 -8
- package/dist/es5/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js.map +1 -1
- package/dist/es5/3d-tiles-converter/helpers/texture-atlas.js +0 -5
- package/dist/es5/3d-tiles-converter/helpers/texture-atlas.js.map +1 -1
- package/dist/es5/3d-tiles-converter/json-templates/tileset.js +0 -6
- package/dist/es5/3d-tiles-converter/json-templates/tileset.js.map +1 -1
- package/dist/es5/bundle.js +0 -1
- package/dist/es5/bundle.js.map +1 -1
- package/dist/es5/constants.js.map +1 -1
- package/dist/es5/converter-cli.js +11 -56
- package/dist/es5/converter-cli.js.map +1 -1
- package/dist/es5/deps-installer/deps-installer.js +5 -35
- package/dist/es5/deps-installer/deps-installer.js.map +1 -1
- package/dist/es5/i3s-attributes-worker.js +3 -6
- package/dist/es5/i3s-attributes-worker.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js +2 -28
- package/dist/es5/i3s-converter/helpers/batch-ids-extensions.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/coordinate-converter.js +8 -25
- package/dist/es5/i3s-converter/helpers/coordinate-converter.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/create-scene-server-path.js +0 -11
- package/dist/es5/i3s-converter/helpers/create-scene-server-path.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/feature-attributes.js +5 -34
- package/dist/es5/i3s-converter/helpers/feature-attributes.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/geometry-attributes.js +13 -45
- package/dist/es5/i3s-converter/helpers/geometry-attributes.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/geometry-converter.js +26 -221
- package/dist/es5/i3s-converter/helpers/geometry-converter.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/gltf-attributes.js +2 -16
- package/dist/es5/i3s-converter/helpers/gltf-attributes.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/node-debug.js +4 -23
- package/dist/es5/i3s-converter/helpers/node-debug.js.map +1 -1
- package/dist/es5/i3s-converter/helpers/node-pages.js +50 -86
- package/dist/es5/i3s-converter/helpers/node-pages.js.map +1 -1
- package/dist/es5/i3s-converter/i3s-converter.js +69 -384
- package/dist/es5/i3s-converter/i3s-converter.js.map +1 -1
- package/dist/es5/i3s-converter/json-templates/layers.js +1 -15
- package/dist/es5/i3s-converter/json-templates/layers.js.map +1 -1
- package/dist/es5/i3s-converter/json-templates/metadata.js +0 -2
- package/dist/es5/i3s-converter/json-templates/metadata.js.map +1 -1
- package/dist/es5/i3s-converter/json-templates/node.js +2 -12
- package/dist/es5/i3s-converter/json-templates/node.js.map +1 -1
- package/dist/es5/i3s-converter/json-templates/scene-server.js +0 -2
- package/dist/es5/i3s-converter/json-templates/scene-server.js.map +1 -1
- package/dist/es5/i3s-converter/json-templates/shared-resources.js +6 -29
- package/dist/es5/i3s-converter/json-templates/shared-resources.js.map +1 -1
- package/dist/es5/i3s-converter/json-templates/store.js.map +1 -1
- package/dist/es5/i3s-converter/types.js.map +1 -1
- package/dist/es5/i3s-server/app.js +0 -5
- package/dist/es5/i3s-server/app.js.map +1 -1
- package/dist/es5/i3s-server/controllers/index-controller.js +0 -16
- package/dist/es5/i3s-server/controllers/index-controller.js.map +1 -1
- package/dist/es5/i3s-server/routes/index.js +1 -10
- package/dist/es5/i3s-server/routes/index.js.map +1 -1
- package/dist/es5/index.js +0 -3
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/lib/utils/compress-util.js +19 -74
- package/dist/es5/lib/utils/compress-util.js.map +1 -1
- package/dist/es5/lib/utils/file-utils.js +10 -38
- package/dist/es5/lib/utils/file-utils.js.map +1 -1
- package/dist/es5/lib/utils/lod-conversion-utils.js +0 -7
- package/dist/es5/lib/utils/lod-conversion-utils.js.map +1 -1
- package/dist/es5/lib/utils/queue.js +0 -14
- package/dist/es5/lib/utils/queue.js.map +1 -1
- package/dist/es5/lib/utils/statistic-utills.js +1 -46
- package/dist/es5/lib/utils/statistic-utills.js.map +1 -1
- package/dist/es5/lib/utils/write-queue.js +0 -52
- package/dist/es5/lib/utils/write-queue.js.map +1 -1
- package/dist/es5/pgm-loader.js +1 -8
- package/dist/es5/pgm-loader.js.map +1 -1
- package/dist/es5/workers/3d-tiles-attributes-worker.js +1 -8
- package/dist/es5/workers/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/es5/workers/i3s-attributes-worker.js +1 -9
- package/dist/es5/workers/i3s-attributes-worker.js.map +1 -1
- package/dist/esm/3d-tiles-attributes-worker.js +3 -1
- package/dist/esm/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js +8 -40
- package/dist/esm/3d-tiles-converter/3d-tiles-converter.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js +7 -38
- package/dist/esm/3d-tiles-converter/helpers/b3dm-converter.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js +1 -0
- package/dist/esm/3d-tiles-converter/helpers/i3s-obb-to-3d-tiles-obb.js.map +1 -1
- package/dist/esm/3d-tiles-converter/helpers/texture-atlas.js +1 -4
- package/dist/esm/3d-tiles-converter/helpers/texture-atlas.js.map +1 -1
- package/dist/esm/3d-tiles-converter/json-templates/tileset.js +0 -3
- package/dist/esm/3d-tiles-converter/json-templates/tileset.js.map +1 -1
- package/dist/esm/bundle.js +1 -1
- package/dist/esm/bundle.js.map +1 -1
- package/dist/esm/constants.js.map +1 -1
- package/dist/esm/converter-cli.js +12 -41
- package/dist/esm/converter-cli.js.map +1 -1
- package/dist/esm/deps-installer/deps-installer.js +6 -7
- package/dist/esm/deps-installer/deps-installer.js.map +1 -1
- package/dist/esm/i3s-attributes-worker.js +3 -1
- package/dist/esm/i3s-attributes-worker.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js +4 -23
- package/dist/esm/i3s-converter/helpers/batch-ids-extensions.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/coordinate-converter.js +11 -12
- package/dist/esm/i3s-converter/helpers/coordinate-converter.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/create-scene-server-path.js +1 -0
- package/dist/esm/i3s-converter/helpers/create-scene-server-path.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/feature-attributes.js +6 -20
- package/dist/esm/i3s-converter/helpers/feature-attributes.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/geometry-attributes.js +3 -22
- package/dist/esm/i3s-converter/helpers/geometry-attributes.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/geometry-converter.js +28 -139
- package/dist/esm/i3s-converter/helpers/geometry-converter.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/gltf-attributes.js +7 -12
- package/dist/esm/i3s-converter/helpers/gltf-attributes.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/node-debug.js +3 -13
- package/dist/esm/i3s-converter/helpers/node-debug.js.map +1 -1
- package/dist/esm/i3s-converter/helpers/node-pages.js +2 -21
- package/dist/esm/i3s-converter/helpers/node-pages.js.map +1 -1
- package/dist/esm/i3s-converter/i3s-converter.js +59 -144
- package/dist/esm/i3s-converter/i3s-converter.js.map +1 -1
- package/dist/esm/i3s-converter/json-templates/layers.js +1 -11
- package/dist/esm/i3s-converter/json-templates/layers.js.map +1 -1
- package/dist/esm/i3s-converter/json-templates/metadata.js.map +1 -1
- package/dist/esm/i3s-converter/json-templates/node.js +0 -4
- package/dist/esm/i3s-converter/json-templates/node.js.map +1 -1
- package/dist/esm/i3s-converter/json-templates/scene-server.js.map +1 -1
- package/dist/esm/i3s-converter/json-templates/shared-resources.js +0 -12
- package/dist/esm/i3s-converter/json-templates/shared-resources.js.map +1 -1
- package/dist/esm/i3s-converter/json-templates/store.js.map +1 -1
- package/dist/esm/i3s-converter/types.js.map +1 -1
- package/dist/esm/i3s-server/app.js +0 -5
- package/dist/esm/i3s-server/app.js.map +1 -1
- package/dist/esm/i3s-server/controllers/index-controller.js +0 -5
- package/dist/esm/i3s-server/controllers/index-controller.js.map +1 -1
- package/dist/esm/i3s-server/routes/index.js +0 -3
- package/dist/esm/i3s-server/routes/index.js.map +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/utils/compress-util.js +19 -12
- package/dist/esm/lib/utils/compress-util.js.map +1 -1
- package/dist/esm/lib/utils/file-utils.js +10 -8
- package/dist/esm/lib/utils/file-utils.js.map +1 -1
- package/dist/esm/lib/utils/lod-conversion-utils.js +2 -6
- package/dist/esm/lib/utils/lod-conversion-utils.js.map +1 -1
- package/dist/esm/lib/utils/queue.js +0 -4
- package/dist/esm/lib/utils/queue.js.map +1 -1
- package/dist/esm/lib/utils/statistic-utills.js +0 -11
- package/dist/esm/lib/utils/statistic-utills.js.map +1 -1
- package/dist/esm/lib/utils/write-queue.js +5 -23
- package/dist/esm/lib/utils/write-queue.js.map +1 -1
- package/dist/esm/pgm-loader.js +3 -1
- package/dist/esm/pgm-loader.js.map +1 -1
- package/dist/esm/workers/3d-tiles-attributes-worker.js +4 -1
- package/dist/esm/workers/3d-tiles-attributes-worker.js.map +1 -1
- package/dist/esm/workers/i3s-attributes-worker.js +4 -1
- package/dist/esm/workers/i3s-attributes-worker.js.map +1 -1
- package/dist/i3s-attributes-worker.js +2 -3
- package/dist/i3s-attributes-worker.js.map +3 -3
- package/dist/i3s-converter/helpers/coordinate-converter.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/coordinate-converter.js +8 -6
- package/dist/i3s-converter/helpers/geometry-converter.d.ts.map +1 -1
- package/dist/i3s-converter/helpers/geometry-converter.js +2 -0
- package/dist/i3s-converter/i3s-converter.d.ts.map +1 -1
- package/dist/i3s-converter/i3s-converter.js +14 -8
- package/dist/pgm-loader.d.ts.map +1 -1
- package/dist/pgm-loader.js +2 -1
- package/package.json +15 -15
- package/src/converter-cli.ts +16 -2
- package/src/i3s-converter/helpers/coordinate-converter.ts +8 -6
- package/src/i3s-converter/helpers/geometry-converter.ts +2 -0
- package/src/i3s-converter/i3s-converter.ts +17 -7
- package/src/pgm-loader.ts +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/i3s-converter/helpers/feature-attributes.ts"],"names":["flattenPropertyTableByFeatureIds","featureIds","propertyTable","resultPropertyTable","propertyName","properties","getPropertiesByFeatureIds","resultProperties","featureId","property","push","checkPropertiesLength","needFlatten","Object","values","attribute","length","STRING_TYPE","SHORT_INT_TYPE","DOUBLE_TYPE","OBJECT_ID_TYPE","getAttributeType","key","Number","isInteger","createdStorageAttribute","attributeIndex","attributeType","storageAttribute","name","ordering","header","valueType","attributeValues","valuesPerElement","setupIdAttribute","setupStringAttribute","setupDoubleAttribute","getFieldAttributeType","createFieldAttribute","fieldAttributeType","type","alias","createPopupInfo","title","mediaInfos","fieldInfos","popupElements","expressionInfos","fieldName","visible","isEditable","label","unshift","encoding","attributeByteCounts"],"mappings":"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","sourcesContent":["import type {FeatureTableJson} from '@loaders.gl/3d-tiles';\nimport {\n Attribute,\n AttributeStorageInfo,\n ESRIField,\n Field,\n FieldInfo,\n PopupInfo\n} from '@loaders.gl/i3s';\n\n/**\n * Takes attributes from property table based on featureIds.\n * If there is no property value for particular featureId (index) the property will be null.\n * Example:\n * Initial data:\n * OBJECTID: [0, 1, 5]\n * component: ['Windows', 'Frames', 'Wall', 'Roof', 'Skylight']\n * Result:\n * OBJECTID: [0, 1, 5]\n * component: ['Windows', 'Frames', 'null']\n * @param featureIds\n * @param propertyTable\n */\nexport function flattenPropertyTableByFeatureIds(\n featureIds: number[],\n propertyTable: FeatureTableJson\n): FeatureTableJson {\n const resultPropertyTable: FeatureTableJson = {};\n for (const propertyName in propertyTable) {\n const properties = propertyTable[propertyName];\n resultPropertyTable[propertyName] = getPropertiesByFeatureIds(properties, featureIds);\n }\n\n return resultPropertyTable;\n}\n\n/**\n * Getting properties by featureId index\n * @param properties\n * @param featureIds\n */\nfunction getPropertiesByFeatureIds(properties: any[], featureIds: number[]): any[] {\n const resultProperties: any = [];\n\n for (const featureId of featureIds) {\n const property = properties[featureId] || null;\n resultProperties.push(property);\n }\n\n return resultProperties;\n}\n\n/**\n * Check that all attributes in propertyTable have the same length as FeatureIds.\n * If there are differencies between lengths we should flatten property table based on exiesting featureIds.\n * @param featureIds\n * @param propertyTable\n * @returns\n */\nexport function checkPropertiesLength(\n featureIds: number[],\n propertyTable: FeatureTableJson\n): boolean {\n let needFlatten = false;\n\n for (const attribute of Object.values(propertyTable)) {\n if (featureIds.length !== attribute.length) {\n needFlatten = true;\n }\n }\n\n return needFlatten;\n}\n\n/** String data type name for feature attributes */\nconst STRING_TYPE = 'string';\n/** Integer data type name for feature attributes */\nconst SHORT_INT_TYPE = 'Int32';\n/** Double data type name for feature attributes */\nconst DOUBLE_TYPE = 'double';\n/** Type of attribute that is linked with feature ids */\nconst OBJECT_ID_TYPE = 'OBJECTID';\n/**\n * Get the attribute type for attributeStorageInfo https://github.com/Esri/i3s-spec/blob/master/docs/1.7/attributeStorageInfo.cmn.md\n * @param key - attribute's key\n * @param attribute - attribute's type in propertyTable\n */\nexport function getAttributeType(key: string, attribute: string): string {\n if (key === OBJECT_ID_TYPE) {\n return OBJECT_ID_TYPE;\n }\n if (typeof attribute === STRING_TYPE) {\n return STRING_TYPE;\n } else if (typeof attribute === 'number') {\n return Number.isInteger(attribute) ? SHORT_INT_TYPE : DOUBLE_TYPE;\n }\n return STRING_TYPE;\n}\n\n/**\n * Generate storage attribute for map segmentation.\n * @param attributeIndex - order index of attribute (f_0, f_1 ...).\n * @param key - attribute key from propertyTable.\n * @param attributeType - attribute type.\n * @return Updated storageAttribute.\n */\nexport function createdStorageAttribute(\n attributeIndex: number,\n key: string,\n attributeType: Attribute\n): AttributeStorageInfo {\n const storageAttribute = {\n key: `f_${attributeIndex}`,\n name: key,\n ordering: ['attributeValues'],\n header: [{property: 'count', valueType: 'UInt32'}],\n attributeValues: {valueType: 'Int32', valuesPerElement: 1}\n };\n\n switch (attributeType) {\n case OBJECT_ID_TYPE:\n setupIdAttribute(storageAttribute);\n break;\n case STRING_TYPE:\n setupStringAttribute(storageAttribute);\n break;\n case DOUBLE_TYPE:\n setupDoubleAttribute(storageAttribute);\n break;\n case SHORT_INT_TYPE:\n break;\n default:\n setupStringAttribute(storageAttribute);\n }\n\n return storageAttribute;\n}\n\n/**\n * Find and return attribute type based on key form propertyTable.\n * @param attributeType\n */\nexport function getFieldAttributeType(attributeType: Attribute): ESRIField {\n switch (attributeType) {\n case OBJECT_ID_TYPE:\n return 'esriFieldTypeOID';\n case STRING_TYPE:\n return 'esriFieldTypeString';\n case SHORT_INT_TYPE:\n return 'esriFieldTypeInteger';\n case DOUBLE_TYPE:\n return 'esriFieldTypeDouble';\n default:\n return 'esriFieldTypeString';\n }\n}\n\n/**\n * Setup field attribute for map segmentation.\n * @param key - attribute for map segmentation.\n * @param fieldAttributeType - esri attribute type ('esriFieldTypeString' or 'esriFieldTypeOID').\n */\nexport function createFieldAttribute(key: string, fieldAttributeType: ESRIField): Field {\n return {\n name: key,\n type: fieldAttributeType,\n alias: key\n };\n}\n\n/**\n * Generate popup info to show metadata on the map.\n * @param propertyTable - table data with OBJECTID.\n * @return data for correct rendering of popup.\n */\nexport function createPopupInfo(propertyTable: FeatureTableJson): PopupInfo {\n const title = '{OBJECTID}';\n const mediaInfos = [];\n const fieldInfos: FieldInfo[] = [];\n const popupElements: {\n fieldInfos: FieldInfo[];\n type: string;\n }[] = [];\n const expressionInfos = [];\n\n for (const key in propertyTable) {\n fieldInfos.push({\n fieldName: key,\n visible: true,\n isEditable: false,\n label: key\n });\n }\n popupElements.push({\n fieldInfos,\n type: 'fields'\n });\n\n return {\n title,\n mediaInfos,\n popupElements,\n fieldInfos,\n expressionInfos\n };\n}\n\n/**\n * Setup storage attribute as string.\n * @param storageAttribute - attribute for map segmentation.\n */\nfunction setupStringAttribute(storageAttribute: AttributeStorageInfo): void {\n // @ts-expect-error\n storageAttribute.ordering.unshift('attributeByteCounts');\n storageAttribute.header.push({property: 'attributeValuesByteCount', valueType: 'UInt32'});\n storageAttribute.attributeValues = {\n valueType: 'String',\n encoding: 'UTF-8',\n valuesPerElement: 1\n };\n storageAttribute.attributeByteCounts = {\n valueType: 'UInt32',\n valuesPerElement: 1\n };\n}\n\n/**\n * Setup Id attribute for map segmentation.\n * @param storageAttribute - attribute for map segmentation .\n */\nfunction setupIdAttribute(storageAttribute: AttributeStorageInfo): void {\n storageAttribute.attributeValues = {\n valueType: 'Oid32',\n valuesPerElement: 1\n };\n}\n\n/**\n * Setup double attribute for map segmentation.\n * @param storageAttribute - attribute for map segmentation .\n */\nfunction setupDoubleAttribute(storageAttribute: AttributeStorageInfo): void {\n storageAttribute.attributeValues = {\n valueType: 'Float64',\n valuesPerElement: 1\n };\n}\n"],"file":"feature-attributes.js"}
|
|
1
|
+
{"version":3,"file":"feature-attributes.js","names":["flattenPropertyTableByFeatureIds","featureIds","propertyTable","resultPropertyTable","propertyName","properties","getPropertiesByFeatureIds","resultProperties","featureId","property","push","checkPropertiesLength","needFlatten","Object","values","attribute","length","STRING_TYPE","SHORT_INT_TYPE","DOUBLE_TYPE","OBJECT_ID_TYPE","getAttributeType","key","Number","isInteger","createdStorageAttribute","attributeIndex","attributeType","storageAttribute","name","ordering","header","valueType","attributeValues","valuesPerElement","setupIdAttribute","setupStringAttribute","setupDoubleAttribute","getFieldAttributeType","createFieldAttribute","fieldAttributeType","type","alias","createPopupInfo","title","mediaInfos","fieldInfos","popupElements","expressionInfos","fieldName","visible","isEditable","label","unshift","encoding","attributeByteCounts"],"sources":["../../../../src/i3s-converter/helpers/feature-attributes.ts"],"sourcesContent":["import type {FeatureTableJson} from '@loaders.gl/3d-tiles';\nimport {\n Attribute,\n AttributeStorageInfo,\n ESRIField,\n Field,\n FieldInfo,\n PopupInfo\n} from '@loaders.gl/i3s';\n\n/**\n * Takes attributes from property table based on featureIds.\n * If there is no property value for particular featureId (index) the property will be null.\n * Example:\n * Initial data:\n * OBJECTID: [0, 1, 5]\n * component: ['Windows', 'Frames', 'Wall', 'Roof', 'Skylight']\n * Result:\n * OBJECTID: [0, 1, 5]\n * component: ['Windows', 'Frames', 'null']\n * @param featureIds\n * @param propertyTable\n */\nexport function flattenPropertyTableByFeatureIds(\n featureIds: number[],\n propertyTable: FeatureTableJson\n): FeatureTableJson {\n const resultPropertyTable: FeatureTableJson = {};\n for (const propertyName in propertyTable) {\n const properties = propertyTable[propertyName];\n resultPropertyTable[propertyName] = getPropertiesByFeatureIds(properties, featureIds);\n }\n\n return resultPropertyTable;\n}\n\n/**\n * Getting properties by featureId index\n * @param properties\n * @param featureIds\n */\nfunction getPropertiesByFeatureIds(properties: any[], featureIds: number[]): any[] {\n const resultProperties: any = [];\n\n for (const featureId of featureIds) {\n const property = properties[featureId] || null;\n resultProperties.push(property);\n }\n\n return resultProperties;\n}\n\n/**\n * Check that all attributes in propertyTable have the same length as FeatureIds.\n * If there are differencies between lengths we should flatten property table based on exiesting featureIds.\n * @param featureIds\n * @param propertyTable\n * @returns\n */\nexport function checkPropertiesLength(\n featureIds: number[],\n propertyTable: FeatureTableJson\n): boolean {\n let needFlatten = false;\n\n for (const attribute of Object.values(propertyTable)) {\n if (featureIds.length !== attribute.length) {\n needFlatten = true;\n }\n }\n\n return needFlatten;\n}\n\n/** String data type name for feature attributes */\nconst STRING_TYPE = 'string';\n/** Integer data type name for feature attributes */\nconst SHORT_INT_TYPE = 'Int32';\n/** Double data type name for feature attributes */\nconst DOUBLE_TYPE = 'double';\n/** Type of attribute that is linked with feature ids */\nconst OBJECT_ID_TYPE = 'OBJECTID';\n/**\n * Get the attribute type for attributeStorageInfo https://github.com/Esri/i3s-spec/blob/master/docs/1.7/attributeStorageInfo.cmn.md\n * @param key - attribute's key\n * @param attribute - attribute's type in propertyTable\n */\nexport function getAttributeType(key: string, attribute: string): string {\n if (key === OBJECT_ID_TYPE) {\n return OBJECT_ID_TYPE;\n }\n if (typeof attribute === STRING_TYPE) {\n return STRING_TYPE;\n } else if (typeof attribute === 'number') {\n return Number.isInteger(attribute) ? SHORT_INT_TYPE : DOUBLE_TYPE;\n }\n return STRING_TYPE;\n}\n\n/**\n * Generate storage attribute for map segmentation.\n * @param attributeIndex - order index of attribute (f_0, f_1 ...).\n * @param key - attribute key from propertyTable.\n * @param attributeType - attribute type.\n * @return Updated storageAttribute.\n */\nexport function createdStorageAttribute(\n attributeIndex: number,\n key: string,\n attributeType: Attribute\n): AttributeStorageInfo {\n const storageAttribute = {\n key: `f_${attributeIndex}`,\n name: key,\n ordering: ['attributeValues'],\n header: [{property: 'count', valueType: 'UInt32'}],\n attributeValues: {valueType: 'Int32', valuesPerElement: 1}\n };\n\n switch (attributeType) {\n case OBJECT_ID_TYPE:\n setupIdAttribute(storageAttribute);\n break;\n case STRING_TYPE:\n setupStringAttribute(storageAttribute);\n break;\n case DOUBLE_TYPE:\n setupDoubleAttribute(storageAttribute);\n break;\n case SHORT_INT_TYPE:\n break;\n default:\n setupStringAttribute(storageAttribute);\n }\n\n return storageAttribute;\n}\n\n/**\n * Find and return attribute type based on key form propertyTable.\n * @param attributeType\n */\nexport function getFieldAttributeType(attributeType: Attribute): ESRIField {\n switch (attributeType) {\n case OBJECT_ID_TYPE:\n return 'esriFieldTypeOID';\n case STRING_TYPE:\n return 'esriFieldTypeString';\n case SHORT_INT_TYPE:\n return 'esriFieldTypeInteger';\n case DOUBLE_TYPE:\n return 'esriFieldTypeDouble';\n default:\n return 'esriFieldTypeString';\n }\n}\n\n/**\n * Setup field attribute for map segmentation.\n * @param key - attribute for map segmentation.\n * @param fieldAttributeType - esri attribute type ('esriFieldTypeString' or 'esriFieldTypeOID').\n */\nexport function createFieldAttribute(key: string, fieldAttributeType: ESRIField): Field {\n return {\n name: key,\n type: fieldAttributeType,\n alias: key\n };\n}\n\n/**\n * Generate popup info to show metadata on the map.\n * @param propertyTable - table data with OBJECTID.\n * @return data for correct rendering of popup.\n */\nexport function createPopupInfo(propertyTable: FeatureTableJson): PopupInfo {\n const title = '{OBJECTID}';\n const mediaInfos = [];\n const fieldInfos: FieldInfo[] = [];\n const popupElements: {\n fieldInfos: FieldInfo[];\n type: string;\n }[] = [];\n const expressionInfos = [];\n\n for (const key in propertyTable) {\n fieldInfos.push({\n fieldName: key,\n visible: true,\n isEditable: false,\n label: key\n });\n }\n popupElements.push({\n fieldInfos,\n type: 'fields'\n });\n\n return {\n title,\n mediaInfos,\n popupElements,\n fieldInfos,\n expressionInfos\n };\n}\n\n/**\n * Setup storage attribute as string.\n * @param storageAttribute - attribute for map segmentation.\n */\nfunction setupStringAttribute(storageAttribute: AttributeStorageInfo): void {\n // @ts-expect-error\n storageAttribute.ordering.unshift('attributeByteCounts');\n storageAttribute.header.push({property: 'attributeValuesByteCount', valueType: 'UInt32'});\n storageAttribute.attributeValues = {\n valueType: 'String',\n encoding: 'UTF-8',\n valuesPerElement: 1\n };\n storageAttribute.attributeByteCounts = {\n valueType: 'UInt32',\n valuesPerElement: 1\n };\n}\n\n/**\n * Setup Id attribute for map segmentation.\n * @param storageAttribute - attribute for map segmentation .\n */\nfunction setupIdAttribute(storageAttribute: AttributeStorageInfo): void {\n storageAttribute.attributeValues = {\n valueType: 'Oid32',\n valuesPerElement: 1\n };\n}\n\n/**\n * Setup double attribute for map segmentation.\n * @param storageAttribute - attribute for map segmentation .\n */\nfunction setupDoubleAttribute(storageAttribute: AttributeStorageInfo): void {\n storageAttribute.attributeValues = {\n valueType: 'Float64',\n valuesPerElement: 1\n };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAuBO,SAASA,gCAAgC,CAC9CC,UAAoB,EACpBC,aAA+B,EACb;EAClB,IAAMC,mBAAqC,GAAG,CAAC,CAAC;EAChD,KAAK,IAAMC,YAAY,IAAIF,aAAa,EAAE;IACxC,IAAMG,UAAU,GAAGH,aAAa,CAACE,YAAY,CAAC;IAC9CD,mBAAmB,CAACC,YAAY,CAAC,GAAGE,yBAAyB,CAACD,UAAU,EAAEJ,UAAU,CAAC;EACvF;EAEA,OAAOE,mBAAmB;AAC5B;;AAOA,SAASG,yBAAyB,CAACD,UAAiB,EAAEJ,UAAoB,EAAS;EACjF,IAAMM,gBAAqB,GAAG,EAAE;EAAC,2CAETN,UAAU;IAAA;EAAA;IAAlC,oDAAoC;MAAA,IAAzBO,SAAS;MAClB,IAAMC,QAAQ,GAAGJ,UAAU,CAACG,SAAS,CAAC,IAAI,IAAI;MAC9CD,gBAAgB,CAACG,IAAI,CAACD,QAAQ,CAAC;IACjC;EAAC;IAAA;EAAA;IAAA;EAAA;EAED,OAAOF,gBAAgB;AACzB;;AASO,SAASI,qBAAqB,CACnCV,UAAoB,EACpBC,aAA+B,EACtB;EACT,IAAIU,WAAW,GAAG,KAAK;EAEvB,kCAAwBC,MAAM,CAACC,MAAM,CAACZ,aAAa,CAAC,oCAAE;IAAjD,IAAMa,SAAS;IAClB,IAAId,UAAU,CAACe,MAAM,KAAKD,SAAS,CAACC,MAAM,EAAE;MAC1CJ,WAAW,GAAG,IAAI;IACpB;EACF;EAEA,OAAOA,WAAW;AACpB;;AAGA,IAAMK,WAAW,GAAG,QAAQ;AAE5B,IAAMC,cAAc,GAAG,OAAO;AAE9B,IAAMC,WAAW,GAAG,QAAQ;AAE5B,IAAMC,cAAc,GAAG,UAAU;AAM1B,SAASC,gBAAgB,CAACC,GAAW,EAAEP,SAAiB,EAAU;EACvE,IAAIO,GAAG,KAAKF,cAAc,EAAE;IAC1B,OAAOA,cAAc;EACvB;EACA,IAAI,sBAAOL,SAAS,MAAKE,WAAW,EAAE;IACpC,OAAOA,WAAW;EACpB,CAAC,MAAM,IAAI,OAAOF,SAAS,KAAK,QAAQ,EAAE;IACxC,OAAOQ,MAAM,CAACC,SAAS,CAACT,SAAS,CAAC,GAAGG,cAAc,GAAGC,WAAW;EACnE;EACA,OAAOF,WAAW;AACpB;;AASO,SAASQ,uBAAuB,CACrCC,cAAsB,EACtBJ,GAAW,EACXK,aAAwB,EACF;EACtB,IAAMC,gBAAgB,GAAG;IACvBN,GAAG,cAAOI,cAAc,CAAE;IAC1BG,IAAI,EAAEP,GAAG;IACTQ,QAAQ,EAAE,CAAC,iBAAiB,CAAC;IAC7BC,MAAM,EAAE,CAAC;MAACtB,QAAQ,EAAE,OAAO;MAAEuB,SAAS,EAAE;IAAQ,CAAC,CAAC;IAClDC,eAAe,EAAE;MAACD,SAAS,EAAE,OAAO;MAAEE,gBAAgB,EAAE;IAAC;EAC3D,CAAC;EAED,QAAQP,aAAa;IACnB,KAAKP,cAAc;MACjBe,gBAAgB,CAACP,gBAAgB,CAAC;MAClC;IACF,KAAKX,WAAW;MACdmB,oBAAoB,CAACR,gBAAgB,CAAC;MACtC;IACF,KAAKT,WAAW;MACdkB,oBAAoB,CAACT,gBAAgB,CAAC;MACtC;IACF,KAAKV,cAAc;MACjB;IACF;MACEkB,oBAAoB,CAACR,gBAAgB,CAAC;EAAC;EAG3C,OAAOA,gBAAgB;AACzB;;AAMO,SAASU,qBAAqB,CAACX,aAAwB,EAAa;EACzE,QAAQA,aAAa;IACnB,KAAKP,cAAc;MACjB,OAAO,kBAAkB;IAC3B,KAAKH,WAAW;MACd,OAAO,qBAAqB;IAC9B,KAAKC,cAAc;MACjB,OAAO,sBAAsB;IAC/B,KAAKC,WAAW;MACd,OAAO,qBAAqB;IAC9B;MACE,OAAO,qBAAqB;EAAC;AAEnC;;AAOO,SAASoB,oBAAoB,CAACjB,GAAW,EAAEkB,kBAA6B,EAAS;EACtF,OAAO;IACLX,IAAI,EAAEP,GAAG;IACTmB,IAAI,EAAED,kBAAkB;IACxBE,KAAK,EAAEpB;EACT,CAAC;AACH;;AAOO,SAASqB,eAAe,CAACzC,aAA+B,EAAa;EAC1E,IAAM0C,KAAK,GAAG,YAAY;EAC1B,IAAMC,UAAU,GAAG,EAAE;EACrB,IAAMC,UAAuB,GAAG,EAAE;EAClC,IAAMC,aAGH,GAAG,EAAE;EACR,IAAMC,eAAe,GAAG,EAAE;EAE1B,KAAK,IAAM1B,GAAG,IAAIpB,aAAa,EAAE;IAC/B4C,UAAU,CAACpC,IAAI,CAAC;MACduC,SAAS,EAAE3B,GAAG;MACd4B,OAAO,EAAE,IAAI;MACbC,UAAU,EAAE,KAAK;MACjBC,KAAK,EAAE9B;IACT,CAAC,CAAC;EACJ;EACAyB,aAAa,CAACrC,IAAI,CAAC;IACjBoC,UAAU,EAAVA,UAAU;IACVL,IAAI,EAAE;EACR,CAAC,CAAC;EAEF,OAAO;IACLG,KAAK,EAALA,KAAK;IACLC,UAAU,EAAVA,UAAU;IACVE,aAAa,EAAbA,aAAa;IACbD,UAAU,EAAVA,UAAU;IACVE,eAAe,EAAfA;EACF,CAAC;AACH;;AAMA,SAASZ,oBAAoB,CAACR,gBAAsC,EAAQ;EAE1EA,gBAAgB,CAACE,QAAQ,CAACuB,OAAO,CAAC,qBAAqB,CAAC;EACxDzB,gBAAgB,CAACG,MAAM,CAACrB,IAAI,CAAC;IAACD,QAAQ,EAAE,0BAA0B;IAAEuB,SAAS,EAAE;EAAQ,CAAC,CAAC;EACzFJ,gBAAgB,CAACK,eAAe,GAAG;IACjCD,SAAS,EAAE,QAAQ;IACnBsB,QAAQ,EAAE,OAAO;IACjBpB,gBAAgB,EAAE;EACpB,CAAC;EACDN,gBAAgB,CAAC2B,mBAAmB,GAAG;IACrCvB,SAAS,EAAE,QAAQ;IACnBE,gBAAgB,EAAE;EACpB,CAAC;AACH;;AAMA,SAASC,gBAAgB,CAACP,gBAAsC,EAAQ;EACtEA,gBAAgB,CAACK,eAAe,GAAG;IACjCD,SAAS,EAAE,OAAO;IAClBE,gBAAgB,EAAE;EACpB,CAAC;AACH;;AAMA,SAASG,oBAAoB,CAACT,gBAAsC,EAAQ;EAC1EA,gBAAgB,CAACK,eAAe,GAAG;IACjCD,SAAS,EAAE,SAAS;IACpBE,gBAAgB,EAAE;EACpB,CAAC;AACH"}
|
|
@@ -1,37 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.generateAttributes = generateAttributes;
|
|
9
|
-
|
|
10
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
|
-
|
|
12
9
|
var _loaderUtils = require("@loaders.gl/loader-utils");
|
|
13
|
-
|
|
14
10
|
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
15
|
-
|
|
16
11
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
17
|
-
|
|
18
12
|
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
19
|
-
|
|
20
|
-
function
|
|
21
|
-
|
|
22
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
23
|
-
|
|
13
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
14
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
24
15
|
var VALUES_PER_VERTEX = 3;
|
|
25
16
|
var POSITIONS_AND_NORMALS_PER_TRIANGLE = 9;
|
|
26
17
|
|
|
27
18
|
function generateAttributes(attributes) {
|
|
28
19
|
var positions = attributes.positions,
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
20
|
+
normals = attributes.normals,
|
|
21
|
+
texCoords = attributes.texCoords,
|
|
22
|
+
colors = attributes.colors,
|
|
23
|
+
featureIndices = attributes.featureIndices;
|
|
33
24
|
var triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
|
|
34
|
-
|
|
35
25
|
if (!featureIndices.length) {
|
|
36
26
|
return {
|
|
37
27
|
faceRange: new Uint32Array([0, triangleCount - 1]),
|
|
@@ -43,7 +33,6 @@ function generateAttributes(attributes) {
|
|
|
43
33
|
colors: colors
|
|
44
34
|
};
|
|
45
35
|
}
|
|
46
|
-
|
|
47
36
|
var data = calculateFaceRangesAndFeaturesCount(featureIndices);
|
|
48
37
|
var attributeObjects = makeAttributeObjects(_objectSpread(_objectSpread({}, data), attributes));
|
|
49
38
|
var unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);
|
|
@@ -60,26 +49,20 @@ function calculateFaceRangesAndFeaturesCount(featureIndices) {
|
|
|
60
49
|
var uniqueFeatureIds = [currentFeatureId];
|
|
61
50
|
faceRangeList[0] = 0;
|
|
62
51
|
featureIds[0] = currentFeatureId;
|
|
63
|
-
|
|
64
52
|
for (var index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {
|
|
65
53
|
var newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));
|
|
66
|
-
|
|
67
54
|
if (currentFeatureId !== newFeatureId) {
|
|
68
55
|
faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;
|
|
69
56
|
faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;
|
|
70
57
|
featureIds[featureIndex] = newFeatureId;
|
|
71
|
-
|
|
72
58
|
if (!uniqueFeatureIds.includes(newFeatureId)) {
|
|
73
59
|
uniqueFeatureIds.push(newFeatureId);
|
|
74
60
|
}
|
|
75
|
-
|
|
76
61
|
rangeIndex += 2;
|
|
77
62
|
featureIndex += 1;
|
|
78
63
|
}
|
|
79
|
-
|
|
80
64
|
currentFeatureId = newFeatureId;
|
|
81
65
|
}
|
|
82
|
-
|
|
83
66
|
faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;
|
|
84
67
|
var faceRange = new Uint32Array(faceRangeList);
|
|
85
68
|
var featureCount = uniqueFeatureIds.length;
|
|
@@ -94,10 +77,8 @@ function getFrequentValue(values) {
|
|
|
94
77
|
var map = {};
|
|
95
78
|
var mostFrequentValue = values[0];
|
|
96
79
|
var maxCount = 1;
|
|
97
|
-
|
|
98
80
|
var _iterator = _createForOfIteratorHelper(values),
|
|
99
|
-
|
|
100
|
-
|
|
81
|
+
_step;
|
|
101
82
|
try {
|
|
102
83
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
103
84
|
var value = _step.value;
|
|
@@ -110,25 +91,23 @@ function getFrequentValue(values) {
|
|
|
110
91
|
} finally {
|
|
111
92
|
_iterator.f();
|
|
112
93
|
}
|
|
113
|
-
|
|
114
94
|
return mostFrequentValue;
|
|
115
95
|
}
|
|
116
96
|
|
|
117
97
|
function makeAttributeObjects(attributes) {
|
|
118
98
|
var featureIds = attributes.featureIds,
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
99
|
+
positions = attributes.positions,
|
|
100
|
+
normals = attributes.normals,
|
|
101
|
+
colors = attributes.colors,
|
|
102
|
+
texCoords = attributes.texCoords,
|
|
103
|
+
_attributes$faceRange = attributes.faceRange,
|
|
104
|
+
faceRange = _attributes$faceRange === void 0 ? new Uint32Array(0) : _attributes$faceRange;
|
|
125
105
|
var groupedData = [];
|
|
126
106
|
var positionsList = new Float32Array(positions);
|
|
127
107
|
var normalsList = new Float32Array(normals);
|
|
128
108
|
var colorsList = new Uint8Array(colors);
|
|
129
109
|
var texCoordsList = new Float32Array(texCoords);
|
|
130
110
|
var faceRangeIndex = 0;
|
|
131
|
-
|
|
132
111
|
for (var index = 0; index < featureIds.length; index++) {
|
|
133
112
|
var startIndex = faceRange[index + faceRangeIndex];
|
|
134
113
|
var endIndex = faceRange[index + faceRangeIndex + 1];
|
|
@@ -149,7 +128,6 @@ function makeAttributeObjects(attributes) {
|
|
|
149
128
|
texCoordsList = texCoordsList.slice(texCoordsCount);
|
|
150
129
|
faceRangeIndex += 1;
|
|
151
130
|
}
|
|
152
|
-
|
|
153
131
|
return groupedData.sort(function (first, second) {
|
|
154
132
|
return first.featureId - second.featureId;
|
|
155
133
|
});
|
|
@@ -160,18 +138,14 @@ function getSliceAttributeCount(attributeName, startIndex, endIndex) {
|
|
|
160
138
|
var texCoordsPerVertex = 2;
|
|
161
139
|
var trianglesCount = endIndex - startIndex + 1;
|
|
162
140
|
var vertexCount = trianglesCount * 3;
|
|
163
|
-
|
|
164
141
|
switch (attributeName) {
|
|
165
142
|
case 'positions':
|
|
166
143
|
case 'normals':
|
|
167
144
|
return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;
|
|
168
|
-
|
|
169
145
|
case 'colors':
|
|
170
146
|
return vertexCount * colorsPerVertex;
|
|
171
|
-
|
|
172
147
|
case 'texCoords':
|
|
173
148
|
return vertexCount * texCoordsPerVertex;
|
|
174
|
-
|
|
175
149
|
default:
|
|
176
150
|
return 0;
|
|
177
151
|
}
|
|
@@ -179,13 +153,11 @@ function getSliceAttributeCount(attributeName, startIndex, endIndex) {
|
|
|
179
153
|
|
|
180
154
|
function unifyObjectsByFeatureId(sortedData) {
|
|
181
155
|
var uniqueObjects = [];
|
|
182
|
-
|
|
183
156
|
var _loop = function _loop(index) {
|
|
184
157
|
var currentObject = sortedData[index];
|
|
185
158
|
var existedObject = uniqueObjects.find(function (obj) {
|
|
186
159
|
return obj.featureId === currentObject.featureId;
|
|
187
160
|
});
|
|
188
|
-
|
|
189
161
|
if (existedObject) {
|
|
190
162
|
existedObject.positions = (0, _loaderUtils.concatenateTypedArrays)(existedObject.positions, currentObject.positions);
|
|
191
163
|
existedObject.normals = (0, _loaderUtils.concatenateTypedArrays)(existedObject.normals, currentObject.normals);
|
|
@@ -195,11 +167,9 @@ function unifyObjectsByFeatureId(sortedData) {
|
|
|
195
167
|
uniqueObjects.push(currentObject);
|
|
196
168
|
}
|
|
197
169
|
};
|
|
198
|
-
|
|
199
170
|
for (var index = 0; index < sortedData.length; index++) {
|
|
200
171
|
_loop(index);
|
|
201
172
|
}
|
|
202
|
-
|
|
203
173
|
return uniqueObjects;
|
|
204
174
|
}
|
|
205
175
|
|
|
@@ -213,7 +183,6 @@ function groupAttributesAndRangesByFeatureId(unifiedObjects, featureCount) {
|
|
|
213
183
|
var range = [0];
|
|
214
184
|
var objIndex = 0;
|
|
215
185
|
var sum = 0;
|
|
216
|
-
|
|
217
186
|
for (var index = 1; index < unifiedObjects.length; index++) {
|
|
218
187
|
var currentAttributesObject = unifiedObjects[index];
|
|
219
188
|
featureIds.push(currentAttributesObject.featureId || 0);
|
|
@@ -227,7 +196,6 @@ function groupAttributesAndRangesByFeatureId(unifiedObjects, featureCount) {
|
|
|
227
196
|
sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;
|
|
228
197
|
objIndex += 1;
|
|
229
198
|
}
|
|
230
|
-
|
|
231
199
|
range.push(positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);
|
|
232
200
|
var faceRange = new Uint32Array(range);
|
|
233
201
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/i3s-converter/helpers/geometry-attributes.ts"],"names":["VALUES_PER_VERTEX","POSITIONS_AND_NORMALS_PER_TRIANGLE","generateAttributes","attributes","positions","normals","texCoords","colors","featureIndices","triangleCount","length","faceRange","Uint32Array","featureIds","featureCount","data","calculateFaceRangesAndFeaturesCount","attributeObjects","makeAttributeObjects","unifiedAttributeObjectsByFeatureIds","unifyObjectsByFeatureId","groupedAttributes","groupAttributesAndRangesByFeatureId","rangeIndex","featureIndex","currentFeatureId","getFrequentValue","slice","faceRangeList","uniqueFeatureIds","index","newFeatureId","includes","push","values","map","mostFrequentValue","maxCount","value","groupedData","positionsList","Float32Array","normalsList","colorsList","Uint8Array","texCoordsList","faceRangeIndex","startIndex","endIndex","positionsCount","getSliceAttributeCount","normalsCount","colorsCount","texCoordsCount","featureId","sort","first","second","attributeName","colorsPerVertex","texCoordsPerVertex","trianglesCount","vertexCount","sortedData","uniqueObjects","currentObject","existedObject","find","obj","unifiedObjects","firstAttributeObject","range","objIndex","sum","currentAttributesObject","groupedObject"],"mappings":"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","sourcesContent":["import type {GeometryAttributes, ConvertedAttributes, GroupedByFeatureIdAttributes} from '../types';\nimport {concatenateTypedArrays} from '@loaders.gl/loader-utils';\n\nconst VALUES_PER_VERTEX = 3;\nconst POSITIONS_AND_NORMALS_PER_TRIANGLE = 9;\n\n/**\n * Generate geometry attributes with faceRange and featureCount\n * @param attributes\n * @returns attirbutes with featureCount, featureIds and changed faceRange.\n */\nexport function generateAttributes(attributes: ConvertedAttributes): GeometryAttributes {\n const {positions, normals, texCoords, colors, featureIndices} = attributes;\n const triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n\n if (!featureIndices.length) {\n return {\n faceRange: new Uint32Array([0, triangleCount - 1]),\n featureIds: [0],\n featureCount: 1,\n positions,\n normals,\n texCoords,\n colors\n };\n }\n\n const data = calculateFaceRangesAndFeaturesCount(featureIndices);\n const attributeObjects = makeAttributeObjects({...data, ...attributes});\n const unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);\n const groupedAttributes = groupAttributesAndRangesByFeatureId(\n unifiedAttributeObjectsByFeatureIds,\n data.featureCount\n );\n return groupedAttributes;\n}\n\n/**\n * Calculates face Ranges and feature count based on featureIndices.\n * @param featureIndices\n * @returns Object with featureCount, reordered attributes and changed faceRange.\n */\nfunction calculateFaceRangesAndFeaturesCount(featureIndices: number[]): {\n faceRange: Uint32Array;\n featureCount: number;\n featureIds: number[];\n} {\n let rangeIndex = 1;\n let featureIndex = 1;\n let currentFeatureId = getFrequentValue(featureIndices.slice(0, VALUES_PER_VERTEX));\n const faceRangeList: any[] = [];\n const featureIds: any[] = [];\n const uniqueFeatureIds = [currentFeatureId];\n\n faceRangeList[0] = 0;\n featureIds[0] = currentFeatureId;\n\n for (let index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {\n const newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));\n if (currentFeatureId !== newFeatureId) {\n faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;\n faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;\n featureIds[featureIndex] = newFeatureId;\n\n if (!uniqueFeatureIds.includes(newFeatureId)) {\n uniqueFeatureIds.push(newFeatureId);\n }\n\n rangeIndex += 2;\n featureIndex += 1;\n }\n currentFeatureId = newFeatureId;\n }\n\n faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;\n\n const faceRange = new Uint32Array(faceRangeList);\n const featureCount = uniqueFeatureIds.length;\n\n return {faceRange, featureCount, featureIds};\n}\n\n/**\n * Find most frequent value to avoid situation where one vertex can be part of multiple features (objects).\n * @param values\n */\nfunction getFrequentValue(values: number[]): number {\n const map: {[key: number]: number} = {};\n\n let mostFrequentValue = values[0];\n let maxCount = 1;\n\n for (const value of values) {\n // Save item and it's frequency count to the map.\n map[value] = (map[value] || 0) + 1;\n // Find max count of frequency.\n maxCount = maxCount > map[value] ? maxCount : map[value];\n // Find the most frequent value.\n mostFrequentValue = maxCount > map[value] ? mostFrequentValue : value;\n }\n\n return mostFrequentValue;\n}\n\n/**\n * Generate list of attribute object grouped by feature ids.\n * @param attributes\n * @returns sorted list of attribute objects.\n */\nfunction makeAttributeObjects(attributes: GeometryAttributes): GroupedByFeatureIdAttributes[] {\n const {\n featureIds,\n positions,\n normals,\n colors,\n texCoords,\n faceRange = new Uint32Array(0)\n } = attributes;\n const groupedData: GroupedByFeatureIdAttributes[] = [];\n\n let positionsList = new Float32Array(positions);\n let normalsList = new Float32Array(normals);\n let colorsList = new Uint8Array(colors);\n let texCoordsList = new Float32Array(texCoords);\n\n let faceRangeIndex = 0;\n\n for (let index = 0; index < featureIds.length; index++) {\n const startIndex = faceRange[index + faceRangeIndex];\n const endIndex = faceRange[index + faceRangeIndex + 1];\n\n const positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);\n const normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);\n const colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);\n const texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);\n\n groupedData.push({\n featureId: featureIds[index],\n positions: positionsList.slice(0, positionsCount),\n normals: normalsList.slice(0, normalsCount),\n colors: colorsList.slice(0, colorsCount),\n texCoords: texCoordsList.slice(0, texCoordsCount)\n });\n\n positionsList = positionsList.slice(positionsCount);\n normalsList = normalsList.slice(normalsCount);\n colorsList = colorsList.slice(colorsCount);\n texCoordsList = texCoordsList.slice(texCoordsCount);\n\n faceRangeIndex += 1;\n }\n\n return groupedData.sort((first, second) => first.featureId - second.featureId);\n}\n\n/**\n * Generate sliced count for generating attribute objects depends on attribute name and range.\n * @param attributeName\n * @param startIndex\n * @param endIndex\n * @returns sliced count\n */\nfunction getSliceAttributeCount(\n attributeName: string,\n startIndex: number,\n endIndex: number\n): number {\n const colorsPerVertex = 4;\n const texCoordsPerVertex = 2;\n\n const trianglesCount = endIndex - startIndex + 1;\n const vertexCount = trianglesCount * 3;\n\n switch (attributeName) {\n case 'positions':\n case 'normals':\n return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;\n case 'colors':\n return vertexCount * colorsPerVertex;\n case 'texCoords':\n return vertexCount * texCoordsPerVertex;\n default:\n return 0;\n }\n}\n\n/**\n * Generates unique object list depends on feature ids and concantenate their attributes.\n * @param sortedData\n * @returns unique list of objects\n */\nfunction unifyObjectsByFeatureId(\n sortedData: GroupedByFeatureIdAttributes[]\n): GroupedByFeatureIdAttributes[] {\n const uniqueObjects: GroupedByFeatureIdAttributes[] = [];\n\n for (let index = 0; index < sortedData.length; index++) {\n const currentObject = sortedData[index];\n const existedObject = uniqueObjects.find((obj) => obj.featureId === currentObject.featureId);\n\n if (existedObject) {\n existedObject.positions = concatenateTypedArrays(\n existedObject.positions,\n currentObject.positions\n );\n existedObject.normals = concatenateTypedArrays(existedObject.normals, currentObject.normals);\n existedObject.colors = concatenateTypedArrays(existedObject.colors, currentObject.colors);\n existedObject.texCoords = concatenateTypedArrays(\n existedObject.texCoords,\n currentObject.texCoords\n );\n } else {\n uniqueObjects.push(currentObject);\n }\n }\n\n return uniqueObjects;\n}\n\n/**\n * Generates attribute objects with new faceRange and reordered attributes.\n * @param unifiedObjects\n * @returns generated attributes with new faceRange.\n */\nfunction groupAttributesAndRangesByFeatureId(\n unifiedObjects: GroupedByFeatureIdAttributes[],\n featureCount: number\n): GeometryAttributes {\n const firstAttributeObject = unifiedObjects[0];\n const featureIds = [firstAttributeObject.featureId || 0];\n\n let positions = new Float32Array(firstAttributeObject.positions);\n let normals = new Float32Array(firstAttributeObject.normals);\n let colors = new Uint8Array(firstAttributeObject.colors);\n let texCoords = new Float32Array(firstAttributeObject.texCoords);\n const range = [0];\n\n let objIndex = 0;\n let sum = 0;\n\n for (let index = 1; index < unifiedObjects.length; index++) {\n const currentAttributesObject = unifiedObjects[index];\n featureIds.push(currentAttributesObject.featureId || 0);\n\n positions = concatenateTypedArrays(positions, currentAttributesObject.positions);\n normals = concatenateTypedArrays(normals, currentAttributesObject.normals);\n colors = concatenateTypedArrays(colors, currentAttributesObject.colors);\n texCoords = concatenateTypedArrays(texCoords, currentAttributesObject.texCoords);\n\n const groupedObject = unifiedObjects[objIndex];\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE + sum);\n\n sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n objIndex += 1;\n }\n\n range.push(positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);\n\n const faceRange = new Uint32Array(range);\n return {faceRange, featureIds, positions, normals, colors, texCoords, featureCount};\n}\n"],"file":"geometry-attributes.js"}
|
|
1
|
+
{"version":3,"file":"geometry-attributes.js","names":["VALUES_PER_VERTEX","POSITIONS_AND_NORMALS_PER_TRIANGLE","generateAttributes","attributes","positions","normals","texCoords","colors","featureIndices","triangleCount","length","faceRange","Uint32Array","featureIds","featureCount","data","calculateFaceRangesAndFeaturesCount","attributeObjects","makeAttributeObjects","unifiedAttributeObjectsByFeatureIds","unifyObjectsByFeatureId","groupedAttributes","groupAttributesAndRangesByFeatureId","rangeIndex","featureIndex","currentFeatureId","getFrequentValue","slice","faceRangeList","uniqueFeatureIds","index","newFeatureId","includes","push","values","map","mostFrequentValue","maxCount","value","groupedData","positionsList","Float32Array","normalsList","colorsList","Uint8Array","texCoordsList","faceRangeIndex","startIndex","endIndex","positionsCount","getSliceAttributeCount","normalsCount","colorsCount","texCoordsCount","featureId","sort","first","second","attributeName","colorsPerVertex","texCoordsPerVertex","trianglesCount","vertexCount","sortedData","uniqueObjects","currentObject","existedObject","find","obj","concatenateTypedArrays","unifiedObjects","firstAttributeObject","range","objIndex","sum","currentAttributesObject","groupedObject"],"sources":["../../../../src/i3s-converter/helpers/geometry-attributes.ts"],"sourcesContent":["import type {GeometryAttributes, ConvertedAttributes, GroupedByFeatureIdAttributes} from '../types';\nimport {concatenateTypedArrays} from '@loaders.gl/loader-utils';\n\nconst VALUES_PER_VERTEX = 3;\nconst POSITIONS_AND_NORMALS_PER_TRIANGLE = 9;\n\n/**\n * Generate geometry attributes with faceRange and featureCount\n * @param attributes\n * @returns attirbutes with featureCount, featureIds and changed faceRange.\n */\nexport function generateAttributes(attributes: ConvertedAttributes): GeometryAttributes {\n const {positions, normals, texCoords, colors, featureIndices} = attributes;\n const triangleCount = positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n\n if (!featureIndices.length) {\n return {\n faceRange: new Uint32Array([0, triangleCount - 1]),\n featureIds: [0],\n featureCount: 1,\n positions,\n normals,\n texCoords,\n colors\n };\n }\n\n const data = calculateFaceRangesAndFeaturesCount(featureIndices);\n const attributeObjects = makeAttributeObjects({...data, ...attributes});\n const unifiedAttributeObjectsByFeatureIds = unifyObjectsByFeatureId(attributeObjects);\n const groupedAttributes = groupAttributesAndRangesByFeatureId(\n unifiedAttributeObjectsByFeatureIds,\n data.featureCount\n );\n return groupedAttributes;\n}\n\n/**\n * Calculates face Ranges and feature count based on featureIndices.\n * @param featureIndices\n * @returns Object with featureCount, reordered attributes and changed faceRange.\n */\nfunction calculateFaceRangesAndFeaturesCount(featureIndices: number[]): {\n faceRange: Uint32Array;\n featureCount: number;\n featureIds: number[];\n} {\n let rangeIndex = 1;\n let featureIndex = 1;\n let currentFeatureId = getFrequentValue(featureIndices.slice(0, VALUES_PER_VERTEX));\n const faceRangeList: any[] = [];\n const featureIds: any[] = [];\n const uniqueFeatureIds = [currentFeatureId];\n\n faceRangeList[0] = 0;\n featureIds[0] = currentFeatureId;\n\n for (let index = VALUES_PER_VERTEX; index < featureIndices.length; index += VALUES_PER_VERTEX) {\n const newFeatureId = getFrequentValue(featureIndices.slice(index, index + VALUES_PER_VERTEX));\n if (currentFeatureId !== newFeatureId) {\n faceRangeList[rangeIndex] = index / VALUES_PER_VERTEX - 1;\n faceRangeList[rangeIndex + 1] = index / VALUES_PER_VERTEX;\n featureIds[featureIndex] = newFeatureId;\n\n if (!uniqueFeatureIds.includes(newFeatureId)) {\n uniqueFeatureIds.push(newFeatureId);\n }\n\n rangeIndex += 2;\n featureIndex += 1;\n }\n currentFeatureId = newFeatureId;\n }\n\n faceRangeList[rangeIndex] = featureIndices.length / VALUES_PER_VERTEX - 1;\n\n const faceRange = new Uint32Array(faceRangeList);\n const featureCount = uniqueFeatureIds.length;\n\n return {faceRange, featureCount, featureIds};\n}\n\n/**\n * Find most frequent value to avoid situation where one vertex can be part of multiple features (objects).\n * @param values\n */\nfunction getFrequentValue(values: number[]): number {\n const map: {[key: number]: number} = {};\n\n let mostFrequentValue = values[0];\n let maxCount = 1;\n\n for (const value of values) {\n // Save item and it's frequency count to the map.\n map[value] = (map[value] || 0) + 1;\n // Find max count of frequency.\n maxCount = maxCount > map[value] ? maxCount : map[value];\n // Find the most frequent value.\n mostFrequentValue = maxCount > map[value] ? mostFrequentValue : value;\n }\n\n return mostFrequentValue;\n}\n\n/**\n * Generate list of attribute object grouped by feature ids.\n * @param attributes\n * @returns sorted list of attribute objects.\n */\nfunction makeAttributeObjects(attributes: GeometryAttributes): GroupedByFeatureIdAttributes[] {\n const {\n featureIds,\n positions,\n normals,\n colors,\n texCoords,\n faceRange = new Uint32Array(0)\n } = attributes;\n const groupedData: GroupedByFeatureIdAttributes[] = [];\n\n let positionsList = new Float32Array(positions);\n let normalsList = new Float32Array(normals);\n let colorsList = new Uint8Array(colors);\n let texCoordsList = new Float32Array(texCoords);\n\n let faceRangeIndex = 0;\n\n for (let index = 0; index < featureIds.length; index++) {\n const startIndex = faceRange[index + faceRangeIndex];\n const endIndex = faceRange[index + faceRangeIndex + 1];\n\n const positionsCount = getSliceAttributeCount('positions', startIndex, endIndex);\n const normalsCount = getSliceAttributeCount('normals', startIndex, endIndex);\n const colorsCount = getSliceAttributeCount('colors', startIndex, endIndex);\n const texCoordsCount = getSliceAttributeCount('texCoords', startIndex, endIndex);\n\n groupedData.push({\n featureId: featureIds[index],\n positions: positionsList.slice(0, positionsCount),\n normals: normalsList.slice(0, normalsCount),\n colors: colorsList.slice(0, colorsCount),\n texCoords: texCoordsList.slice(0, texCoordsCount)\n });\n\n positionsList = positionsList.slice(positionsCount);\n normalsList = normalsList.slice(normalsCount);\n colorsList = colorsList.slice(colorsCount);\n texCoordsList = texCoordsList.slice(texCoordsCount);\n\n faceRangeIndex += 1;\n }\n\n return groupedData.sort((first, second) => first.featureId - second.featureId);\n}\n\n/**\n * Generate sliced count for generating attribute objects depends on attribute name and range.\n * @param attributeName\n * @param startIndex\n * @param endIndex\n * @returns sliced count\n */\nfunction getSliceAttributeCount(\n attributeName: string,\n startIndex: number,\n endIndex: number\n): number {\n const colorsPerVertex = 4;\n const texCoordsPerVertex = 2;\n\n const trianglesCount = endIndex - startIndex + 1;\n const vertexCount = trianglesCount * 3;\n\n switch (attributeName) {\n case 'positions':\n case 'normals':\n return trianglesCount * POSITIONS_AND_NORMALS_PER_TRIANGLE;\n case 'colors':\n return vertexCount * colorsPerVertex;\n case 'texCoords':\n return vertexCount * texCoordsPerVertex;\n default:\n return 0;\n }\n}\n\n/**\n * Generates unique object list depends on feature ids and concantenate their attributes.\n * @param sortedData\n * @returns unique list of objects\n */\nfunction unifyObjectsByFeatureId(\n sortedData: GroupedByFeatureIdAttributes[]\n): GroupedByFeatureIdAttributes[] {\n const uniqueObjects: GroupedByFeatureIdAttributes[] = [];\n\n for (let index = 0; index < sortedData.length; index++) {\n const currentObject = sortedData[index];\n const existedObject = uniqueObjects.find((obj) => obj.featureId === currentObject.featureId);\n\n if (existedObject) {\n existedObject.positions = concatenateTypedArrays(\n existedObject.positions,\n currentObject.positions\n );\n existedObject.normals = concatenateTypedArrays(existedObject.normals, currentObject.normals);\n existedObject.colors = concatenateTypedArrays(existedObject.colors, currentObject.colors);\n existedObject.texCoords = concatenateTypedArrays(\n existedObject.texCoords,\n currentObject.texCoords\n );\n } else {\n uniqueObjects.push(currentObject);\n }\n }\n\n return uniqueObjects;\n}\n\n/**\n * Generates attribute objects with new faceRange and reordered attributes.\n * @param unifiedObjects\n * @returns generated attributes with new faceRange.\n */\nfunction groupAttributesAndRangesByFeatureId(\n unifiedObjects: GroupedByFeatureIdAttributes[],\n featureCount: number\n): GeometryAttributes {\n const firstAttributeObject = unifiedObjects[0];\n const featureIds = [firstAttributeObject.featureId || 0];\n\n let positions = new Float32Array(firstAttributeObject.positions);\n let normals = new Float32Array(firstAttributeObject.normals);\n let colors = new Uint8Array(firstAttributeObject.colors);\n let texCoords = new Float32Array(firstAttributeObject.texCoords);\n const range = [0];\n\n let objIndex = 0;\n let sum = 0;\n\n for (let index = 1; index < unifiedObjects.length; index++) {\n const currentAttributesObject = unifiedObjects[index];\n featureIds.push(currentAttributesObject.featureId || 0);\n\n positions = concatenateTypedArrays(positions, currentAttributesObject.positions);\n normals = concatenateTypedArrays(normals, currentAttributesObject.normals);\n colors = concatenateTypedArrays(colors, currentAttributesObject.colors);\n texCoords = concatenateTypedArrays(texCoords, currentAttributesObject.texCoords);\n\n const groupedObject = unifiedObjects[objIndex];\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1 + sum);\n range.push(groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE + sum);\n\n sum += groupedObject.positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE;\n objIndex += 1;\n }\n\n range.push(positions.length / POSITIONS_AND_NORMALS_PER_TRIANGLE - 1);\n\n const faceRange = new Uint32Array(range);\n return {faceRange, featureIds, positions, normals, colors, texCoords, featureCount};\n}\n"],"mappings":"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"}
|