QGIS API Documentation  3.10.0-A Coruña (6c816b4204)
feature.h
Go to the documentation of this file.
1 /*
2  * libpal - Automated Placement of Labels Library
3  *
4  * Copyright (C) 2008 Maxence Laurent, MIS-TIC, HEIG-VD
5  * University of Applied Sciences, Western Switzerland
6  * http://www.hes-so.ch
7  *
8  * Contact:
9  * maxence.laurent <at> heig-vd <dot> ch
10  * or
11  * eric.taillard <at> heig-vd <dot> ch
12  *
13  * This file is part of libpal.
14  *
15  * libpal is free software: you can redistribute it and/or modify
16  * it under the terms of the GNU General Public License as published by
17  * the Free Software Foundation, either version 3 of the License, or
18  * (at your option) any later version.
19  *
20  * libpal is distributed in the hope that it will be useful,
21  * but WITHOUT ANY WARRANTY; without even the implied warranty of
22  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23  * GNU General Public License for more details.
24  *
25  * You should have received a copy of the GNU General Public License
26  * along with libpal. If not, see <http://www.gnu.org/licenses/>.
27  *
28  */
29 
30 #ifndef FEATURE_H
31 #define FEATURE_H
32 
33 #define SIP_NO_FILE
34 
35 
36 #include "qgis_core.h"
37 #include "pointset.h"
38 #include "labelposition.h" // for LabelPosition enum
39 #include "qgslabelfeature.h"
40 #include "rtree.hpp"
41 #include <iostream>
42 #include <fstream>
43 #include <cmath>
44 #include <QString>
45 
52 namespace pal
53 {
55  class CORE_EXPORT LabelInfo
56  {
57  public:
58  typedef struct
59  {
60  double width;
61  } CharacterInfo;
62 
63  LabelInfo( int num, double height, double maxinangle = 20.0, double maxoutangle = -20.0 )
64  {
65  max_char_angle_inside = maxinangle;
66  // outside angle should be negative
67  max_char_angle_outside = maxoutangle > 0 ? -maxoutangle : maxoutangle;
68  label_height = height;
69  char_num = num;
70  char_info = new CharacterInfo[num];
71  }
72  ~LabelInfo() { delete [] char_info; }
73 
75  LabelInfo( const LabelInfo &rh ) = delete;
77  LabelInfo &operator=( const LabelInfo &rh ) = delete;
78 
81  double label_height;
82  int char_num;
83  CharacterInfo *char_info = nullptr;
84 
85  };
86 
87  class LabelPosition;
88  class FeaturePart;
89 
96  class CORE_EXPORT FeaturePart : public PointSet
97  {
98 
99  public:
100 
106  FeaturePart( QgsLabelFeature *lf, const GEOSGeometry *geom );
107 
108  FeaturePart( const FeaturePart &other );
109 
113  ~FeaturePart() override;
114 
118  QgsLabelFeature *feature() { return mLF; }
119 
123  Layer *layer();
124 
128  QgsFeatureId featureId() const;
129 
137  QList<LabelPosition *> createCandidates( const GEOSPreparedGeometry *mapBoundary, PointSet *mapShape, RTree<LabelPosition *, double, 2, double> *candidates );
138 
147  int createCandidatesAroundPoint( double x, double y, QList<LabelPosition *> &lPos, double angle );
148 
157  int createCandidatesOverPoint( double x, double y, QList<LabelPosition *> &lPos, double angle );
158 
165  std::unique_ptr< LabelPosition > createCandidatePointOnSurface( PointSet *mapShape );
166 
175  int createCandidatesAtOrderedPositionsOverPoint( double x, double y, QList<LabelPosition *> &lPos, double angle );
176 
184  int createCandidatesAlongLine( QList<LabelPosition *> &lPos, PointSet *mapShape, bool allowOverrun = false );
185 
193  int createCandidatesAlongLineNearStraightSegments( QList<LabelPosition *> &lPos, PointSet *mapShape );
194 
204  int createCandidatesAlongLineNearMidpoint( QList<LabelPosition *> &lPos, PointSet *mapShape, double initialCost = 0.0 );
205 
216  LabelPosition *curvedPlacementAtOffset( PointSet *path_positions, double *path_distances,
217  int &orientation, double distance, bool &reversed, bool &flip );
218 
226  int createCurvedCandidatesAlongLine( QList<LabelPosition *> &lPos, PointSet *mapShape, bool allowOverrun = false );
227 
234  int createCandidatesForPolygon( QList<LabelPosition *> &lPos, PointSet *mapShape );
235 
242  bool hasSameLabelFeatureAs( FeaturePart *part ) const;
243 
244 #if 0
245 
250  void print();
251 #endif
252 
257  double getLabelWidth( double angle = 0.0 ) const { return mLF->size( angle ).width(); }
258 
263  double getLabelHeight( double angle = 0.0 ) const { return mLF->size( angle ).height(); }
264 
269  double getLabelDistance() const { return mLF->distLabel(); }
270 
272  bool hasFixedRotation() const { return mLF->hasFixedAngle(); }
273 
275  double fixedAngle() const { return mLF->fixedAngle(); }
276 
278  bool hasFixedPosition() const { return mLF->hasFixedPosition(); }
279 
284  bool alwaysShow() const { return mLF->alwaysShow(); }
285 
287  bool isObstacle() const { return mLF->isObstacle(); }
288 
293  double obstacleFactor() const { return mLF->obstacleFactor(); }
294 
296  double repeatDistance() const { return mLF->repeatDistance(); }
297 
299  int getNumSelfObstacles() const { return mHoles.count(); }
301  FeaturePart *getSelfObstacle( int i ) { return mHoles.at( i ); }
302 
304  bool isConnected( FeaturePart *p2 );
305 
309  bool mergeWithFeaturePart( FeaturePart *other );
310 
311  void addSizePenalty( int nbp, QList<LabelPosition *> &lPos, double bbx[4], double bby[4] );
312 
317  double calculatePriority() const;
318 
320  bool showUprightLabels() const;
321 
323  bool nextCharPosition( double charWidth, double segmentLength, PointSet *path_positions, int &index, double &currentDistanceAlongSegment,
324  double &characterStartX, double &characterStartY, double &characterEndX, double &characterEndY ) const;
325 
330  int totalRepeats() const;
331 
336  void setTotalRepeats( int repeats );
337 
338  protected:
339 
340  QgsLabelFeature *mLF = nullptr;
341  QList<FeaturePart *> mHoles;
342 
344  void extractCoords( const GEOSGeometry *geom );
345 
346  private:
347 
348  LabelPosition::Quadrant quadrantFromOffset() const;
349 
350  int mTotalRepeats = 0;
351  };
352 
353 } // end namespace pal
354 
355 #endif
double obstacleFactor() const
Returns the feature&#39;s obstacle factor, which represents the penalty incurred for a label to overlap t...
Definition: feature.h:293
double fixedAngle() const
Returns the fixed angle for the feature&#39;s label.
Definition: feature.h:275
double max_char_angle_outside
Definition: feature.h:80
QgsLabelFeature * feature()
Returns the parent feature.
Definition: feature.h:118
bool hasFixedRotation() const
Returns true if the feature&#39;s label has a fixed rotation.
Definition: feature.h:272
A set of features which influence the labeling process.
Definition: layer.h:63
bool alwaysShow() const
Returns true if the feature&#39;s label should always been shown, even when it collides with other labels...
Definition: feature.h:284
qint64 QgsFeatureId
Definition: qgsfeatureid.h:25
int getNumSelfObstacles() const
Gets number of holes (inner rings) - they are considered as obstacles.
Definition: feature.h:299
LabelInfo(int num, double height, double maxinangle=20.0, double maxoutangle=-20.0)
Definition: feature.h:63
double getLabelDistance() const
Returns the distance from the anchor point to the label.
Definition: feature.h:269
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored)
Definition: MathUtils.cpp:786
double repeatDistance() const
Returns the distance between repeating labels for this feature.
Definition: feature.h:296
bool isObstacle() const
Returns true if the feature should act as an obstacle to labels.
Definition: feature.h:287
Optional additional info about label (for curved labels)
Definition: feature.h:55
double label_height
Definition: feature.h:81
Main class to handle feature.
Definition: feature.h:96
bool hasFixedPosition() const
Returns true if the feature&#39;s label has a fixed position.
Definition: feature.h:278
The QgsLabelFeature class describes a feature that should be used within the labeling engine...
QList< FeaturePart * > mHoles
Definition: feature.h:341
double max_char_angle_inside
Definition: feature.h:79
FeaturePart * getSelfObstacle(int i)
Gets hole (inner ring) - considered as obstacle.
Definition: feature.h:301
LabelPosition is a candidate feature label position.
Definition: labelposition.h:55
Quadrant
Position of label candidate relative to feature.
Definition: labelposition.h:65
int char_num
Definition: feature.h:82
double getLabelWidth(double angle=0.0) const
Returns the width of the label, optionally taking an angle into account.
Definition: feature.h:257
double getLabelHeight(double angle=0.0) const
Returns the height of the label, optionally taking an angle into account.
Definition: feature.h:263