itowns
Version:
A JS/WebGL framework for 3D geospatial data visualization
133 lines (104 loc) • 4.46 kB
JavaScript
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
};
}
;