/usr/include/osgEarthAnnotation/EllipseNode is in libosgearth-dev 2.9.0+dfsg-1.
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 | /* -*-c++-*- */
/* osgEarth - Dynamic map generation toolkit for OpenSceneGraph
* Copyright 2016 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 <http://www.gnu.org/licenses/>
*/
#ifndef OSGEARTH_ANNOTATION_ELLIPSE_NODE_H
#define OSGEARTH_ANNOTATION_ELLIPSE_NODE_H 1
#include <osgEarthAnnotation/LocalGeometryNode>
#include <osgEarthSymbology/Style>
#include <osgEarth/Units>
#include <osgEarth/MapNode>
namespace osgEarth { namespace Annotation
{
using namespace osgEarth;
using namespace osgEarth::Symbology;
/**
* Renders an ellipse that can drape on a MapNode terrain.
*/
class OSGEARTHANNO_EXPORT EllipseNode : public LocalGeometryNode
{
public:
META_AnnotationNode( osgEarthAnnotation, EllipseNode );
/**
* Constructs a new ellipse annotation.
*
* @param mapNode Map on which the annotation will appear
* @param position Location of the annotation, in map coordinates
* @param radiusMajor Length of 1/2 the major axis of the ellipse
* @param radiusMinor Length of 1/2 the minor axis of the ellipse
* @param rotation Rotation angle of the ellipse
* @param style Style defining how the annotation will look
* @param arcStart Optional start of arc (default to 0.0 degrees)
* @param arcStop Optional end of arc (default to 360.0 degrees)
* @param pie Optionally make pie shape instead of arc
*/
EllipseNode(
MapNode* mapNode,
const GeoPoint& position,
const Distance& radiusMajor,
const Distance& radiusMinor,
const Angle& rotationAngle,
const Style& style,
const Angle& arcStart = Angle(0.0, Units::DEGREES),
const Angle& arcEnd = Angle(360.0, Units::DEGREES),
const bool pie = false);
virtual ~EllipseNode() { }
/**
* Gets the major radius
*/
const Distance& getRadiusMajor() const;
/**
* Gets the minor radius
*/
const Distance& getRadiusMinor() const;
/**
* Sets the major radius
*/
void setRadiusMajor( const Distance& radiusMajor );
/**
* Sets the minor radius
*/
void setRadiusMinor( const Distance& radiusMinor );
/**
* Sets the major and minor radii
*/
void setRadii( const Distance& radiusMajor, const Distance& radiusMinor );
/*
* Gets the rotation angle
*/
const Angle& getRotationAngle() const;
/**
* Sets the rotation angle
*/
void setRotationAngle(const Angle& rotationAngle);
/**
* Gets the number of segments
*/
unsigned int getNumSegments() const;
/**
* Sets the number of segments
*/
void setNumSegments(unsigned int numSegments );
/**
* Gets the start degrees of this (arc) circle
*/
const Angle& getArcStart(void) const;
/**
* Sets the start degrees of this (arc) circle
*/
void setArcStart(const Angle& arcStart);
/**
* Gets the end degrees of this (arc) circle
*/
const Angle& getArcEnd(void) const;
/**
* Sets the end degrees of this (arc) circle
*/
void setArcEnd(const Angle& arcEnd);
/**
* Gets the pie flag
*/
const bool& getPie(void) const;
/**
* Sets the pie flag
*/
void setPie(const bool& pie);
public:
EllipseNode(MapNode* mapNode, const Config& conf, const osgDB::Options* dbOptions);
virtual Config getConfig() const;
private:
EllipseNode() { }
EllipseNode(const EllipseNode& rhs, const osg::CopyOp& op) { }
void rebuildGeometry();
void initEllipseNode();
Angle _rotationAngle;
Distance _radiusMajor;
Distance _radiusMinor;
Angle _arcStart;
Angle _arcEnd;
bool _pie;
unsigned int _numSegments;
};
} } // namespace osgEarth::Annotation
#endif // OSGEARTH_ANNOTATION_ELLIPSE_NODE_H
|