itowns
Version:
A JS/WebGL framework for 3D geospatial data visualization
163 lines (134 loc) • 7.52 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var THREE = _interopRequireWildcard(require("three"));
var _PointCloudNode2 = _interopRequireDefault(require("./PointCloudNode"));
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function () { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
// Create an A(xis)A(ligned)B(ounding)B(ox) for the child `childIndex` of one aabb.
// (PotreeConverter protocol builds implicit octree hierarchy by applying the same
// subdivision algo recursively)
var dHalfLength = new THREE.Vector3();
var PotreeNode = /*#__PURE__*/function (_PointCloudNode) {
(0, _inherits2["default"])(PotreeNode, _PointCloudNode);
var _super = _createSuper(PotreeNode);
function PotreeNode() {
var _this;
var numPoints = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
var childrenBitField = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
var layer = arguments.length > 2 ? arguments[2] : undefined;
(0, _classCallCheck2["default"])(this, PotreeNode);
_this = _super.call(this, numPoints, layer);
_this.childrenBitField = childrenBitField;
_this.id = '';
_this.depth = 0;
_this.baseurl = layer.source.baseurl;
return _this;
}
(0, _createClass2["default"])(PotreeNode, [{
key: "add",
value: function add(node, indexChild, root) {
(0, _get2["default"])((0, _getPrototypeOf2["default"])(PotreeNode.prototype), "add", this).call(this, node, indexChild);
node.id = this.id + indexChild;
node.depth = node.id.length;
if (node.id.length % this.layer.hierarchyStepSize == 0) {
node.baseurl = "".concat(root.baseurl, "/").concat(node.id.substr(root.id.length));
} else {
node.baseurl = root.baseurl;
}
}
}, {
key: "createChildAABB",
value: function createChildAABB(node, childIndex) {
// Code inspired from potree
node.bbox.copy(this.bbox);
this.bbox.getCenter(node.bbox.max);
dHalfLength.copy(node.bbox.max).sub(this.bbox.min);
if (childIndex === 1) {
node.bbox.min.z += dHalfLength.z;
node.bbox.max.z += dHalfLength.z;
} else if (childIndex === 3) {
node.bbox.min.z += dHalfLength.z;
node.bbox.max.z += dHalfLength.z;
node.bbox.min.y += dHalfLength.y;
node.bbox.max.y += dHalfLength.y;
} else if (childIndex === 0) {//
} else if (childIndex === 2) {
node.bbox.min.y += dHalfLength.y;
node.bbox.max.y += dHalfLength.y;
} else if (childIndex === 5) {
node.bbox.min.z += dHalfLength.z;
node.bbox.max.z += dHalfLength.z;
node.bbox.min.x += dHalfLength.x;
node.bbox.max.x += dHalfLength.x;
} else if (childIndex === 7) {
node.bbox.min.add(dHalfLength);
node.bbox.max.add(dHalfLength);
} else if (childIndex === 4) {
node.bbox.min.x += dHalfLength.x;
node.bbox.max.x += dHalfLength.x;
} else if (childIndex === 6) {
node.bbox.min.y += dHalfLength.y;
node.bbox.max.y += dHalfLength.y;
node.bbox.min.x += dHalfLength.x;
node.bbox.max.x += dHalfLength.x;
}
}
}, {
key: "octreeIsLoaded",
get: function get() {
return !(this.childrenBitField && this.children.length === 0);
}
}, {
key: "url",
get: function get() {
return "".concat(this.baseurl, "/r").concat(this.id, ".").concat(this.layer.source.extension);
}
}, {
key: "loadOctree",
value: function loadOctree() {
var _this2 = this;
var octreeUrl = "".concat(this.baseurl, "/r").concat(this.id, ".").concat(this.layer.source.extensionOctree);
return this.layer.source.fetcher(octreeUrl, this.layer.source.networkOptions).then(function (blob) {
var view = new DataView(blob);
var stack = [];
var offset = 0;
_this2.childrenBitField = view.getUint8(0);
offset += 1;
_this2.numPoints = view.getUint32(1, true);
offset += 4;
stack.push(_this2);
while (stack.length && offset < blob.byteLength) {
var snode = stack.shift(); // look up 8 children
for (var indexChild = 0; indexChild < 8; indexChild++) {
// does snode have a #indexChild child ?
if (snode.childrenBitField & 1 << indexChild && offset + 5 <= blob.byteLength) {
var childrenBitField = view.getUint8(offset);
offset += 1;
var numPoints = view.getUint32(offset, true) || _this2.numPoints;
offset += 4;
var item = new PotreeNode(numPoints, childrenBitField, _this2.layer);
snode.add(item, indexChild, _this2);
stack.push(item);
}
}
}
});
}
}]);
return PotreeNode;
}(_PointCloudNode2["default"]);
var _default = PotreeNode;
exports["default"] = _default;