/usr/include/qgis/qgslabel.h is in libqgis-dev 2.18.17+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 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 | /***************************************************************************
qgslabel.h - render vector labels
-------------------
begin : August 2004
copyright : (C) 2004 by Radim Blazek
email : blazek@itc.it
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef QGSLABEL_H
#define QGSLABEL_H
#include <vector>
#include <QColor>
#include <QList>
#include <QMap>
#include "qgspoint.h"
class QDomNode;
class QDomDocument;
class QDomElement;
class QString;
class QPainter;
class QPaintDevice;
class QgsFeature;
class QgsField;
class QgsLabelAttributes;
#include "qgsfield.h"
#include "qgsrectangle.h"
#include "qgsrendercontext.h"
typedef QList<int> QgsAttributeList;
class QgsFields;
/** \ingroup core
* A class to render labels.
* Label rendering properties can be either specified directly or
* in most cases determined dynamically based on the value of an attribute.
**/
class CORE_EXPORT QgsLabel
{
public:
QgsLabel( const QgsFields & fields );
~QgsLabel();
/* Fields */
enum LabelField
{
Text = 0,
Family,
Size,
SizeType,
Bold,
Italic,
Underline,
Color,
XCoordinate,
YCoordinate,
XOffset,
YOffset,
Angle,
Alignment,
BufferEnabled,
BufferSize,
BufferColor,
BufferBrush,
BorderWidth,
BorderColor,
BorderStyle,
MultilineEnabled,
StrikeOut,
LabelFieldCount
};
struct labelpoint
{
QgsPoint p;
double angle;
};
/** \brief render label
* \param renderContext the render context
* \param feature feature to render the label for
* \param selected feature is selected
* \param classAttributes attributes to create the label from
*/
void renderLabel( QgsRenderContext &renderContext, QgsFeature &feature, bool selected, QgsLabelAttributes *classAttributes = nullptr );
/** Reads the renderer configuration from an XML file
* @param node the Dom node to read
*/
void readXML( const QDomNode& node );
/** Writes the contents of the renderer to a configuration file */
void writeXML( QDomNode & label_node, QDomDocument & document ) const;
//! add vector of required fields to existing list of fields
void addRequiredFields( QgsAttributeList& fields ) const;
//! Set available fields
void setFields( const QgsFields & fields );
//! Available vector fields
QgsFields & fields();
/** Pointer to default attributes.
* @note this replaces the to-be-deprecated layerAttributes method.
* @note introduced in QGIS 1.4
*/
QgsLabelAttributes *labelAttributes();
//! Set label field
void setLabelField( int attr, int fieldIndex );
//! label field
QString labelField( int attr ) const;
/** Get field value if : 1) field name is not empty
* 2) field exists
* 3) value is defined
* otherwise returns empty string
*/
QString fieldValue( int attr, QgsFeature& feature );
/** Accessor and mutator for the minimum scale member */
void setMinScale( float theMinScale );
float minScale() const;
/** Accessor and mutator for the maximum scale member */
void setMaxScale( float theMaxScale );
float maxScale() const;
/** Accessor and mutator for the scale based visilibility flag */
void setScaleBasedVisibility( bool theVisibilityFlag );
bool scaleBasedVisibility() const;
/** Return true if the label is visible at the given scale */
bool isInScaleRange( double scale ) const;
private:
/** Does the actual rendering of a label at the given point */
void renderLabel( QgsRenderContext &renderContext, QgsPoint point,
const QString& text, const QFont& font, const QPen& pen,
int dx, int dy,
double xoffset, double yoffset,
double ang,
int width, int height, int alignment );
bool readLabelField( QDomElement &el, int attr, const QString& prefix );
/** Get label point for simple feature in map units */
void labelPoint( std::vector<labelpoint>&, QgsFeature &feature );
/** Get label point for the given feature in wkb format. */
const unsigned char* labelPoint( labelpoint& point, const unsigned char* wkb, size_t wkblen );
/** Color to draw selected features */
QColor mSelectionColor;
//! Default layer attributes
QgsLabelAttributes *mLabelAttributes;
//! Available layer fields
QgsFields mFields;
//! Label fields
std::vector<QString> mLabelField;
//! Label field indexes
std::vector<int> mLabelFieldIdx;
/** Minimum scale at which this label should be displayed */
float mMinScale;
/** Maximum scale at which this label should be displayed */
float mMaxScale;
/** A flag that tells us whether to use the above vars to restrict the label's visibility */
bool mScaleBasedVisibility;
QgsLabel( const QgsLabel& rh );
QgsLabel& operator=( const QgsLabel& rh );
};
#endif
|