/* -*-c++-*- */
/* osgEarth - Dynamic map generation toolkit for OpenSceneGraph
 * Copyright 2008-2010 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_TRANSFORM_FILTER_H
#define OSGEARTHFEATURES_TRANSFORM_FILTER_H 1

#include <osgEarthFeatures/Common>
#include <osgEarthFeatures/Feature>
#include <osgEarthFeatures/Filter>
#include <osg/BoundingBox>

namespace osgEarth { namespace Features
{
    using namespace osgEarth;

    /**
     * Feature filter that transforms features from one FeatureProfile to 
     * another.
     */
    class OSGEARTHFEATURES_EXPORT TransformFilter : public FeatureFilter
    {
    public:
        TransformFilter();
        TransformFilter( const SpatialReference* outputSRS );

        /** Height offset to apply after doing the SRS transformation. Output SRS units. */
        void setHeightOffset( double value ) { _heightOffset = value; }
        double getHeightOffset() const { return _heightOffset; }

        /** Whether to convert the transformed coordinates into geocentric (default = false ) */
        void setMakeGeocentric( bool value ) { _makeGeocentric = value; }
        bool getMakeGeocentric() const { return _makeGeocentric; }

        /** Whether to localize coordinates to the bounding box centroid (to avoid precision jitter
            when turning the data into OSG geometry) */
        void setLocalizeCoordinates( bool value ) { _localize = value; }
        bool getLocalizeCoordinates() const { return _localize; }

    public:
        FilterContext push( FeatureList& features, const FilterContext& context );

    protected:
        osg::ref_ptr<const SpatialReference> _outputSRS;
        bool _makeGeocentric;
        double _heightOffset;
        osg::BoundingBoxd _bbox;
        bool _localize;
        
        bool push( Feature* feature, const FilterContext& context );
    };

} } // namespace osgEarth::Features

#endif // OSGEARTHFEATURES_TRANSFORM_FILTER_H
