/* -*-c++-*- */ /* osgEarth - Geospatial SDK for OpenSceneGraph * Copyright 2020 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. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS * IN THE SOFTWARE. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see */ #ifndef OSGEARTH_TILEHANDLER_H #define OSGEARTH_TILEHANDLER_H 1 #include #include #include #include namespace osgEarth { namespace Util { using namespace osgEarth; class TileVisitor; /** * TileHandler is an interface for operations on a TileKey */ class OSGEARTH_EXPORT TileHandler : public osg::Referenced { public: /** * Process a tile - also provides a reference to the calling TileVisitor */ virtual bool handleTile(const TileKey& key, const TileVisitor& tv); /** * Callback that tells a TileVisitor if it should attempt to process this key. * If this function returns false no further processing is done on child keys. */ virtual bool hasData( const TileKey& key ) const; /** * Returns the process to run when executing in a MultiProcessTileVisitor. * * When running in a MultiProcessTileVisitor the actual data processing is done by an external program * that takes a --tiles argument. This function lets you tie that process to the TileHandler */ virtual std::string getProcessString() const; //! Estimates the total number of tiles that this handler //! expects to handle for the given input extents. virtual unsigned getEstimatedTileCount( const std::vector& extents, unsigned minLevel, unsigned maxLevel) const { return 0; } }; } } // namespace osgEarth #endif // OSGEARTH_TRAVERSAL_DATA_H