From a2048c2ed50d7936112b7af9f3bb34dea877a641 Mon Sep 17 00:00:00 2001 From: Jason Beverage Date: Fri, 8 Dec 2023 15:52:14 -0500 Subject: [PATCH] Fixes for a ModelSymbol with a model node instead of a URI. Fixes #2312. --- src/osgEarth/SubstituteModelFilter.cpp | 32 +++++++++++++++++++------- 1 file changed, 24 insertions(+), 8 deletions(-) diff --git a/src/osgEarth/SubstituteModelFilter.cpp b/src/osgEarth/SubstituteModelFilter.cpp index 16e60a92d7..02141d5ddd 100644 --- a/src/osgEarth/SubstituteModelFilter.cpp +++ b/src/osgEarth/SubstituteModelFilter.cpp @@ -262,7 +262,7 @@ SubstituteModelFilter::process(const FeatureList& features, // first, go through the features and build the model cache. Apply the model matrix' scale // factor to any AutoTransforms directly (cloning them as necessary) - std::map< std::pair, osg::ref_ptr > uniqueModels; + std::map< std::pair, osg::ref_ptr > uniqueModels; // URI cache speeds up URI creation since it can be slow. std::unordered_map uriCache; @@ -307,12 +307,28 @@ SubstituteModelFilter::process(const FeatureList& features, calculateGeometryHeading(input, context); } // evaluate the instance URI expression: - const std::string& st = input->eval(uriEx, &context); - URI& instanceURI = uriCache[st]; - if(instanceURI.empty()) // Create a map, to reuse URI's, since they take a long time to create - { - instanceURI = URI( st, uriEx.uriContext() ); - } + std::string resourceKey; + if (symbol->url().isSet()) + { + resourceKey = input->eval(uriEx, &context); + } + else if (modelSymbol && modelSymbol->getModel()) + { + resourceKey = Stringify() << modelSymbol->getModel(); + } + else if (iconSymbol && iconSymbol->getImage()) + { + resourceKey = Stringify() << iconSymbol->getImage(); + } + URI instanceURI; + if (symbol->url().isSet()) + { + instanceURI = uriCache[resourceKey]; + if (instanceURI.empty()) // Create a map, to reuse URI's, since they take a long time to create + { + instanceURI = URI(resourceKey, uriEx.uriContext()); + } + } // find the corresponding marker in the cache osg::ref_ptr instance; @@ -374,7 +390,7 @@ SubstituteModelFilter::process(const FeatureList& features, } // now that we have a marker source, create a node for it - std::pair key( instanceURI, iconSymbol? scale : 1.0f ); //use 1.0 for models, since we don't want unique models based on scaling + std::pair key( resourceKey, iconSymbol? scale : 1.0f ); //use 1.0 for models, since we don't want unique models based on scaling // cache nodes per instance. osg::ref_ptr& model = uniqueModels[key];