/* -*-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_UTIL_GEODETIC_LABELING_ENGINE_H #define OSGEARTH_UTIL_GEODETIC_LABELING_ENGINE_H 1 #include #include #include #include #include #include #include namespace osgEarth { namespace Util { using namespace osgEarth; using namespace osgEarth::Util; /** * Node that plots geodetic coordinats labels along the edge of the * viewport when you are looking straight down on a zoomed-in area. */ class GeodeticLabelingEngine : public GraticuleLabelingEngine { public: //! Construct a new labeling engine with the map's SRS GeodeticLabelingEngine(const SpatialReference* srs); virtual bool updateLabels(const osg::Vec3d& LL_world, osg::Vec3d& UL_world, osg::Vec3d& LR_world, ClipSpace& window, CameraData& data); double getResolution() const; void setResolution(double resolution); protected: std::string getText(const GeoPoint& location, bool lat); double _resolution; osg::ref_ptr _formatter; }; } } // namespace osgEarth::Util #endif // GeodeticLabelingEngine