/usr/include/marble/GeoGraphicsItem.h is in libmarble-dev 4:17.12.3-0ubuntu1.
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 171 172 173 174 | //
// This file is part of the Marble Virtual Globe.
//
// This program is free software licensed under the GNU LGPL. You can
// find a copy of this license in LICENSE.txt in the top directory of
// the source code.
//
// Copyright 2009 Bastian Holst <bastianholst@gmx.de>
// Copyright 2009 Andrew Manson <g.real.ate@gmail.com>
//
#ifndef MARBLE_GEOGRAPHICSITEM_H
#define MARBLE_GEOGRAPHICSITEM_H
// Marble
#include "marble_export.h"
#include "GeoDataStyle.h"
class QString;
namespace Marble
{
class GeoDataFeature;
class GeoDataLatLonAltBox;
class GeoDataCoordinates;
class GeoGraphicsItemPrivate;
class GeoPainter;
class StyleBuilder;
class ViewportParams;
class GeoDataRelation;
class RenderContext
{
public:
bool operator==(const RenderContext &other) const;
bool operator!=(const RenderContext &other) const;
explicit RenderContext(int tileLevel = -1);
int tileLevel() const;
private:
int m_tileLevel;
};
class MARBLE_EXPORT GeoGraphicsItem
{
public:
explicit GeoGraphicsItem( const GeoDataFeature *feature );
virtual ~GeoGraphicsItem();
enum GeoGraphicsItemFlag {
NoOptions = 0x0,
ItemIsMovable = 0x1,
ItemIsSelectable = 0x2,
ItemIsVisible = 0x4
};
Q_DECLARE_FLAGS(GeoGraphicsItemFlags, GeoGraphicsItemFlag)
bool visible() const;
void setVisible( bool visible );
/**
* Get the GeoGraphicItemFlags value that describes which flags are set on
* this item. @see QFlags
*/
GeoGraphicsItemFlags flags() const;
/**
* Set or unset a single flag
* @param enabled sets if the flag is to be set or unset
*/
void setFlag( GeoGraphicsItemFlag flag, bool enabled = true );
/**
* Replace all of the current flags.
* @param flags is the new value for this item's flags.
*/
void setFlags( GeoGraphicsItemFlags flags );
/**
* Returns the minim zoom level on which item will be active.
*/
int minZoomLevel() const;
/**
* Sets the minimum zoom level
*/
void setMinZoomLevel( int zoomLevel );
/**
* Returns the placemark for that item.
*/
const GeoDataFeature* feature() const;
/**
* Returns the bounding box covered by the item.
*/
virtual const GeoDataLatLonAltBox &latLonAltBox() const = 0;
/**
* Returns the style of item.
*/
GeoDataStyle::ConstPtr style() const;
/**
* Set the style for the item.
*/
void setStyleBuilder(const StyleBuilder *styleBuilder);
void resetStyle();
/**
* Set the style which will be used when
* placemark is highlighted.
* GeoGraphicsItem takes ownership of the
* passed style and deletes it when appropriate.
*/
void setHighlightStyle( const GeoDataStyle::ConstPtr &highlightStyle );
/**
* Returns the z value of the item
*/
qreal zValue() const;
/**
* Set the z value of the item
*/
void setZValue( qreal z );
static bool zValueLessThan(GeoGraphicsItem* one, GeoGraphicsItem* two);
static bool styleLessThan(GeoGraphicsItem* one, GeoGraphicsItem* two);
static bool zValueAndStyleLessThan(GeoGraphicsItem* one, GeoGraphicsItem* two);
/**
* Paints the item using the given GeoPainter.
*
* Note that depending on the projection and zoom level, the item may be visible more than once,
* which is taken care of by GeoPainter.
*/
virtual void paint(GeoPainter *painter, const ViewportParams *viewport, const QString &layer, int tileZoomLevel) = 0;
void setHighlighted( bool highlight );
bool isHighlighted() const;
QStringList paintLayers() const;
void setPaintLayers(const QStringList &paintLayers);
void setRenderContext(const RenderContext &renderContext);
/**
* @brief contains Returns true if the item contains the given coordinates
* @param coordinates
* @param screenPosition
* @return
*/
virtual bool contains(const QPoint &screenPosition, const ViewportParams *viewport) const;
void setRelations(const QSet<const GeoDataRelation *> &relations);
protected:
virtual void handleRelationUpdate(const QVector<const GeoDataRelation *> &relations);
GeoGraphicsItemPrivate *const d;
};
} // Namespace Marble
Q_DECLARE_OPERATORS_FOR_FLAGS(Marble::GeoGraphicsItem::GeoGraphicsItemFlags)
#endif
|