osgEarth 2.1.1

/home/cube/sources/osgearth/src/osgEarthFeatures/BuildGeometryFilter

Go to the documentation of this file.
00001 /* -*-c++-*- */
00002 /* osgEarth - Dynamic map generation toolkit for OpenSceneGraph
00003  * Copyright 2008-2010 Pelican Mapping
00004  * http://osgearth.org
00005  *
00006  * osgEarth is free software; you can redistribute it and/or modify
00007  * it under the terms of the GNU Lesser General Public License as published by
00008  * the Free Software Foundation; either version 2 of the License, or
00009  * (at your option) any later version.
00010  *
00011  * This program is distributed in the hope that it will be useful,
00012  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00013  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00014  * GNU Lesser General Public License for more details.
00015  *
00016  * You should have received a copy of the GNU Lesser General Public License
00017  * along with this program.  If not, see <http://www.gnu.org/licenses/>
00018  */
00019 
00020 #ifndef OSGEARTHFEATURES_BUILD_GEOMETRY_FILTER_H
00021 #define OSGEARTHFEATURES_BUILD_GEOMETRY_FILTER_H 1
00022 
00023 #include <osgEarthFeatures/Common>
00024 #include <osgEarthFeatures/Feature>
00025 #include <osgEarthFeatures/Filter>
00026 #include <osgEarthSymbology/Style>
00027 #include <osgEarth/GeoMath>
00028 #include <osg/Geode>
00029 
00030 namespace osgEarth { namespace Features 
00031 {
00032     using namespace osgEarth;
00033     using namespace osgEarth::Symbology;
00034 
00038     class OSGEARTHFEATURES_EXPORT BuildGeometryFilter : public FeaturesToNodeFilter
00039     {
00040     public:
00041         BuildGeometryFilter( const Style& style =Style() );
00042 
00044         osg::Node* push( FeatureList& input, FilterContext& context );
00045 
00047         const Style& getStyle() { return _style; }
00048         void setStyle(const Style& s) { _style = s; }
00049 
00057         optional<double>& maxGranularity() { return _maxAngle_deg; }
00058         const optional<double>& maxGranularity() const { return _maxAngle_deg; }
00059 
00064         optional<GeoInterpolation>& geoInterp() { return _geoInterp; }
00065         const optional<GeoInterpolation>& geoInterp() const { return _geoInterp; }
00066 
00072         optional<bool>& mergeGeometry() { return _mergeGeometry; }
00073         const optional<bool>& mergeGeometry() const { return _mergeGeometry; }
00074 
00079         optional<StringExpression>& featureName() { return _featureNameExpr; }
00080         const optional<StringExpression>& featureName() const { return _featureNameExpr; }
00081 
00082     protected:
00083         osg::ref_ptr<osg::Node> _result;
00084         osg::ref_ptr<osg::Geode> _geode;
00085         Style _style;
00086         optional<double> _maxAngle_deg;
00087         optional<GeoInterpolation> _geoInterp;
00088         optional<bool> _mergeGeometry;
00089         optional<StringExpression> _featureNameExpr;
00090         bool _hasPoints;
00091         bool _hasLines;
00092         bool _hasPolygons;
00093 
00094         void reset();
00095         
00096         bool process( FeatureList& input, const FilterContext& context );
00097     };
00098 
00099 } } // namespace osgEarth::Features
00100 
00101 #endif // OSGEARTHFEATURES_BUILD_GEOMETRY_FILTER_H
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines