/usr/include/osgEarthFeatures/FeatureSourceIndexNode is in libosgearth-dev 2.5.0+dfsg-2+b2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | /* -*-c++-*- */
/* osgEarth - Dynamic map generation toolkit for OpenSceneGraph
* Copyright 2008-2013 Pelican Mapping
* http://osgearth.org
*
* osgEarth is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>
*/
#ifndef OSGEARTHFEATURES_FEATURE_SOURCE_INDEX_NODE_H
#define OSGEARTHFEATURES_FEATURE_SOURCE_INDEX_NODE_H 1
#include <osgEarthFeatures/Common>
#include <osgEarthFeatures/FeatureDrawSet>
#include <osgEarthFeatures/FeatureSource>
#include <osg/Config>
#include <osg/Group>
#include <osg/Drawable>
namespace osgEarth { namespace Features
{
/**
* Options for a feature index
*/
class OSGEARTHFEATURES_EXPORT FeatureSourceIndexOptions
{
public:
FeatureSourceIndexOptions(const Config& conf =Config());
/** Wheter to embed the actual Feature objects in the index (instead of
* just the FeatureID). This is useful for feature sources that cannot
* be queried by ID (e.g., streaming data like TFS) */
optional<bool>& embedFeatures() { return _embedFeatures; }
const optional<bool>& embedFeatures() const { return _embedFeatures; }
public:
Config getConfig() const;
private:
optional<bool> _embedFeatures;
};
/**
* Interface for feature indexing.
*/
class FeatureSourceIndex
{
public: // tagging functions
virtual void tagPrimitiveSets( osg::Drawable* drawable, Feature* feature ) const =0;
virtual void tagNode( osg::Node* node, Feature* feature ) const =0;
virtual ~FeatureSourceIndex() { }
};
/**
* Maintains an index that maps FeatureID's from a FeatureSource to
* PrimitiveSets within the subgraph's geometry.
*/
class OSGEARTHFEATURES_EXPORT FeatureSourceIndexNode : public osg::Group, public FeatureSourceIndex
{
public:
/**
* Constructs a new index node.
*/
FeatureSourceIndexNode(
FeatureSource* featureSource,
const FeatureSourceIndexOptions& options );
virtual ~FeatureSourceIndexNode() { }
public: // FeatureSourceIndex
/**
* Tags all the primitive sets in a Drawable with the specified FeatureID.
*/
void tagPrimitiveSets( osg::Drawable* drawable, Feature* feature ) const;
/**
* Tags a node with the specified FeatureID.
*/
void tagNode( osg::Node* node, Feature* feature ) const;
public:
/**
* The feature source tied to this node
*/
FeatureSource* getFeatureSource() { return _featureSource.get(); }
/**
* Traverses this node's subgraph and rebuilds the feature index based on
* any tagged drawables found. (See tagPrimitiveSets for tagging drawables).
*/
void reindex();
/**
* Given a primitive set, returns the feature ID corresponding to that set.
*
* @param pset Primitive set to query
* @param output Holds the result of the query, if returning true
* @return true if successful
*/
bool getFID(osg::PrimitiveSet* pset, FeatureID& output) const;
/**
* Gets the Feature ID corresponding to a drawable and a prim index. This is
* useful to call using the results of an intersection test.
*
* @param drawable Drawable for which to lookup the feature ID
* @param primitiveIndex Index of the primitive to look up
* @param output Holds the result of the query, if returning true
* @return true if successful
*/
bool getFID(osg::Drawable* drawable, int primitiveIndex, FeatureID& output) const;
/**
* Given a FeatureID, returns the collection of drawable/primitiveset combinations
* corresponding to that feature.
*
* @param fid Feature ID to look up
* @return Corresponding collection of primitive sets (empty if the query fails)
*/
FeatureDrawSet& getDrawSet( const FeatureID& fid );
/**
* Given a FeatureID, returns the cached feature.
*
* @param fid Feature ID to look up
* @param output cached feature
* @return true if successful
*/
bool getFeature(const FeatureID& fid, const Feature*& output) const;
private:
osg::ref_ptr<FeatureSource> _featureSource;
typedef std::map<FeatureID, FeatureDrawSet> FeatureIDDrawSetMap;
FeatureIDDrawSetMap _drawSets;
struct Collect : public osg::NodeVisitor {
Collect(FeatureIDDrawSetMap&);
void apply(osg::Node&);
void apply(osg::Geode&);
FeatureIDDrawSetMap& _index;
unsigned _psets;
};
FeatureSourceIndexOptions _options;
typedef std::map< FeatureID, osg::ref_ptr<const Feature> > FeatureMap;
mutable FeatureMap _features; // cache
public:
virtual const char* className() const { return "FeatureSourceIndexNode"; }
virtual const char* libraryName() const { return "osgEarthFeatures"; }
};
} } // namespace osgEarth::Features
#endif // OSGEARTHFEATURES_FEATURE_SOURCE_INDEX_NODE_H
|