From 77cf8387856d74682488756340666a74eb46f6b8 Mon Sep 17 00:00:00 2001 From: Georg Dangl Date: Tue, 16 Jul 2024 12:17:17 +0200 Subject: [PATCH] Update handling of section boxes --- .../Services/RevitViewpointDisplayService.cs | 45 ++++++++++++++++++- 1 file changed, 43 insertions(+), 2 deletions(-) diff --git a/src/IPA.Bcfier.Revit/Services/RevitViewpointDisplayService.cs b/src/IPA.Bcfier.Revit/Services/RevitViewpointDisplayService.cs index 7e85509..a29b525 100644 --- a/src/IPA.Bcfier.Revit/Services/RevitViewpointDisplayService.cs +++ b/src/IPA.Bcfier.Revit/Services/RevitViewpointDisplayService.cs @@ -68,6 +68,18 @@ public RevitViewpointDisplayService(UIDocument uiDocument) } orthoView.SetOrientation(orient3D); + + if (ShouldEnableSectionBox(bcfViewpoint)) + { + orthoView.CropBoxActive = true; + orthoView.CropBoxVisible = true; + } + else + { + orthoView.CropBoxActive = false; + orthoView.CropBoxVisible = false; + } + trans.Commit(); } } @@ -123,8 +135,17 @@ public RevitViewpointDisplayService(UIDocument uiDocument) Parameter m_farClip = perspView.get_Parameter(BuiltInParameter.VIEWER_BOUND_ACTIVE_FAR); m_farClip.Set(0); } - perspView.CropBoxActive = true; - perspView.CropBoxVisible = true; + + if (ShouldEnableSectionBox(bcfViewpoint)) + { + perspView.CropBoxActive = true; + perspView.CropBoxVisible = true; + } + else + { + perspView.CropBoxActive = false; + perspView.CropBoxVisible = false; + } trans.Commit(); } @@ -283,12 +304,30 @@ public string GetName() // https://github.com/opf/openproject-revit-add-in/blob/93e117ad10176f4fffa741116733a3ee113e9335/src/OpenProject.Revit/Entry/OpenViewpointEventHandler.cs#L212 private const decimal _viewpointAngleThresholdRad = 0.087266462599716m; + private bool ShouldEnableSectionBox(BcfViewpoint bcfViewpoint) + { + if (bcfViewpoint.ClippingPlanes?.Count != 6) + { + return false; + } + + AxisAlignedBoundingBox boundingBox = GetViewpointClippingBox(bcfViewpoint); + if (boundingBox.Equals(AxisAlignedBoundingBox.Infinite)) + { + return false; + } + + return true; + } + private void ApplyClippingPlanes(UIDocument uiDocument, View3D view, BcfViewpoint bcfViewpoint) { if (bcfViewpoint.ClippingPlanes?.Count != 6) { // Don't apply section box if it's not a full box view.IsSectionBoxActive = false; + view.CropBoxActive = false; + view.CropBoxVisible = false; return; } @@ -302,6 +341,8 @@ private void ApplyClippingPlanes(UIDocument uiDocument, View3D view, BcfViewpoin else { view.IsSectionBoxActive = false; + view.CropBoxActive = false; + view.CropBoxVisible = false; } }