@jdultra/threedtiles 6.0.2 → 6.0.3
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/package.json +1 -1
- package/src/tileset/OGC3DTile.js +6 -7
package/package.json
CHANGED
package/src/tileset/OGC3DTile.js
CHANGED
|
@@ -392,7 +392,7 @@ class OGC3DTile extends THREE.Object3D {
|
|
|
392
392
|
!visibilityBeforeUpdate &&
|
|
393
393
|
self.hasMeshContent &&
|
|
394
394
|
self.meshContent &&
|
|
395
|
-
self.
|
|
395
|
+
self.meshDisplayed &&
|
|
396
396
|
self.areAllChildrenLoadedAndHidden()) {
|
|
397
397
|
|
|
398
398
|
self.disposeChildren();
|
|
@@ -444,7 +444,7 @@ class OGC3DTile extends THREE.Object3D {
|
|
|
444
444
|
if (!child.inFrustum) {
|
|
445
445
|
return true;
|
|
446
446
|
};
|
|
447
|
-
if (!child.materialVisibility || child.
|
|
447
|
+
if (!child.materialVisibility || child.meshDisplayed) {
|
|
448
448
|
allLoadedAndHidden = false;
|
|
449
449
|
return false;
|
|
450
450
|
} else if (self.occlusionCullingService.hasID(child.colorID)) {
|
|
@@ -501,7 +501,7 @@ class OGC3DTile extends THREE.Object3D {
|
|
|
501
501
|
}
|
|
502
502
|
|
|
503
503
|
// if all meshes have been displayed once
|
|
504
|
-
if (this.
|
|
504
|
+
if (this.meshDisplayed) {
|
|
505
505
|
return true;
|
|
506
506
|
}
|
|
507
507
|
|
|
@@ -534,8 +534,8 @@ class OGC3DTile extends THREE.Object3D {
|
|
|
534
534
|
return;
|
|
535
535
|
}
|
|
536
536
|
self.materialVisibility = visibility
|
|
537
|
-
|
|
538
|
-
self.
|
|
537
|
+
|
|
538
|
+
self.meshDisplayed = false;
|
|
539
539
|
if (!!self.meshContent.traverse) {
|
|
540
540
|
self.meshContent.traverse(function (element) {
|
|
541
541
|
if (element.material) setMeshVisibility(element, visibility);
|
|
@@ -549,10 +549,9 @@ class OGC3DTile extends THREE.Object3D {
|
|
|
549
549
|
function setMeshVisibility(mesh, visibility) {
|
|
550
550
|
mesh.material.visible = visibility;
|
|
551
551
|
if (!!visibility) {
|
|
552
|
-
self.meshesToDisplay=1;
|
|
553
552
|
mesh.onAfterRender = () => {
|
|
554
553
|
delete mesh.onAfterRender;
|
|
555
|
-
self.
|
|
554
|
+
self.meshDisplayed = true;
|
|
556
555
|
};
|
|
557
556
|
}
|
|
558
557
|
|