UNPKG

itowns

Version:

A JS/WebGL framework for 3D geospatial data visualization

133 lines (104 loc) 4.46 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var THREE = _interopRequireWildcard(require("three")); var _Utf8Decoder = _interopRequireDefault(require("../Utils/Utf8Decoder")); var _BatchTableParser = _interopRequireDefault(require("./BatchTableParser")); var _default = { /** @module PntsParser */ /** Parse pnts buffer and extract THREE.Points and batch table * @function parse * @param {ArrayBuffer} buffer - the pnts buffer. * @return {Promise} - a promise that resolves with an object containig a THREE.Points (point) and a batch table (batchTable). * */ parse: function (buffer) { if (!buffer) { throw new Error('No array buffer provided.'); } var view = new DataView(buffer); var byteOffset = 0; var pntsHeader = {}; var batchTable = {}; var point = {}; // Magic type is unsigned char [4] pntsHeader.magic = _Utf8Decoder["default"].decode(new Uint8Array(buffer, byteOffset, 4)); byteOffset += 4; if (pntsHeader.magic) { // Version, byteLength, batchTableJSONByteLength, batchTableBinaryByteLength and batchTable types are uint32 pntsHeader.version = view.getUint32(byteOffset, true); byteOffset += Uint32Array.BYTES_PER_ELEMENT; pntsHeader.byteLength = view.getUint32(byteOffset, true); byteOffset += Uint32Array.BYTES_PER_ELEMENT; pntsHeader.FTJSONLength = view.getUint32(byteOffset, true); byteOffset += Uint32Array.BYTES_PER_ELEMENT; pntsHeader.FTBinaryLength = view.getUint32(byteOffset, true); byteOffset += Uint32Array.BYTES_PER_ELEMENT; pntsHeader.BTJSONLength = view.getUint32(byteOffset, true); byteOffset += Uint32Array.BYTES_PER_ELEMENT; pntsHeader.BTBinaryLength = view.getUint32(byteOffset, true); byteOffset += Uint32Array.BYTES_PER_ELEMENT; // binary table if (pntsHeader.FTBinaryLength > 0) { point = parseFeatureBinary(buffer, byteOffset, pntsHeader.FTJSONLength); } // batch table if (pntsHeader.BTJSONLength > 0) { var sizeBegin = 28 + pntsHeader.FTJSONLength + pntsHeader.FTBinaryLength; batchTable = _BatchTableParser["default"].parse(buffer.slice(sizeBegin, pntsHeader.BTJSONLength + sizeBegin)); } var pnts = { point: point, batchTable: batchTable }; return Promise.resolve(pnts); } else { throw new Error('Invalid pnts file.'); } } }; exports["default"] = _default; function parseFeatureBinary(array, byteOffset, FTJSONLength) { // Init geometry var geometry = new THREE.BufferGeometry(); // init Array feature binary var subArrayJson = _Utf8Decoder["default"].decode(new Uint8Array(array, byteOffset, FTJSONLength)); var parseJSON = JSON.parse(subArrayJson); var lengthFeature; if (parseJSON.POINTS_LENGTH) { lengthFeature = parseJSON.POINTS_LENGTH; } if (parseJSON.POSITION) { var byteOffsetPos = parseJSON.POSITION.byteOffset + subArrayJson.length + byteOffset; var positionArray = new Float32Array(array, byteOffsetPos, lengthFeature * 3); geometry.addAttribute('position', new THREE.BufferAttribute(positionArray, 3)); } if (parseJSON.RGB) { var byteOffsetCol = parseJSON.RGB.byteOffset + subArrayJson.length + byteOffset; var colorArray = new Uint8Array(array, byteOffsetCol, lengthFeature * 3); geometry.addAttribute('color', new THREE.BufferAttribute(colorArray, 3, true)); } if (parseJSON.POSITION_QUANTIZED) { throw new Error('For pnts loader, POSITION_QUANTIZED: not yet managed'); } if (parseJSON.RGBA) { throw new Error('For pnts loader, RGBA: not yet managed'); } if (parseJSON.RGB565) { throw new Error('For pnts loader, RGB565: not yet managed'); } if (parseJSON.NORMAL) { throw new Error('For pnts loader, NORMAL: not yet managed'); } if (parseJSON.NORMAL_OCT16P) { throw new Error('For pnts loader, NORMAL_OCT16P: not yet managed'); } if (parseJSON.BATCH_ID) { throw new Error('For pnts loader, BATCH_ID: not yet managed'); } // Add RTC feature var offset = parseJSON.RTC_CENTER ? new THREE.Vector3().fromArray(parseJSON.RTC_CENTER) : undefined; return { geometry: geometry, offset: offset }; }