From e123772be9dda73f49ac646deaa5725015a36d27 Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 15:41:34 -0400 Subject: [PATCH 01/42] HYDRA-1098 : Add new pruning scene index --- lib/flowViewport/sceneIndex/CMakeLists.txt | 2 + .../sceneIndex/fvpPruningSceneIndex.cpp | 76 +++++++++++++++++++ .../sceneIndex/fvpPruningSceneIndex.h | 73 ++++++++++++++++++ 3 files changed, 151 insertions(+) create mode 100644 lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp create mode 100644 lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h diff --git a/lib/flowViewport/sceneIndex/CMakeLists.txt b/lib/flowViewport/sceneIndex/CMakeLists.txt index 56d3c1458..364e0463d 100644 --- a/lib/flowViewport/sceneIndex/CMakeLists.txt +++ b/lib/flowViewport/sceneIndex/CMakeLists.txt @@ -13,6 +13,7 @@ target_sources(${TARGET_NAME} fvpWireframeSelectionHighlightSceneIndex.cpp fvpDisplayStyleOverrideSceneIndex.cpp fvpPruneTexturesSceneIndex.cpp + fvpPruningSceneIndex.cpp fvpBBoxSceneIndex.cpp fvpReprSelectorSceneIndex.cpp fvpBlockPrimRemovalPropagationSceneIndex.cpp @@ -32,6 +33,7 @@ set(HEADERS fvpWireframeSelectionHighlightSceneIndex.h fvpDisplayStyleOverrideSceneIndex.h fvpPruneTexturesSceneIndex.h + fvpPruningSceneIndex.h fvpBBoxSceneIndex.h fvpReprSelectorSceneIndex.h fvpBlockPrimRemovalPropagationSceneIndex.h diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp new file mode 100644 index 000000000..fa6a216db --- /dev/null +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -0,0 +1,76 @@ +// Copyright 2024 Autodesk +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#include "flowViewport/sceneIndex/fvpPruningSceneIndex.h" + +#include +#include +#include +#include +#include + +#include + +PXR_NAMESPACE_USING_DIRECTIVE + +namespace { + +} // namespace + +namespace FVP_NS_DEF { + +PruningSceneIndexRefPtr PruningSceneIndex::New(const HdSceneIndexBaseRefPtr &inputSceneIndex) +{ + return TfCreateRefPtr(new PruningSceneIndex(inputSceneIndex)); +} + +PruningSceneIndex::PruningSceneIndex(HdSceneIndexBaseRefPtr const &inputSceneIndex) : + HdSingleInputFilteringSceneIndexBase(inputSceneIndex), + InputSceneIndexUtils(inputSceneIndex) +{ +} + +HdSceneIndexPrim PruningSceneIndex::GetPrim(const SdfPath& primPath) const +{ + return GetInputSceneIndex()->GetPrim(primPath); +} + +SdfPathVector PruningSceneIndex::GetChildPrimPaths(const SdfPath& primPath) const +{ + return GetInputSceneIndex()->GetChildPrimPaths(primPath); +} + +void PruningSceneIndex::_PrimsAdded( + const PXR_NS::HdSceneIndexBase &sender, + const PXR_NS::HdSceneIndexObserver::AddedPrimEntries &entries) +{ + +} + +void PruningSceneIndex::_PrimsRemoved( + const PXR_NS::HdSceneIndexBase &sender, + const PXR_NS::HdSceneIndexObserver::RemovedPrimEntries &entries) +{ + +} + +void PruningSceneIndex::_PrimsDirtied( + const PXR_NS::HdSceneIndexBase &sender, + const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) +{ + +} + +} // namespace FVP_NS_DEF diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h new file mode 100644 index 000000000..577ac0e0a --- /dev/null +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -0,0 +1,73 @@ +// Copyright 2024 Autodesk +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +#ifndef FVP_PRUNING_SCENE_INDEX_H +#define FVP_PRUNING_SCENE_INDEX_H + +#include "flowViewport/api.h" +#include "flowViewport/sceneIndex/fvpSceneIndexUtils.h" + +#include +#include +#include +#include + +namespace FVP_NS_DEF { + +class PruningSceneIndex; +typedef PXR_NS::TfRefPtr PruningSceneIndexRefPtr; +typedef PXR_NS::TfRefPtr PruningSceneIndexConstRefPtr; + +class PruningSceneIndex : + public PXR_NS::HdSingleInputFilteringSceneIndexBase + , public Fvp::InputSceneIndexUtils +{ +public: + using PXR_NS::HdSingleInputFilteringSceneIndexBase::_GetInputSceneIndex; + + FVP_API + static PruningSceneIndexRefPtr New(const PXR_NS::HdSceneIndexBaseRefPtr &inputScene); + + FVP_API + ~PruningSceneIndex() override = default; + + FVP_API + PXR_NS::HdSceneIndexPrim GetPrim(const PXR_NS::SdfPath& primPath) const override; + + FVP_API + PXR_NS::SdfPathVector GetChildPrimPaths(const PXR_NS::SdfPath& primPath) const override; + +protected: + FVP_API + PruningSceneIndex(PXR_NS::HdSceneIndexBaseRefPtr const &inputSceneIndex); + + FVP_API + void _PrimsAdded( + const PXR_NS::HdSceneIndexBase &sender, + const PXR_NS::HdSceneIndexObserver::AddedPrimEntries &entries) override; + + FVP_API + void _PrimsRemoved( + const PXR_NS::HdSceneIndexBase &sender, + const PXR_NS::HdSceneIndexObserver::RemovedPrimEntries &entries) override; + + FVP_API + void _PrimsDirtied( + const PXR_NS::HdSceneIndexBase &sender, + const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) override; +}; + +} // namespace FVP_NS_DEF + +#endif // FVP_PRUNING_SCENE_INDEX_H From 3f36ca7175343a0b3696becef9dc2b6c616335f3 Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 16:18:02 -0400 Subject: [PATCH 02/42] HYDRA-1098 : Implement enable/disable filter --- .../sceneIndex/fvpPruningSceneIndex.cpp | 58 ++++++++++++++++++- .../sceneIndex/fvpPruningSceneIndex.h | 12 ++++ 2 files changed, 67 insertions(+), 3 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index fa6a216db..b228a3641 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -14,9 +14,13 @@ // #include "flowViewport/sceneIndex/fvpPruningSceneIndex.h" +#include "fvpPruningSceneIndex.h" #include +#include #include +#include +#include #include #include #include @@ -27,6 +31,11 @@ PXR_NAMESPACE_USING_DIRECTIVE namespace { +bool _PrunePrim(const HdSceneIndexPrim& prim, const TfToken& filterToken) +{ + return true; +} + } // namespace namespace FVP_NS_DEF { @@ -52,25 +61,68 @@ SdfPathVector PruningSceneIndex::GetChildPrimPaths(const SdfPath& primPath) cons return GetInputSceneIndex()->GetChildPrimPaths(primPath); } +bool PruningSceneIndex::EnableFilter(const TfToken& filterToken) +{ + if (_prunedPathsByFilter.find(filterToken) != _prunedPathsByFilter.end()) { + // Filter already enabled, no change needed. + return false; + } + + HdSceneIndexObserver::RemovedPrimEntries prunedPrims; + + for (const SdfPath& primPath: HdSceneIndexPrimView(GetInputSceneIndex())) { + if (_PrunePrim(GetInputSceneIndex()->GetPrim(primPath), filterToken)) { + _prunedPathsByFilter[filterToken].emplace(primPath); + prunedPrims.emplace_back(primPath); + } + } + + if (!prunedPrims.empty()) { + _SendPrimsRemoved(prunedPrims); + } + + return true; +} + +bool PruningSceneIndex::DisableFilter(const TfToken& filterToken) +{ + if (_prunedPathsByFilter.find(filterToken) == _prunedPathsByFilter.end()) { + // Filter already disabled, no change needed. + return false; + } + + HdSceneIndexObserver::AddedPrimEntries unprunedPrims; + + for (const auto& primPath : _prunedPathsByFilter[filterToken]) { + unprunedPrims.emplace_back(primPath, GetInputSceneIndex()->GetPrim(primPath).primType); + } + + if (!unprunedPrims.empty()) { + _SendPrimsAdded(unprunedPrims); + } + + return true; +} + void PruningSceneIndex::_PrimsAdded( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::AddedPrimEntries &entries) { - +// Catch prims to prune } void PruningSceneIndex::_PrimsRemoved( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::RemovedPrimEntries &entries) { - +// Remove from map if it was pruned } void PruningSceneIndex::_PrimsDirtied( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) { - +// Check if prim pruning status should change } } // namespace FVP_NS_DEF diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 577ac0e0a..67994878d 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -18,10 +18,13 @@ #include "flowViewport/api.h" #include "flowViewport/sceneIndex/fvpSceneIndexUtils.h" +#include #include #include #include #include +#include +#include namespace FVP_NS_DEF { @@ -48,6 +51,12 @@ class PruningSceneIndex : FVP_API PXR_NS::SdfPathVector GetChildPrimPaths(const PXR_NS::SdfPath& primPath) const override; + FVP_API + bool EnableFilter(const PXR_NS::TfToken& filterToken); + + FVP_API + bool DisableFilter(const PXR_NS::TfToken& filterToken); + protected: FVP_API PruningSceneIndex(PXR_NS::HdSceneIndexBaseRefPtr const &inputSceneIndex); @@ -66,6 +75,9 @@ class PruningSceneIndex : void _PrimsDirtied( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) override; + + // Maps a filtering token to the set of prim paths that have been pruned out by this token + std::map _prunedPathsByFilter; }; } // namespace FVP_NS_DEF From dc636e547dbcb0d6059c9b99c5b74a2b8da870a7 Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 16:21:12 -0400 Subject: [PATCH 03/42] HYDRA-1098 : Add pruning tokens --- .../sceneIndex/fvpPruningSceneIndex.cpp | 22 ++++++++++++------- .../sceneIndex/fvpPruningSceneIndex.h | 14 ++++++++++++ 2 files changed, 28 insertions(+), 8 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index b228a3641..9668c80b9 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -27,11 +27,17 @@ #include +PXR_NAMESPACE_OPEN_SCOPE + +TF_DEFINE_PUBLIC_TOKENS(FvpPruningTokens, FVP_PRUNING_TOKENS); + +PXR_NAMESPACE_CLOSE_SCOPE + PXR_NAMESPACE_USING_DIRECTIVE namespace { -bool _PrunePrim(const HdSceneIndexPrim& prim, const TfToken& filterToken) +bool _PrunePrim(const HdSceneIndexPrim& prim, const TfToken& pruningToken) { return true; } @@ -61,9 +67,9 @@ SdfPathVector PruningSceneIndex::GetChildPrimPaths(const SdfPath& primPath) cons return GetInputSceneIndex()->GetChildPrimPaths(primPath); } -bool PruningSceneIndex::EnableFilter(const TfToken& filterToken) +bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) { - if (_prunedPathsByFilter.find(filterToken) != _prunedPathsByFilter.end()) { + if (_prunedPathsByFilter.find(pruningToken) != _prunedPathsByFilter.end()) { // Filter already enabled, no change needed. return false; } @@ -71,8 +77,8 @@ bool PruningSceneIndex::EnableFilter(const TfToken& filterToken) HdSceneIndexObserver::RemovedPrimEntries prunedPrims; for (const SdfPath& primPath: HdSceneIndexPrimView(GetInputSceneIndex())) { - if (_PrunePrim(GetInputSceneIndex()->GetPrim(primPath), filterToken)) { - _prunedPathsByFilter[filterToken].emplace(primPath); + if (_PrunePrim(GetInputSceneIndex()->GetPrim(primPath), pruningToken)) { + _prunedPathsByFilter[pruningToken].emplace(primPath); prunedPrims.emplace_back(primPath); } } @@ -84,16 +90,16 @@ bool PruningSceneIndex::EnableFilter(const TfToken& filterToken) return true; } -bool PruningSceneIndex::DisableFilter(const TfToken& filterToken) +bool PruningSceneIndex::DisableFilter(const TfToken& pruningToken) { - if (_prunedPathsByFilter.find(filterToken) == _prunedPathsByFilter.end()) { + if (_prunedPathsByFilter.find(pruningToken) == _prunedPathsByFilter.end()) { // Filter already disabled, no change needed. return false; } HdSceneIndexObserver::AddedPrimEntries unprunedPrims; - for (const auto& primPath : _prunedPathsByFilter[filterToken]) { + for (const auto& primPath : _prunedPathsByFilter[pruningToken]) { unprunedPrims.emplace_back(primPath, GetInputSceneIndex()->GetPrim(primPath).primType); } diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 67994878d..134596cca 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -26,6 +26,20 @@ #include #include +PXR_NAMESPACE_OPEN_SCOPE + +// clang-format off +#define FVP_PRUNING_TOKENS \ + (mesh) \ + (sphere) \ + (cone) \ + (cube) +// clang-format on + +TF_DECLARE_PUBLIC_TOKENS(FvpPruningTokens, FVP_API, FVP_PRUNING_TOKENS); + +PXR_NAMESPACE_CLOSE_SCOPE + namespace FVP_NS_DEF { class PruningSceneIndex; From 325880944960e287929cefb528ab14e42feb3548 Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 16:47:07 -0400 Subject: [PATCH 04/42] HYDRA-1098 : Implement notifications handlers --- .../sceneIndex/fvpPruningSceneIndex.cpp | 65 +++++++++++++++++-- 1 file changed, 61 insertions(+), 4 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 9668c80b9..328edde60 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -24,6 +24,7 @@ #include #include #include +#include #include @@ -39,7 +40,10 @@ namespace { bool _PrunePrim(const HdSceneIndexPrim& prim, const TfToken& pruningToken) { - return true; + if (pruningToken == FvpPruningTokens->mesh) { + return prim.primType == HdPrimTypeTokens->mesh; + } + return false; } } // namespace @@ -114,21 +118,74 @@ void PruningSceneIndex::_PrimsAdded( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::AddedPrimEntries &entries) { -// Catch prims to prune + HdSceneIndexObserver::AddedPrimEntries editedEntries; + for (const auto& addedEntry : entries) { + for (auto& filterEntry : _prunedPathsByFilter) { + if (_PrunePrim(GetInputSceneIndex()->GetPrim(addedEntry.primPath), filterEntry.first)) { + filterEntry.second.emplace(addedEntry.primPath); + } else { + editedEntries.emplace_back(addedEntry); + } + } + } + if (!editedEntries.empty()) { + _SendPrimsAdded(editedEntries); + } } void PruningSceneIndex::_PrimsRemoved( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::RemovedPrimEntries &entries) { -// Remove from map if it was pruned + HdSceneIndexObserver::RemovedPrimEntries editedEntries; + for (const auto& removedEntry : entries) { + for (auto& filterEntry : _prunedPathsByFilter) { + if (filterEntry.second.find(removedEntry.primPath) != filterEntry.second.end()) { + filterEntry.second.erase(removedEntry.primPath); + } else { + editedEntries.emplace_back(removedEntry); + } + } + } + if (!editedEntries.empty()) { + _SendPrimsRemoved(editedEntries); + } } void PruningSceneIndex::_PrimsDirtied( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) { -// Check if prim pruning status should change + HdSceneIndexObserver::DirtiedPrimEntries editedEntries; + HdSceneIndexObserver::RemovedPrimEntries removedEntries; + HdSceneIndexObserver::AddedPrimEntries addedEntries; + + for (const auto& dirtiedEntry : entries) { + for (const auto& filterEntry : _prunedPathsByFilter) { + HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); + + bool isPruned = filterEntry.second.find(dirtiedEntry.primPath) != filterEntry.second.end(); + bool shouldBePruned = _PrunePrim(dirtiedPrim, filterEntry.first); + + if (!isPruned && shouldBePruned) { + removedEntries.emplace_back(dirtiedEntry.primPath); + } else if (isPruned && !shouldBePruned) { + addedEntries.emplace_back(dirtiedEntry.primPath, dirtiedPrim.primType); + } else { + editedEntries.emplace_back(dirtiedEntry); + } + } + } + + if (!removedEntries.empty()) { + _SendPrimsRemoved(removedEntries); + } + if (!addedEntries.empty()) { + _SendPrimsAdded(addedEntries); + } + if (!editedEntries.empty()) { + _SendPrimsDirtied(editedEntries); + } } } // namespace FVP_NS_DEF From 8fd711d5306e50f054ee855aa12dff70ce507fb3 Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 17:14:36 -0400 Subject: [PATCH 05/42] HYDRA-1098 : Workaround for PathInterface + basic integration --- lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h | 13 ++++++++++++- lib/mayaHydra/mayaPlugin/renderOverride.cpp | 11 ++++++++++- lib/mayaHydra/mayaPlugin/renderOverride.h | 2 ++ 3 files changed, 24 insertions(+), 2 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 134596cca..2d0cc6549 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -17,7 +17,9 @@ #include "flowViewport/api.h" #include "flowViewport/sceneIndex/fvpSceneIndexUtils.h" +#include "flowViewport/sceneIndex/fvpPathInterface.h" +#include #include #include #include @@ -48,7 +50,8 @@ typedef PXR_NS::TfRefPtr PruningSceneIndexConstRefPtr; class PruningSceneIndex : public PXR_NS::HdSingleInputFilteringSceneIndexBase - , public Fvp::InputSceneIndexUtils + , public InputSceneIndexUtils + , public PathInterface // As a workaround until we move to exclusively using PathMappers { public: using PXR_NS::HdSingleInputFilteringSceneIndexBase::_GetInputSceneIndex; @@ -71,6 +74,14 @@ class PruningSceneIndex : FVP_API bool DisableFilter(const PXR_NS::TfToken& filterToken); + FVP_API + PrimSelections UfePathToPrimSelections(const Ufe::Path& appPath) const override { + PXR_NAMESPACE_USING_DIRECTIVE; + const PathInterface* pathInterface = dynamic_cast(&*GetInputSceneIndex()); + TF_AXIOM(pathInterface); + return pathInterface->UfePathToPrimSelections(appPath); + } + protected: FVP_API PruningSceneIndex(PXR_NS::HdSceneIndexBaseRefPtr const &inputSceneIndex); diff --git a/lib/mayaHydra/mayaPlugin/renderOverride.cpp b/lib/mayaHydra/mayaPlugin/renderOverride.cpp index f04ba1b09..62f72dc7b 100644 --- a/lib/mayaHydra/mayaPlugin/renderOverride.cpp +++ b/lib/mayaHydra/mayaPlugin/renderOverride.cpp @@ -102,6 +102,7 @@ #include #include #include +#include #include #include #include @@ -802,6 +803,13 @@ MStatus MtohRenderOverride::Render( _displayStyleSceneIndex->SetRefineLevel({true, delegateParams.refineLevel}); } + auto objectExclusions = framecontext->objectTypeExclusions(); + if (objectExclusions & MHWRender::MFrameContext::kExcludeMeshes) { + _pruningSceneIndex->EnableFilter(FvpPruningTokens->mesh); + } else { + _pruningSceneIndex->DisableFilter(FvpPruningTokens->mesh); + } + // Toggle textures in the material network const unsigned int currentDisplayMode = drawContext.getDisplayStyle(); bool isTextured = currentDisplayMode & MHWRender::MFrameContext::kTextured; @@ -1088,8 +1096,9 @@ void MtohRenderOverride::_InitHydraResources(const MHWRender::MDrawContext& draw //Put BlockPrimRemovalPropagationSceneIndex first as it can block/unblock the prim removal propagation on the whole scene indices chain _blockPrimRemovalPropagationSceneIndex = Fvp::BlockPrimRemovalPropagationSceneIndex::New(_inputSceneIndexOfFilteringSceneIndicesChain); + _pruningSceneIndex = Fvp::PruningSceneIndex::New(_blockPrimRemovalPropagationSceneIndex); _selection = std::make_shared(); - _selectionSceneIndex = Fvp::SelectionSceneIndex::New(_blockPrimRemovalPropagationSceneIndex, _selection); + _selectionSceneIndex = Fvp::SelectionSceneIndex::New(_pruningSceneIndex, _selection); _selectionSceneIndex->SetDisplayName("Flow Viewport Selection Scene Index"); _inputSceneIndexOfFilteringSceneIndicesChain = _selectionSceneIndex; diff --git a/lib/mayaHydra/mayaPlugin/renderOverride.h b/lib/mayaHydra/mayaPlugin/renderOverride.h index a04d4b6c0..41cf634c1 100644 --- a/lib/mayaHydra/mayaPlugin/renderOverride.h +++ b/lib/mayaHydra/mayaPlugin/renderOverride.h @@ -53,6 +53,7 @@ #include #include #include +#include #include #include @@ -280,6 +281,7 @@ class MtohRenderOverride : public MHWRender::MRenderOverride, Fvp::SelectionPtr _selection; Fvp::WireframeSelectionHighlightSceneIndexRefPtr _wireframeSelectionHighlightSceneIndex; Fvp::BlockPrimRemovalPropagationSceneIndexRefPtr _blockPrimRemovalPropagationSceneIndex; + Fvp::PruningSceneIndexRefPtr _pruningSceneIndex; Fvp::LightsManagementSceneIndexRefPtr _lightsManagementSceneIndex; // Naming this identifier _ufeSelection clashes with UFE's selection.h From 580eda8882988b5c91298a4545e4501461f1f3dd Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 17:20:59 -0400 Subject: [PATCH 06/42] HYDRA-1098 : Implement GetPrim and GetChildPrimPaths --- .../sceneIndex/fvpPruningSceneIndex.cpp | 22 ++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 328edde60..026656a32 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -25,6 +25,7 @@ #include #include #include +#include #include @@ -63,12 +64,31 @@ PruningSceneIndex::PruningSceneIndex(HdSceneIndexBaseRefPtr const &inputSceneInd HdSceneIndexPrim PruningSceneIndex::GetPrim(const SdfPath& primPath) const { + for (const auto& filterEntry : _prunedPathsByFilter) { + if (filterEntry.second.find(primPath) != filterEntry.second.end()) { + return {}; + } + } return GetInputSceneIndex()->GetPrim(primPath); } SdfPathVector PruningSceneIndex::GetChildPrimPaths(const SdfPath& primPath) const { - return GetInputSceneIndex()->GetChildPrimPaths(primPath); + SdfPathVector baseChildPaths = GetInputSceneIndex()->GetChildPrimPaths(primPath); + SdfPathVector editedChildPaths; + for (const auto& baseChildPath : baseChildPaths) { + bool isPruned = false; + for (const auto& filterEntry : _prunedPathsByFilter) { + if (filterEntry.second.find(baseChildPath) != filterEntry.second.end()) { + isPruned = true; + break; + } + } + if (!isPruned) { + editedChildPaths.emplace_back(baseChildPath); + } + } + return editedChildPaths; } bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) From c68aa74346b74dd6e4781497320277a14139a88f Mon Sep 17 00:00:00 2001 From: debloip Date: Thu, 10 Oct 2024 17:28:49 -0400 Subject: [PATCH 07/42] HYDRA-1098 : Update filter map on enable/disable --- lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 026656a32..a40e115f9 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -98,6 +98,8 @@ bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) return false; } + _prunedPathsByFilter[pruningToken] = SdfPathSet(); + HdSceneIndexObserver::RemovedPrimEntries prunedPrims; for (const SdfPath& primPath: HdSceneIndexPrimView(GetInputSceneIndex())) { @@ -127,6 +129,8 @@ bool PruningSceneIndex::DisableFilter(const TfToken& pruningToken) unprunedPrims.emplace_back(primPath, GetInputSceneIndex()->GetPrim(primPath).primType); } + _prunedPathsByFilter.erase(pruningToken); + if (!unprunedPrims.empty()) { _SendPrimsAdded(unprunedPrims); } From 30387f1728433abd79cb4fccece315fe7dd9984a Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 11:34:20 -0400 Subject: [PATCH 08/42] HYDRA-108 : Exclude scene roots --- .../sceneIndex/fvpPruningSceneIndex.cpp | 39 ++++++++++++++----- .../sceneIndex/fvpPruningSceneIndex.h | 12 ++++++ 2 files changed, 42 insertions(+), 9 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index a40e115f9..63640a093 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -39,14 +39,6 @@ PXR_NAMESPACE_USING_DIRECTIVE namespace { -bool _PrunePrim(const HdSceneIndexPrim& prim, const TfToken& pruningToken) -{ - if (pruningToken == FvpPruningTokens->mesh) { - return prim.primType == HdPrimTypeTokens->mesh; - } - return false; -} - } // namespace namespace FVP_NS_DEF { @@ -62,6 +54,32 @@ PruningSceneIndex::PruningSceneIndex(HdSceneIndexBaseRefPtr const &inputSceneInd { } +void PruningSceneIndex::AddExcludedSceneRoot(const PXR_NS::SdfPath& sceneRoot) +{ + _excludedSceneRoots.emplace(sceneRoot); +} + +bool PruningSceneIndex::_IsExcluded(const PXR_NS::SdfPath& primPath) const +{ + for (const auto& excludedSceneRoot : _excludedSceneRoots) { + if (primPath.HasPrefix(excludedSceneRoot)) { + return true; + } + } + return false; +} + +bool PruningSceneIndex::_PrunePrim(const SdfPath& primPath, const HdSceneIndexPrim& prim, const TfToken& pruningToken) const +{ + if (_IsExcluded(primPath)) { + return false; + } + if (pruningToken == FvpPruningTokens->mesh) { + return prim.primType == HdPrimTypeTokens->mesh; + } + return false; +} + HdSceneIndexPrim PruningSceneIndex::GetPrim(const SdfPath& primPath) const { for (const auto& filterEntry : _prunedPathsByFilter) { @@ -102,7 +120,7 @@ bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) HdSceneIndexObserver::RemovedPrimEntries prunedPrims; - for (const SdfPath& primPath: HdSceneIndexPrimView(GetInputSceneIndex())) { + for (const SdfPath& primPath : HdSceneIndexPrimView(GetInputSceneIndex())) { if (_PrunePrim(GetInputSceneIndex()->GetPrim(primPath), pruningToken)) { _prunedPathsByFilter[pruningToken].emplace(primPath); prunedPrims.emplace_back(primPath); @@ -144,6 +162,7 @@ void PruningSceneIndex::_PrimsAdded( { HdSceneIndexObserver::AddedPrimEntries editedEntries; for (const auto& addedEntry : entries) { + // We're executing the full loop for each filter, so too many notification sent for (auto& filterEntry : _prunedPathsByFilter) { if (_PrunePrim(GetInputSceneIndex()->GetPrim(addedEntry.primPath), filterEntry.first)) { filterEntry.second.emplace(addedEntry.primPath); @@ -163,6 +182,7 @@ void PruningSceneIndex::_PrimsRemoved( { HdSceneIndexObserver::RemovedPrimEntries editedEntries; for (const auto& removedEntry : entries) { + // We're executing the full loop for each filter, so too many notification sent for (auto& filterEntry : _prunedPathsByFilter) { if (filterEntry.second.find(removedEntry.primPath) != filterEntry.second.end()) { filterEntry.second.erase(removedEntry.primPath); @@ -185,6 +205,7 @@ void PruningSceneIndex::_PrimsDirtied( HdSceneIndexObserver::AddedPrimEntries addedEntries; for (const auto& dirtiedEntry : entries) { + // We're executing the full loop for each filter, so too many notification sent for (const auto& filterEntry : _prunedPathsByFilter) { HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 2d0cc6549..92da72f48 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -25,6 +25,7 @@ #include #include #include + #include #include @@ -74,6 +75,9 @@ class PruningSceneIndex : FVP_API bool DisableFilter(const PXR_NS::TfToken& filterToken); + FVP_API + void AddExcludedSceneRoot(const PXR_NS::SdfPath& sceneRoot); + FVP_API PrimSelections UfePathToPrimSelections(const Ufe::Path& appPath) const override { PXR_NAMESPACE_USING_DIRECTIVE; @@ -101,8 +105,16 @@ class PruningSceneIndex : const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) override; + FVP_API + bool _IsExcluded(const PXR_NS::SdfPath& primPath) const; + + FVP_API + bool _PrunePrim(const PXR_NS::SdfPath& primPath, const PXR_NS::HdSceneIndexPrim& prim, const PXR_NS::TfToken& pruningToken) const; + // Maps a filtering token to the set of prim paths that have been pruned out by this token std::map _prunedPathsByFilter; + + std::set _excludedSceneRoots; }; } // namespace FVP_NS_DEF From ae0e6ae43cd9cbbb8f4c3620010e3430a095d33a Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 12:06:03 -0400 Subject: [PATCH 09/42] HYDRA-1098 : Add ancestor check --- .../sceneIndex/fvpPruningSceneIndex.cpp | 57 ++++++++++++------- .../sceneIndex/fvpPruningSceneIndex.h | 4 ++ 2 files changed, 41 insertions(+), 20 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 63640a093..72048e45c 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -61,6 +61,7 @@ void PruningSceneIndex::AddExcludedSceneRoot(const PXR_NS::SdfPath& sceneRoot) bool PruningSceneIndex::_IsExcluded(const PXR_NS::SdfPath& primPath) const { + // TODO : Use parent-based approach for (const auto& excludedSceneRoot : _excludedSceneRoots) { if (primPath.HasPrefix(excludedSceneRoot)) { return true; @@ -80,13 +81,24 @@ bool PruningSceneIndex::_PrunePrim(const SdfPath& primPath, const HdSceneIndexPr return false; } -HdSceneIndexPrim PruningSceneIndex::GetPrim(const SdfPath& primPath) const +bool PruningSceneIndex::_IsAncestorPrunedInclusive(const SdfPath& primPath) const { - for (const auto& filterEntry : _prunedPathsByFilter) { - if (filterEntry.second.find(primPath) != filterEntry.second.end()) { - return {}; + SdfPath currPath = primPath; + while (!currPath.IsAbsoluteRootPath()) { + if (_filtersByPrunedPath.find(currPath) != _filtersByPrunedPath.end()) { + return true; + } else { + currPath = currPath.GetParentPath(); } } + return false; +} + +HdSceneIndexPrim PruningSceneIndex::GetPrim(const SdfPath& primPath) const +{ + if (_filtersByPrunedPath.find(primPath) != _filtersByPrunedPath.end()) { + return {}; + } return GetInputSceneIndex()->GetPrim(primPath); } @@ -95,14 +107,7 @@ SdfPathVector PruningSceneIndex::GetChildPrimPaths(const SdfPath& primPath) cons SdfPathVector baseChildPaths = GetInputSceneIndex()->GetChildPrimPaths(primPath); SdfPathVector editedChildPaths; for (const auto& baseChildPath : baseChildPaths) { - bool isPruned = false; - for (const auto& filterEntry : _prunedPathsByFilter) { - if (filterEntry.second.find(baseChildPath) != filterEntry.second.end()) { - isPruned = true; - break; - } - } - if (!isPruned) { + if (_filtersByPrunedPath.find(baseChildPath) == _filtersByPrunedPath.end()) { editedChildPaths.emplace_back(baseChildPath); } } @@ -116,14 +121,16 @@ bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) return false; } - _prunedPathsByFilter[pruningToken] = SdfPathSet(); - HdSceneIndexObserver::RemovedPrimEntries prunedPrims; for (const SdfPath& primPath : HdSceneIndexPrimView(GetInputSceneIndex())) { - if (_PrunePrim(GetInputSceneIndex()->GetPrim(primPath), pruningToken)) { + if (_PrunePrim(primPath, GetInputSceneIndex()->GetPrim(primPath), pruningToken)) { + if (!_IsAncestorPrunedInclusive(primPath)) { + // Only send notification if it was not already pruned out, directly or indirectly + prunedPrims.emplace_back(primPath); + } _prunedPathsByFilter[pruningToken].emplace(primPath); - prunedPrims.emplace_back(primPath); + _filtersByPrunedPath[primPath].emplace(pruningToken); } } @@ -141,13 +148,23 @@ bool PruningSceneIndex::DisableFilter(const TfToken& pruningToken) return false; } - HdSceneIndexObserver::AddedPrimEntries unprunedPrims; + SdfPathSet prunedPaths = _prunedPathsByFilter[pruningToken]; - for (const auto& primPath : _prunedPathsByFilter[pruningToken]) { - unprunedPrims.emplace_back(primPath, GetInputSceneIndex()->GetPrim(primPath).primType); + _prunedPathsByFilter.erase(pruningToken); + for (const auto& primPath : prunedPaths) { + _filtersByPrunedPath[primPath].erase(pruningToken); + if (_filtersByPrunedPath[primPath].empty()) { + _filtersByPrunedPath.erase(primPath); + } } - _prunedPathsByFilter.erase(pruningToken); + HdSceneIndexObserver::AddedPrimEntries unprunedPrims; + for (const auto& primPath : prunedPaths) { + // If it's still pruned, avoid sending a notification + if (!_IsAncestorPrunedInclusive(primPath)) { + unprunedPrims.emplace_back(primPath, GetInputSceneIndex()->GetPrim(primPath).primType); + } + } if (!unprunedPrims.empty()) { _SendPrimsAdded(unprunedPrims); diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 92da72f48..f41efaf04 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -111,8 +111,12 @@ class PruningSceneIndex : FVP_API bool _PrunePrim(const PXR_NS::SdfPath& primPath, const PXR_NS::HdSceneIndexPrim& prim, const PXR_NS::TfToken& pruningToken) const; + FVP_API + bool _IsAncestorPrunedInclusive(const PXR_NS::SdfPath& primPath) const; + // Maps a filtering token to the set of prim paths that have been pruned out by this token std::map _prunedPathsByFilter; + std::map> _filtersByPrunedPath; std::set _excludedSceneRoots; }; From b157daea76f0c45cadb9490cfb961c97392cdb46 Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 12:27:53 -0400 Subject: [PATCH 10/42] HYDRA-1098 : Handle all the different cases (hopefully) --- .../sceneIndex/fvpPruningSceneIndex.cpp | 54 ++++++++++++------- 1 file changed, 35 insertions(+), 19 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 72048e45c..572afe156 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -84,7 +84,7 @@ bool PruningSceneIndex::_PrunePrim(const SdfPath& primPath, const HdSceneIndexPr bool PruningSceneIndex::_IsAncestorPrunedInclusive(const SdfPath& primPath) const { SdfPath currPath = primPath; - while (!currPath.IsAbsoluteRootPath()) { + while (!currPath.IsEmpty() && !currPath.IsAbsoluteRootPath()) { if (_filtersByPrunedPath.find(currPath) != _filtersByPrunedPath.end()) { return true; } else { @@ -179,14 +179,15 @@ void PruningSceneIndex::_PrimsAdded( { HdSceneIndexObserver::AddedPrimEntries editedEntries; for (const auto& addedEntry : entries) { - // We're executing the full loop for each filter, so too many notification sent for (auto& filterEntry : _prunedPathsByFilter) { - if (_PrunePrim(GetInputSceneIndex()->GetPrim(addedEntry.primPath), filterEntry.first)) { + if (_PrunePrim(addedEntry.primPath, GetInputSceneIndex()->GetPrim(addedEntry.primPath), filterEntry.first)) { filterEntry.second.emplace(addedEntry.primPath); - } else { - editedEntries.emplace_back(addedEntry); + _filtersByPrunedPath[addedEntry.primPath].emplace(filterEntry.first); } } + if (!_IsAncestorPrunedInclusive(addedEntry.primPath)) { + editedEntries.emplace_back(addedEntry); + } } if (!editedEntries.empty()) { _SendPrimsAdded(editedEntries); @@ -199,14 +200,15 @@ void PruningSceneIndex::_PrimsRemoved( { HdSceneIndexObserver::RemovedPrimEntries editedEntries; for (const auto& removedEntry : entries) { - // We're executing the full loop for each filter, so too many notification sent for (auto& filterEntry : _prunedPathsByFilter) { if (filterEntry.second.find(removedEntry.primPath) != filterEntry.second.end()) { filterEntry.second.erase(removedEntry.primPath); - } else { - editedEntries.emplace_back(removedEntry); } } + _filtersByPrunedPath.erase(removedEntry.primPath); + if (!_IsAncestorPrunedInclusive(removedEntry.primPath)) { + editedEntries.emplace_back(removedEntry); + } } if (!editedEntries.empty()) { _SendPrimsRemoved(editedEntries); @@ -222,20 +224,34 @@ void PruningSceneIndex::_PrimsDirtied( HdSceneIndexObserver::AddedPrimEntries addedEntries; for (const auto& dirtiedEntry : entries) { - // We're executing the full loop for each filter, so too many notification sent - for (const auto& filterEntry : _prunedPathsByFilter) { - HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); - - bool isPruned = filterEntry.second.find(dirtiedEntry.primPath) != filterEntry.second.end(); - bool shouldBePruned = _PrunePrim(dirtiedPrim, filterEntry.first); + bool wasInitiallyPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); + HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); + for (auto& filterEntry : _prunedPathsByFilter) { + bool shouldBePruned = _PrunePrim(dirtiedEntry.primPath, dirtiedPrim, filterEntry.first); - if (!isPruned && shouldBePruned) { - removedEntries.emplace_back(dirtiedEntry.primPath); - } else if (isPruned && !shouldBePruned) { - addedEntries.emplace_back(dirtiedEntry.primPath, dirtiedPrim.primType); + if (shouldBePruned) { + filterEntry.second.emplace(dirtiedEntry.primPath); + _filtersByPrunedPath[dirtiedEntry.primPath].emplace(filterEntry.first); } else { - editedEntries.emplace_back(dirtiedEntry); + if (filterEntry.second.find(dirtiedEntry.primPath) != filterEntry.second.end()) { + filterEntry.second.erase(dirtiedEntry.primPath); + } + if (_filtersByPrunedPath.find(dirtiedEntry.primPath) != _filtersByPrunedPath.end()) { + _filtersByPrunedPath[dirtiedEntry.primPath].erase(filterEntry.first); + if (_filtersByPrunedPath[dirtiedEntry.primPath].empty()) { + _filtersByPrunedPath.erase(dirtiedEntry.primPath); + } + } } + + } + bool isNowPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); + if (!wasInitiallyPruned && isNowPruned) { + removedEntries.emplace_back(dirtiedEntry.primPath); + } else if (wasInitiallyPruned && !isNowPruned) { + addedEntries.emplace_back(dirtiedEntry.primPath, dirtiedPrim.primType); + } else { + editedEntries.emplace_back(dirtiedEntry); } } From 0a29f77d8cd37a2f342f7995cea715ebc44f8a9c Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 12:33:15 -0400 Subject: [PATCH 11/42] HYDRA-1098 : Refactor common code --- .../sceneIndex/fvpPruningSceneIndex.cpp | 31 +++++++++---------- 1 file changed, 15 insertions(+), 16 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 572afe156..84dc08227 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -39,6 +39,19 @@ PXR_NAMESPACE_USING_DIRECTIVE namespace { +template +bool _HasAncestorInclusiveInContainer(const SdfPath& path, const Container& pathsContainer) { + SdfPath currPath = path; + while (!currPath.IsEmpty() && !currPath.IsAbsoluteRootPath()) { + if (pathsContainer.find(currPath) != pathsContainer.end()) { + return true; + } else { + currPath = currPath.GetParentPath(); + } + } + return false; +} + } // namespace namespace FVP_NS_DEF { @@ -61,13 +74,7 @@ void PruningSceneIndex::AddExcludedSceneRoot(const PXR_NS::SdfPath& sceneRoot) bool PruningSceneIndex::_IsExcluded(const PXR_NS::SdfPath& primPath) const { - // TODO : Use parent-based approach - for (const auto& excludedSceneRoot : _excludedSceneRoots) { - if (primPath.HasPrefix(excludedSceneRoot)) { - return true; - } - } - return false; + return _HasAncestorInclusiveInContainer(primPath, _excludedSceneRoots); } bool PruningSceneIndex::_PrunePrim(const SdfPath& primPath, const HdSceneIndexPrim& prim, const TfToken& pruningToken) const @@ -83,15 +90,7 @@ bool PruningSceneIndex::_PrunePrim(const SdfPath& primPath, const HdSceneIndexPr bool PruningSceneIndex::_IsAncestorPrunedInclusive(const SdfPath& primPath) const { - SdfPath currPath = primPath; - while (!currPath.IsEmpty() && !currPath.IsAbsoluteRootPath()) { - if (_filtersByPrunedPath.find(currPath) != _filtersByPrunedPath.end()) { - return true; - } else { - currPath = currPath.GetParentPath(); - } - } - return false; + return _HasAncestorInclusiveInContainer(primPath, _filtersByPrunedPath); } HdSceneIndexPrim PruningSceneIndex::GetPrim(const SdfPath& primPath) const From e05f9dfc9bfac3026e3f80e63f80eaf7367d7334 Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 12:56:46 -0400 Subject: [PATCH 12/42] HYDRA-1098 : Refactor common code --- .../sceneIndex/fvpPruningSceneIndex.cpp | 48 ++++++++++--------- .../sceneIndex/fvpPruningSceneIndex.h | 10 +++- 2 files changed, 34 insertions(+), 24 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 84dc08227..4cccb528d 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -172,6 +172,26 @@ bool PruningSceneIndex::DisableFilter(const TfToken& pruningToken) return true; } +void PruningSceneIndex::_InsertEntry(const PXR_NS::SdfPath& primPath, const PXR_NS::TfToken& pruningToken) +{ + _prunedPathsByFilter[pruningToken].emplace(primPath); + _filtersByPrunedPath[primPath].emplace(pruningToken); +} + +void PruningSceneIndex::_RemoveEntry(const PXR_NS::SdfPath& primPath, const PXR_NS::TfToken& pruningToken) +{ + if (_prunedPathsByFilter.find(pruningToken) != _prunedPathsByFilter.end()) { + _prunedPathsByFilter[pruningToken].erase(primPath); + } + + if (_filtersByPrunedPath.find(primPath) != _filtersByPrunedPath.end()) { + _filtersByPrunedPath[primPath].erase(pruningToken); + if (_filtersByPrunedPath[primPath].empty()) { + _filtersByPrunedPath.erase(primPath); + } + } +} + void PruningSceneIndex::_PrimsAdded( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::AddedPrimEntries &entries) @@ -180,8 +200,7 @@ void PruningSceneIndex::_PrimsAdded( for (const auto& addedEntry : entries) { for (auto& filterEntry : _prunedPathsByFilter) { if (_PrunePrim(addedEntry.primPath, GetInputSceneIndex()->GetPrim(addedEntry.primPath), filterEntry.first)) { - filterEntry.second.emplace(addedEntry.primPath); - _filtersByPrunedPath[addedEntry.primPath].emplace(filterEntry.first); + _InsertEntry(addedEntry.primPath, filterEntry.first); } } if (!_IsAncestorPrunedInclusive(addedEntry.primPath)) { @@ -200,11 +219,8 @@ void PruningSceneIndex::_PrimsRemoved( HdSceneIndexObserver::RemovedPrimEntries editedEntries; for (const auto& removedEntry : entries) { for (auto& filterEntry : _prunedPathsByFilter) { - if (filterEntry.second.find(removedEntry.primPath) != filterEntry.second.end()) { - filterEntry.second.erase(removedEntry.primPath); - } + _RemoveEntry(removedEntry.primPath, filterEntry.first); } - _filtersByPrunedPath.erase(removedEntry.primPath); if (!_IsAncestorPrunedInclusive(removedEntry.primPath)) { editedEntries.emplace_back(removedEntry); } @@ -218,31 +234,19 @@ void PruningSceneIndex::_PrimsDirtied( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) { - HdSceneIndexObserver::DirtiedPrimEntries editedEntries; HdSceneIndexObserver::RemovedPrimEntries removedEntries; HdSceneIndexObserver::AddedPrimEntries addedEntries; + HdSceneIndexObserver::DirtiedPrimEntries editedEntries; for (const auto& dirtiedEntry : entries) { bool wasInitiallyPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); for (auto& filterEntry : _prunedPathsByFilter) { - bool shouldBePruned = _PrunePrim(dirtiedEntry.primPath, dirtiedPrim, filterEntry.first); - - if (shouldBePruned) { - filterEntry.second.emplace(dirtiedEntry.primPath); - _filtersByPrunedPath[dirtiedEntry.primPath].emplace(filterEntry.first); + if (_PrunePrim(dirtiedEntry.primPath, dirtiedPrim, filterEntry.first)) { + _InsertEntry(dirtiedEntry.primPath, filterEntry.first); } else { - if (filterEntry.second.find(dirtiedEntry.primPath) != filterEntry.second.end()) { - filterEntry.second.erase(dirtiedEntry.primPath); - } - if (_filtersByPrunedPath.find(dirtiedEntry.primPath) != _filtersByPrunedPath.end()) { - _filtersByPrunedPath[dirtiedEntry.primPath].erase(filterEntry.first); - if (_filtersByPrunedPath[dirtiedEntry.primPath].empty()) { - _filtersByPrunedPath.erase(dirtiedEntry.primPath); - } - } + _RemoveEntry(dirtiedEntry.primPath, filterEntry.first); } - } bool isNowPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); if (!wasInitiallyPruned && isNowPruned) { diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index f41efaf04..2c7f1bf69 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -70,10 +70,10 @@ class PruningSceneIndex : PXR_NS::SdfPathVector GetChildPrimPaths(const PXR_NS::SdfPath& primPath) const override; FVP_API - bool EnableFilter(const PXR_NS::TfToken& filterToken); + bool EnableFilter(const PXR_NS::TfToken& pruningToken); FVP_API - bool DisableFilter(const PXR_NS::TfToken& filterToken); + bool DisableFilter(const PXR_NS::TfToken& pruningToken); FVP_API void AddExcludedSceneRoot(const PXR_NS::SdfPath& sceneRoot); @@ -104,6 +104,12 @@ class PruningSceneIndex : void _PrimsDirtied( const PXR_NS::HdSceneIndexBase &sender, const PXR_NS::HdSceneIndexObserver::DirtiedPrimEntries &entries) override; + + FVP_API + void _InsertEntry(const PXR_NS::SdfPath& primPath, const PXR_NS::TfToken& pruningToken); + + FVP_API + void _RemoveEntry(const PXR_NS::SdfPath& primPath, const PXR_NS::TfToken& pruningToken); FVP_API bool _IsExcluded(const PXR_NS::SdfPath& primPath) const; From 4b543d20417e589bf2fa9e25ebd52365e52ff411 Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:01:15 -0400 Subject: [PATCH 13/42] HYDRA-1098 : Provide accessor for active filters --- .../sceneIndex/fvpPruningSceneIndex.cpp | 27 ++++++++++++------- .../sceneIndex/fvpPruningSceneIndex.h | 3 +++ 2 files changed, 21 insertions(+), 9 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 4cccb528d..9154666da 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -172,6 +172,15 @@ bool PruningSceneIndex::DisableFilter(const TfToken& pruningToken) return true; } +std::set PruningSceneIndex::GetActiveFilters() +{ + std::set pruningTokens; + for (const auto& filterEntry : _prunedPathsByFilter) { + pruningTokens.emplace(filterEntry.first); + } + return pruningTokens; +} + void PruningSceneIndex::_InsertEntry(const PXR_NS::SdfPath& primPath, const PXR_NS::TfToken& pruningToken) { _prunedPathsByFilter[pruningToken].emplace(primPath); @@ -198,9 +207,9 @@ void PruningSceneIndex::_PrimsAdded( { HdSceneIndexObserver::AddedPrimEntries editedEntries; for (const auto& addedEntry : entries) { - for (auto& filterEntry : _prunedPathsByFilter) { - if (_PrunePrim(addedEntry.primPath, GetInputSceneIndex()->GetPrim(addedEntry.primPath), filterEntry.first)) { - _InsertEntry(addedEntry.primPath, filterEntry.first); + for (const auto& pruningToken : GetActiveFilters()) { + if (_PrunePrim(addedEntry.primPath, GetInputSceneIndex()->GetPrim(addedEntry.primPath), pruningToken)) { + _InsertEntry(addedEntry.primPath, pruningToken); } } if (!_IsAncestorPrunedInclusive(addedEntry.primPath)) { @@ -218,8 +227,8 @@ void PruningSceneIndex::_PrimsRemoved( { HdSceneIndexObserver::RemovedPrimEntries editedEntries; for (const auto& removedEntry : entries) { - for (auto& filterEntry : _prunedPathsByFilter) { - _RemoveEntry(removedEntry.primPath, filterEntry.first); + for (const auto& pruningToken : GetActiveFilters()) { + _RemoveEntry(removedEntry.primPath, pruningToken); } if (!_IsAncestorPrunedInclusive(removedEntry.primPath)) { editedEntries.emplace_back(removedEntry); @@ -241,11 +250,11 @@ void PruningSceneIndex::_PrimsDirtied( for (const auto& dirtiedEntry : entries) { bool wasInitiallyPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); - for (auto& filterEntry : _prunedPathsByFilter) { - if (_PrunePrim(dirtiedEntry.primPath, dirtiedPrim, filterEntry.first)) { - _InsertEntry(dirtiedEntry.primPath, filterEntry.first); + for (const auto& pruningToken : GetActiveFilters()) { + if (_PrunePrim(dirtiedEntry.primPath, dirtiedPrim, pruningToken)) { + _InsertEntry(dirtiedEntry.primPath, pruningToken); } else { - _RemoveEntry(dirtiedEntry.primPath, filterEntry.first); + _RemoveEntry(dirtiedEntry.primPath, pruningToken); } } bool isNowPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 2c7f1bf69..417bd88ce 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -75,6 +75,9 @@ class PruningSceneIndex : FVP_API bool DisableFilter(const PXR_NS::TfToken& pruningToken); + FVP_API + std::set GetActiveFilters(); + FVP_API void AddExcludedSceneRoot(const PXR_NS::SdfPath& sceneRoot); From 34e68cd990837e729433b54b0898602ec4b2e262 Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:01:51 -0400 Subject: [PATCH 14/42] HYDRA-1098 : Adjust comment --- lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 417bd88ce..29b4fe71f 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -123,7 +123,7 @@ class PruningSceneIndex : FVP_API bool _IsAncestorPrunedInclusive(const PXR_NS::SdfPath& primPath) const; - // Maps a filtering token to the set of prim paths that have been pruned out by this token + // Maps a pruning token to the set of prim paths that have been pruned out by this token std::map _prunedPathsByFilter; std::map> _filtersByPrunedPath; From aa23f843a219152a106e3866cafcac5b49f88555 Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:05:52 -0400 Subject: [PATCH 15/42] HYDRA-1098 : Legibility improvements --- .../sceneIndex/fvpPruningSceneIndex.cpp | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 9154666da..b8887f34d 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -206,16 +206,19 @@ void PruningSceneIndex::_PrimsAdded( const PXR_NS::HdSceneIndexObserver::AddedPrimEntries &entries) { HdSceneIndexObserver::AddedPrimEntries editedEntries; + for (const auto& addedEntry : entries) { for (const auto& pruningToken : GetActiveFilters()) { if (_PrunePrim(addedEntry.primPath, GetInputSceneIndex()->GetPrim(addedEntry.primPath), pruningToken)) { _InsertEntry(addedEntry.primPath, pruningToken); } } + if (!_IsAncestorPrunedInclusive(addedEntry.primPath)) { editedEntries.emplace_back(addedEntry); } } + if (!editedEntries.empty()) { _SendPrimsAdded(editedEntries); } @@ -226,14 +229,17 @@ void PruningSceneIndex::_PrimsRemoved( const PXR_NS::HdSceneIndexObserver::RemovedPrimEntries &entries) { HdSceneIndexObserver::RemovedPrimEntries editedEntries; + for (const auto& removedEntry : entries) { - for (const auto& pruningToken : GetActiveFilters()) { - _RemoveEntry(removedEntry.primPath, pruningToken); - } if (!_IsAncestorPrunedInclusive(removedEntry.primPath)) { editedEntries.emplace_back(removedEntry); + } else { + for (const auto& pruningToken : GetActiveFilters()) { + _RemoveEntry(removedEntry.primPath, pruningToken); + } } } + if (!editedEntries.empty()) { _SendPrimsRemoved(editedEntries); } @@ -249,7 +255,9 @@ void PruningSceneIndex::_PrimsDirtied( for (const auto& dirtiedEntry : entries) { bool wasInitiallyPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); + HdSceneIndexPrim dirtiedPrim = GetInputSceneIndex()->GetPrim(dirtiedEntry.primPath); + for (const auto& pruningToken : GetActiveFilters()) { if (_PrunePrim(dirtiedEntry.primPath, dirtiedPrim, pruningToken)) { _InsertEntry(dirtiedEntry.primPath, pruningToken); @@ -257,7 +265,9 @@ void PruningSceneIndex::_PrimsDirtied( _RemoveEntry(dirtiedEntry.primPath, pruningToken); } } + bool isNowPruned = _IsAncestorPrunedInclusive(dirtiedEntry.primPath); + if (!wasInitiallyPruned && isNowPruned) { removedEntries.emplace_back(dirtiedEntry.primPath); } else if (wasInitiallyPruned && !isNowPruned) { From d313b1b91cd29cdb480c39da378a711988f3c96f Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:15:05 -0400 Subject: [PATCH 16/42] HYDRA-1098 : Minor touchups for consistency --- .../sceneIndex/fvpPruningSceneIndex.cpp | 24 +++++++++---------- 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index b8887f34d..b66d45aee 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -120,6 +120,9 @@ bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) return false; } + // Enable the filter + _prunedPathsByFilter[pruningToken] = SdfPathSet(); + HdSceneIndexObserver::RemovedPrimEntries prunedPrims; for (const SdfPath& primPath : HdSceneIndexPrimView(GetInputSceneIndex())) { @@ -128,8 +131,7 @@ bool PruningSceneIndex::EnableFilter(const TfToken& pruningToken) // Only send notification if it was not already pruned out, directly or indirectly prunedPrims.emplace_back(primPath); } - _prunedPathsByFilter[pruningToken].emplace(primPath); - _filtersByPrunedPath[primPath].emplace(pruningToken); + _InsertEntry(primPath, pruningToken); } } @@ -147,24 +149,20 @@ bool PruningSceneIndex::DisableFilter(const TfToken& pruningToken) return false; } - SdfPathSet prunedPaths = _prunedPathsByFilter[pruningToken]; - - _prunedPathsByFilter.erase(pruningToken); - for (const auto& primPath : prunedPaths) { - _filtersByPrunedPath[primPath].erase(pruningToken); - if (_filtersByPrunedPath[primPath].empty()) { - _filtersByPrunedPath.erase(primPath); - } - } - HdSceneIndexObserver::AddedPrimEntries unprunedPrims; + + SdfPathSet prunedPaths = _prunedPathsByFilter[pruningToken]; for (const auto& primPath : prunedPaths) { - // If it's still pruned, avoid sending a notification + _RemoveEntry(primPath, pruningToken); if (!_IsAncestorPrunedInclusive(primPath)) { + // Only send notification if it was pruned and no longer is unprunedPrims.emplace_back(primPath, GetInputSceneIndex()->GetPrim(primPath).primType); } } + // Disable the filter + _prunedPathsByFilter.erase(pruningToken); + if (!unprunedPrims.empty()) { _SendPrimsAdded(unprunedPrims); } From 88c4bbc5a8f51224d6c15a759c06e56a9c1eaf6d Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:18:56 -0400 Subject: [PATCH 17/42] HYDRA-1098 : Add filtering tokens --- lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 29b4fe71f..8e114da69 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -33,10 +33,16 @@ PXR_NAMESPACE_OPEN_SCOPE // clang-format off #define FVP_PRUNING_TOKENS \ - (mesh) \ - (sphere) \ - (cone) \ - (cube) + (meshes) \ + (capsules) \ + (cones) \ + (cubes) \ + (cylinders) \ + (spheres) \ + (nurbsPatches) \ + (nurbsCurves) \ + (lightGizmos) \ + (cameraGizmos) // clang-format on TF_DECLARE_PUBLIC_TOKENS(FvpPruningTokens, FVP_API, FVP_PRUNING_TOKENS); From cb21f9ad001d9511e94b766c066adcb194ec25d5 Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:19:25 -0400 Subject: [PATCH 18/42] HYDRA-1098 : Remove unimplementable tokens for now --- lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h | 2 -- 1 file changed, 2 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 8e114da69..5d59759e2 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -41,8 +41,6 @@ PXR_NAMESPACE_OPEN_SCOPE (spheres) \ (nurbsPatches) \ (nurbsCurves) \ - (lightGizmos) \ - (cameraGizmos) // clang-format on TF_DECLARE_PUBLIC_TOKENS(FvpPruningTokens, FVP_API, FVP_PRUNING_TOKENS); From 239e0feb3a016a4e9cc58674baf23f298275a1cf Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:30:33 -0400 Subject: [PATCH 19/42] HYDRA-1098 : Implement various filter handlers --- .../sceneIndex/fvpPruningSceneIndex.cpp | 57 +++++++++++++++++-- .../sceneIndex/fvpPruningSceneIndex.h | 2 +- 2 files changed, 54 insertions(+), 5 deletions(-) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index b66d45aee..87fcf5452 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -27,6 +27,7 @@ #include #include +#include #include PXR_NAMESPACE_OPEN_SCOPE @@ -52,6 +53,46 @@ bool _HasAncestorInclusiveInContainer(const SdfPath& path, const Container& path return false; } +bool _MeshesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->mesh; +} + +bool _CapsulesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->capsule; +} + +bool _ConesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->cone; +} + +bool _CubesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->cube; +} + +bool _CylindersFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->cylinder; +} + +bool _SpheresFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->sphere; +} + +bool _NurbsCurvesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->nurbsCurves; +} + +bool _NurbsPatchesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) +{ + return prim.primType == HdPrimTypeTokens->nurbsPatch; +} + } // namespace namespace FVP_NS_DEF { @@ -82,10 +123,18 @@ bool PruningSceneIndex::_PrunePrim(const SdfPath& primPath, const HdSceneIndexPr if (_IsExcluded(primPath)) { return false; } - if (pruningToken == FvpPruningTokens->mesh) { - return prim.primType == HdPrimTypeTokens->mesh; - } - return false; + using FilterHandler = std::function; + static std::map filterHandlers = { + { FvpPruningTokens->meshes, _MeshesFilterHandler }, + { FvpPruningTokens->capsules, _CapsulesFilterHandler }, + { FvpPruningTokens->cones, _ConesFilterHandler }, + { FvpPruningTokens->cubes, _CubesFilterHandler }, + { FvpPruningTokens->cylinders, _CylindersFilterHandler }, + { FvpPruningTokens->spheres, _SpheresFilterHandler }, + { FvpPruningTokens->nurbsCurves, _NurbsCurvesFilterHandler }, + { FvpPruningTokens->nurbsPatches, _NurbsPatchesFilterHandler } + }; + return filterHandlers[pruningToken](GetInputSceneIndex(), primPath, prim); } bool PruningSceneIndex::_IsAncestorPrunedInclusive(const SdfPath& primPath) const diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h index 5d59759e2..a534d0882 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.h @@ -39,8 +39,8 @@ PXR_NAMESPACE_OPEN_SCOPE (cubes) \ (cylinders) \ (spheres) \ - (nurbsPatches) \ (nurbsCurves) \ + (nurbsPatches) \ // clang-format on TF_DECLARE_PUBLIC_TOKENS(FvpPruningTokens, FVP_API, FVP_PRUNING_TOKENS); From d9b3a65bcef84044c368461eb2b8a0effbc22cad Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 13:41:56 -0400 Subject: [PATCH 20/42] HYDRA-1098 : Plug Maya filters to Fvp pruning scene index --- lib/mayaHydra/mayaPlugin/renderOverride.cpp | 38 +++++++++++++++++---- 1 file changed, 32 insertions(+), 6 deletions(-) diff --git a/lib/mayaHydra/mayaPlugin/renderOverride.cpp b/lib/mayaHydra/mayaPlugin/renderOverride.cpp index 62f72dc7b..6d40150ff 100644 --- a/lib/mayaHydra/mayaPlugin/renderOverride.cpp +++ b/lib/mayaHydra/mayaPlugin/renderOverride.cpp @@ -803,12 +803,38 @@ MStatus MtohRenderOverride::Render( _displayStyleSceneIndex->SetRefineLevel({true, delegateParams.refineLevel}); } - auto objectExclusions = framecontext->objectTypeExclusions(); - if (objectExclusions & MHWRender::MFrameContext::kExcludeMeshes) { - _pruningSceneIndex->EnableFilter(FvpPruningTokens->mesh); - } else { - _pruningSceneIndex->DisableFilter(FvpPruningTokens->mesh); - } + // Update "Show" menu filters + { + auto objectExclusions = framecontext->objectTypeExclusions(); + + TfTokenVector polygonFilters = { + FvpPruningTokens->meshes, + FvpPruningTokens->capsules, + FvpPruningTokens->cones, + FvpPruningTokens->cubes, + FvpPruningTokens->cylinders, + FvpPruningTokens->spheres + }; + for (const auto& polygonFilter : polygonFilters) { + if (objectExclusions & MHWRender::MFrameContext::kExcludeMeshes) { + _pruningSceneIndex->EnableFilter(polygonFilter); + } else { + _pruningSceneIndex->DisableFilter(polygonFilter); + } + } + + if (objectExclusions & MHWRender::MFrameContext::kExcludeNurbsCurves) { + _pruningSceneIndex->EnableFilter(FvpPruningTokens->nurbsCurves); + } else { + _pruningSceneIndex->DisableFilter(FvpPruningTokens->nurbsCurves); + } + + if (objectExclusions & MHWRender::MFrameContext::kExcludeNurbsSurfaces) { + _pruningSceneIndex->EnableFilter(FvpPruningTokens->nurbsPatches); + } else { + _pruningSceneIndex->DisableFilter(FvpPruningTokens->nurbsPatches); + } + } // Toggle textures in the material network const unsigned int currentDisplayMode = drawContext.getDisplayStyle(); From 36a1013a2b6ccd6a31fda22b39554f63de71f2ca Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 14:35:00 -0400 Subject: [PATCH 21/42] HYDRA-1098 : Restructure Maya plugging code --- lib/mayaHydra/mayaPlugin/renderOverride.cpp | 33 ++++++++++----------- 1 file changed, 15 insertions(+), 18 deletions(-) diff --git a/lib/mayaHydra/mayaPlugin/renderOverride.cpp b/lib/mayaHydra/mayaPlugin/renderOverride.cpp index 6d40150ff..2b038187a 100644 --- a/lib/mayaHydra/mayaPlugin/renderOverride.cpp +++ b/lib/mayaHydra/mayaPlugin/renderOverride.cpp @@ -114,6 +114,7 @@ #include #include #include +#include #include #include @@ -807,7 +808,7 @@ MStatus MtohRenderOverride::Render( { auto objectExclusions = framecontext->objectTypeExclusions(); - TfTokenVector polygonFilters = { + static TfTokenVector polygonFilters = { FvpPruningTokens->meshes, FvpPruningTokens->capsules, FvpPruningTokens->cones, @@ -815,24 +816,20 @@ MStatus MtohRenderOverride::Render( FvpPruningTokens->cylinders, FvpPruningTokens->spheres }; - for (const auto& polygonFilter : polygonFilters) { - if (objectExclusions & MHWRender::MFrameContext::kExcludeMeshes) { - _pruningSceneIndex->EnableFilter(polygonFilter); - } else { - _pruningSceneIndex->DisableFilter(polygonFilter); - } - } - - if (objectExclusions & MHWRender::MFrameContext::kExcludeNurbsCurves) { - _pruningSceneIndex->EnableFilter(FvpPruningTokens->nurbsCurves); - } else { - _pruningSceneIndex->DisableFilter(FvpPruningTokens->nurbsCurves); - } + static std::map mayaFiltersToFvpPruningTokens = { + { MHWRender::MFrameContext::kExcludeMeshes, polygonFilters }, + { MHWRender::MFrameContext::kExcludeNurbsCurves, {FvpPruningTokens->nurbsCurves} }, + { MHWRender::MFrameContext::kExcludeNurbsSurfaces, {FvpPruningTokens->nurbsPatches} } + }; - if (objectExclusions & MHWRender::MFrameContext::kExcludeNurbsSurfaces) { - _pruningSceneIndex->EnableFilter(FvpPruningTokens->nurbsPatches); - } else { - _pruningSceneIndex->DisableFilter(FvpPruningTokens->nurbsPatches); + for (auto [mayaFilter, fvpPruningTokens] : mayaFiltersToFvpPruningTokens) { + for (const auto& fvpPruningToken : fvpPruningTokens) { + if (objectExclusions & mayaFilter) { + _pruningSceneIndex->EnableFilter(fvpPruningToken); + } else { + _pruningSceneIndex->DisableFilter(fvpPruningToken); + } + } } } From f8a0f70f105e3e4c2f0ac7f69daccc781b27258d Mon Sep 17 00:00:00 2001 From: debloip Date: Fri, 11 Oct 2024 15:33:03 -0400 Subject: [PATCH 22/42] HYDRA-1098 : Add comment --- lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp index 87fcf5452..6e713f53f 100644 --- a/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp +++ b/lib/flowViewport/sceneIndex/fvpPruningSceneIndex.cpp @@ -55,6 +55,8 @@ bool _HasAncestorInclusiveInContainer(const SdfPath& path, const Container& path bool _MeshesFilterHandler(const HdSceneIndexBaseRefPtr& sceneIndex, const SdfPath& primPath, const HdSceneIndexPrim& prim) { + // Currently we just flat out remove any prim with a mesh type. If we were to add extra checks to make sure this is not + // a mesh prim that serves another purpose, we would add them here. return prim.primType == HdPrimTypeTokens->mesh; } From 1fd1afba37b69d617eb1379024df2935eec8ef09 Mon Sep 17 00:00:00 2001 From: debloip Date: Tue, 15 Oct 2024 15:51:32 -0400 Subject: [PATCH 23/42] HYDRA-1098 : Add filter tests with USD data for polygon and nurbs curve filters --- .../nurbsCurves_USD_excluded.png | Bin 0 -> 1563 bytes .../nurbsCurves_USD_included.png | Bin 0 -> 5176 bytes .../polygons_USD_excluded.png | Bin 0 -> 1563 bytes .../polygons_USD_included.png | Bin 0 -> 13820 bytes .../render/mayaToHydra/testViewportFilters.py | 63 ++++++++++++++++++ 5 files changed, 63 insertions(+) create mode 100644 test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsCurves_USD_excluded.png create mode 100644 test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsCurves_USD_included.png create mode 100644 test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/polygons_USD_excluded.png create mode 100644 test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/polygons_USD_included.png diff --git a/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsCurves_USD_excluded.png b/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsCurves_USD_excluded.png new file mode 100644 index 0000000000000000000000000000000000000000..dbedef32fd8f3b0a32f32b3420710101c9e1097e GIT binary patch literal 1563 zcmeAS@N?(olHy`uVBq!ia0y~yV4MKL9Be?5hW%z|fD~V9glC$sFM}44%>l$9a4C2) zkmSsFb1Me(LBuVsZRZ#mSZ8{=IEGZrd3)87mqAhBz=6jl>*{4Q7RWmpEncvH-OQg1 z53bZ(Gc=e>axio@GE9&drAC8bG!=|ygwe8q#>HXI_W%}?wyzd{fMqrAGM&NG)z4*} HQ$iB}d4q$r literal 0 HcmV?d00001 diff --git a/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsCurves_USD_included.png b/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsCurves_USD_included.png new file mode 100644 index 0000000000000000000000000000000000000000..ddd8f44330797b25ee941c92554051223826331b GIT binary patch literal 5176 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 literal 0 HcmV?d00001 diff --git a/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/polygons_USD_excluded.png b/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/polygons_USD_excluded.png new file mode 100644 index 0000000000000000000000000000000000000000..dbedef32fd8f3b0a32f32b3420710101c9e1097e GIT binary patch literal 1563 zcmeAS@N?(olHy`uVBq!ia0y~yV4MKL9Be?5hW%z|fD~V9glC$sFM}44%>l$9a4C2) zkmSsFb1Me(LBuVsZRZ#mSZ8{=IEGZrd3)87mqAhBz=6jl>*{4Q7RWmpEncvH-OQg1 z53bZ(Gc=e>axio@GE9&drAC8bG!=|ygwe8q#>HXI_W%}?wyzd{fMqrAGM&NG)z4*} HQ$iB}d4q$r literal 0 HcmV?d00001 diff --git a/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/polygons_USD_included.png b/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/polygons_USD_included.png new file mode 100644 index 0000000000000000000000000000000000000000..9f33a504754ea0de12f2d03b2dc115545a3acf9a GIT binary patch literal 13820 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 z�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 literal 0 HcmV?d00001 diff --git a/test/lib/mayaUsd/render/mayaToHydra/testViewportFilters.py b/test/lib/mayaUsd/render/mayaToHydra/testViewportFilters.py index a09780cfa..524127119 100644 --- a/test/lib/mayaUsd/render/mayaToHydra/testViewportFilters.py +++ b/test/lib/mayaUsd/render/mayaToHydra/testViewportFilters.py @@ -14,8 +14,13 @@ # import maya.cmds as cmds import fixturesUtils +import functools +import mayaUsd_createStageWithNewLayer +import mayaUsd.lib import mayaUtils import mtohUtils +import testUtils +import usdUtils # Note : the order of the bit flags does not correspond to the order # of the options in the "Show" -> "Viewport" UI. @@ -103,6 +108,8 @@ def checkFilter(self, name, exclusionMask, cameraDistance=15): # Restore old mask cmds.modelEditor(activeViewport, edit=True, excludeObjectMask=oldMask) + # --- Maya data --- + # TODO : Construction planes (not working in Hydra as of 2024-05-03) def test_Dimensions(self): @@ -222,5 +229,61 @@ def test_Strokes(self): # TODO : Texture Placements (not working in Hydra as of 2024-05-03) + # --- USD data --- + + def test_UsdPolygons(self): + from pxr import UsdGeom + + stagePath = mayaUsd_createStageWithNewLayer.createStageWithNewLayer() + stage = mayaUsd.lib.GetPrim(stagePath).GetStage() + + capsuleName = "UsdCapsule" + capsuleXform = UsdGeom.Xform.Define(stage, "/" + capsuleName + "Xform") + capsuleXform.AddTranslateOp().Set(value=(6, 0, 0)) + UsdGeom.Capsule.Define(stage, str(capsuleXform.GetPath()) + "/" + capsuleName) + cmds.select(clear=True) + + coneName = "UsdCone" + coneXform = UsdGeom.Xform.Define(stage, "/" + coneName + "Xform") + coneXform.AddTranslateOp().Set(value=(2, 0, -2)) + UsdGeom.Cone.Define(stage, str(coneXform.GetPath()) + "/" + coneName) + cmds.select(clear=True) + + cubeName = "UsdCube" + cubeXform = UsdGeom.Xform.Define(stage, "/" + cubeName + "Xform") + cubeXform.AddTranslateOp().Set(value=(-3, 0, -3)) + UsdGeom.Cube.Define(stage, str(cubeXform.GetPath()) + "/" + cubeName) + cmds.select(clear=True) + + cylinderName = "UsdCylinder" + cylinderXform = UsdGeom.Xform.Define(stage, "/" + cylinderName + "Xform") + cylinderXform.AddTranslateOp().Set(value=(-2, 0, 2)) + UsdGeom.Cylinder.Define(stage, str(cylinderXform.GetPath()) + "/" + cylinderName) + cmds.select(clear=True) + + sphereName = "UsdSphere" + sphereXform = UsdGeom.Xform.Define(stage, "/" + sphereName + "Xform") + sphereXform.AddTranslateOp().Set(value=(0, 0, 6)) + UsdGeom.Sphere.Define(stage, str(sphereXform.GetPath()) + "/" + sphereName) + cmds.select(clear=True) + + cmds.polyTorus() + cmds.move(3, 0, 3) + cmds.select(clear=True) + + cmds.refresh() + self.checkFilter("polygons_USD", kExcludeMeshes, 10) + + def test_UsdNurbsCurves(self): + def createUsdCurve(stagePath): + circleName = cmds.circle() + usdCircleName = mayaUsd.lib.PrimUpdaterManager.duplicate(cmds.ls(circleName[0], long=True)[0], stagePath) + cmds.select(circleName) + cmds.delete() + cmds.select(usdCircleName) + stagePath = mayaUsd_createStageWithNewLayer.createStageWithNewLayer() + self.stackInstances(functools.partial(createUsdCurve, stagePath), 50, [0, 0, 0.005]) + self.checkFilter("nurbsCurves_USD", kExcludeNurbsCurves, 2) + if __name__ == '__main__': fixturesUtils.runTests(globals()) From 751dece8b5e52d64cd38b58b29414238d9c5d15d Mon Sep 17 00:00:00 2001 From: debloip Date: Tue, 15 Oct 2024 16:12:29 -0400 Subject: [PATCH 24/42] HYDRA-1098 : Add filter test with USD data for nurbs patches filter --- .../nurbsPatches_USD_excluded.png | Bin 0 -> 1563 bytes .../nurbsPatches_USD_included.png | Bin 0 -> 20117 bytes .../render/mayaToHydra/testViewportFilters.py | 13 +++++++++++-- 3 files changed, 11 insertions(+), 2 deletions(-) create mode 100644 test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsPatches_USD_excluded.png create mode 100644 test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsPatches_USD_included.png diff --git a/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsPatches_USD_excluded.png b/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsPatches_USD_excluded.png new file mode 100644 index 0000000000000000000000000000000000000000..dbedef32fd8f3b0a32f32b3420710101c9e1097e GIT binary patch literal 1563 zcmeAS@N?(olHy`uVBq!ia0y~yV4MKL9Be?5hW%z|fD~V9glC$sFM}44%>l$9a4C2) zkmSsFb1Me(LBuVsZRZ#mSZ8{=IEGZrd3)87mqAhBz=6jl>*{4Q7RWmpEncvH-OQg1 z53bZ(Gc=e>axio@GE9&drAC8bG!=|ygwe8q#>HXI_W%}?wyzd{fMqrAGM&NG)z4*} HQ$iB}d4q$r literal 0 HcmV?d00001 diff --git a/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsPatches_USD_included.png b/test/lib/mayaUsd/render/mayaToHydra/ViewportFiltersTest/nurbsPatches_USD_included.png new file mode 100644 index 0000000000000000000000000000000000000000..6c42ebcf78abd4df79bcb3fecc85c187be93b258 GIT binary patch literal 20117 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