QGIS API Documentation  3.20.0-Odense (decaadbb31)
qgslabelingengine.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgslabelingengine.h
3  --------------------------------------
4  Date : September 2015
5  Copyright : (C) 2015 by Martin Dobias
6  Email : wonder dot sk at gmail dot com
7  ***************************************************************************
8  * *
9  * This program is free software; you can redistribute it and/or modify *
10  * it under the terms of the GNU General Public License as published by *
11  * the Free Software Foundation; either version 2 of the License, or *
12  * (at your option) any later version. *
13  * *
14  ***************************************************************************/
15 
16 #ifndef QGSLABELINGENGINE_H
17 #define QGSLABELINGENGINE_H
18 
19 #define SIP_NO_FILE
20 
21 #include "qgis_core.h"
22 #include "qgsmapsettings.h"
23 
24 #include "qgspallabeling.h"
26 #include "qgslabeling.h"
27 
28 class QgsLabelingEngine;
29 class QgsLabelingResults;
30 
31 namespace pal
32 {
33  class Problem;
34 }
35 
48 class CORE_EXPORT QgsAbstractLabelProvider
49 {
50 
51  public:
53  QgsAbstractLabelProvider( QgsMapLayer *layer, const QString &providerId = QString() );
54 
55  virtual ~QgsAbstractLabelProvider() = default;
56 
58  void setEngine( const QgsLabelingEngine *engine ) { mEngine = engine; }
59 
60  enum Flag
61  {
62  DrawLabels = 1 << 1,
63  DrawAllLabels = 1 << 2,
64  MergeConnectedLines = 1 << 3,
65  CentroidMustBeInside = 1 << 4,
66  };
67  Q_DECLARE_FLAGS( Flags, Flag )
68 
69 
70  virtual QList<QgsLabelFeature *> labelFeatures( QgsRenderContext &context ) = 0;
71 
78  virtual void drawLabel( QgsRenderContext &context, pal::LabelPosition *label ) const = 0;
79 
91  virtual void drawUnplacedLabel( QgsRenderContext &context, pal::LabelPosition *label ) const;
92 
105  virtual void drawLabelBackground( QgsRenderContext &context, pal::LabelPosition *label ) const;
106 
112  virtual void startRender( QgsRenderContext &context );
113 
119  virtual void stopRender( QgsRenderContext &context );
120 
122  virtual QList<QgsAbstractLabelProvider *> subProviders() { return QList<QgsAbstractLabelProvider *>(); }
123 
125  QString name() const { return mName; }
126 
128  QString layerId() const { return mLayerId; }
129 
131  QgsMapLayer *layer() const { return mLayer.data(); }
132 
138  QString providerId() const { return mProviderId; }
139 
141  Flags flags() const { return mFlags; }
142 
144  QgsPalLayerSettings::Placement placement() const { return mPlacement; }
145 
147  double priority() const { return mPriority; }
148 
150  QgsLabelObstacleSettings::ObstacleType obstacleType() const { return mObstacleType; }
151 
153  QgsPalLayerSettings::UpsideDownLabels upsidedownLabels() const { return mUpsidedownLabels; }
154 
155  protected:
157  const QgsLabelingEngine *mEngine = nullptr;
158 
160  QString mName;
162  QString mLayerId;
166  QString mProviderId;
168  Flags mFlags;
172  double mPriority;
177 };
178 
179 Q_DECLARE_OPERATORS_FOR_FLAGS( QgsAbstractLabelProvider::Flags )
180 
181 
182 
215 class CORE_EXPORT QgsLabelingEngine
216 {
217  public:
221  virtual ~QgsLabelingEngine();
222 
224  QgsLabelingEngine( const QgsLabelingEngine &rh ) = delete;
227 
229  void setMapSettings( const QgsMapSettings &mapSettings );
231  const QgsMapSettings &mapSettings() const { return mMapSettings; }
232 
234  const QgsLabelingEngineSettings &engineSettings() const { return mMapSettings.labelingEngineSettings(); }
235 
240  QList< QgsMapLayer * > participatingLayers() const;
241 
246  QStringList participatingLayerIds() const;
247 
249  void addProvider( QgsAbstractLabelProvider *provider );
250 
252  void removeProvider( QgsAbstractLabelProvider *provider );
253 
261  virtual void run( QgsRenderContext &context ) = 0;
262 
264  QgsLabelingResults *takeResults();
265 
267  QgsLabelingResults *results() const { return mResults.get(); }
268 
269  protected:
270  void processProvider( QgsAbstractLabelProvider *provider, QgsRenderContext &context, pal::Pal &p );
271 
272  protected:
273 
281  void registerLabels( QgsRenderContext &context );
282 
291  void solve( QgsRenderContext &context );
292 
303  void drawLabels( QgsRenderContext &context, const QString &layerId = QString() );
304 
309  void cleanup();
310 
313 
315  QList<QgsAbstractLabelProvider *> mProviders;
316  QList<QgsAbstractLabelProvider *> mSubProviders;
317 
319  std::unique_ptr< QgsLabelingResults > mResults;
320 
321  std::unique_ptr< pal::Pal > mPal;
322  std::unique_ptr< pal::Problem > mProblem;
323  QList<pal::LabelPosition *> mUnlabeled;
324  QList<pal::LabelPosition *> mLabels;
325 
326 };
327 
337 class CORE_EXPORT QgsDefaultLabelingEngine : public QgsLabelingEngine
338 {
339  public:
342 
347 
348  void run( QgsRenderContext &context ) override;
349 
350 };
351 
364 {
365  public:
368 
373 
374  void run( QgsRenderContext &context ) override;
375 
380  void renderLabelsForLayer( QgsRenderContext &context, const QString &layerId );
381 
386  void finalize();
387 };
388 
389 
398 class CORE_EXPORT QgsLabelingUtils
399 {
400  public:
401 
408  static QString encodePredefinedPositionOrder( const QVector< QgsPalLayerSettings::PredefinedPointPosition > &positions );
409 
416  static QVector< QgsPalLayerSettings::PredefinedPointPosition > decodePredefinedPositionOrder( const QString &positionString );
417 
422  static QString encodeLinePlacementFlags( QgsLabeling::LinePlacementFlags flags );
423 
428  static QgsLabeling::LinePlacementFlags decodeLinePlacementFlags( const QString &string );
429 
430 };
431 
432 #endif // QGSLABELINGENGINE_H
The QgsAbstractLabelProvider class is an interface class.
QString mName
Name of the layer.
virtual ~QgsAbstractLabelProvider()=default
QgsMapLayer * layer() const
Returns the associated layer, or nullptr if no layer is associated with the provider.
void setEngine(const QgsLabelingEngine *engine)
Associate provider with a labeling engine (should be only called internally from QgsLabelingEngine)
QString mLayerId
Associated layer's ID, if applicable.
QgsPalLayerSettings::Placement placement() const
What placement strategy to use for the labels.
double priority() const
Default priority of labels (may be overridden by individual labels)
QgsPalLayerSettings::UpsideDownLabels mUpsidedownLabels
How to handle labels that would be upside down.
QString name() const
Name of the layer (for statistics, debugging etc.) - does not need to be unique.
double mPriority
Default priority of labels.
Flags mFlags
Flags altering drawing and registration of features.
Flags flags() const
Flags associated with the provider.
QgsLabelObstacleSettings::ObstacleType obstacleType() const
How the feature geometries will work as obstacles.
QgsPalLayerSettings::UpsideDownLabels upsidedownLabels() const
How to handle labels that would be upside down.
QString layerId() const
Returns ID of associated layer, or empty string if no layer is associated with the provider.
QgsWeakMapLayerPointer mLayer
Weak pointer to source layer.
QString providerId() const
Returns provider ID - useful in case there is more than one label provider within a layer (e....
QgsPalLayerSettings::Placement mPlacement
Placement strategy.
QString mProviderId
Associated provider ID (one layer may have multiple providers, e.g. in rule-based labeling)
Default QgsLabelingEngine implementation, which completes the whole labeling operation (including lab...
QgsDefaultLabelingEngine(const QgsDefaultLabelingEngine &rh)=delete
QgsDefaultLabelingEngine cannot be copied.
QgsDefaultLabelingEngine & operator=(const QgsDefaultLabelingEngine &rh)=delete
QgsDefaultLabelingEngine cannot be copied.
The QgsLabelFeature class describes a feature that should be used within the labeling engine.
ObstacleType
Valid obstacle types, which affect how features within the layer will act as obstacles for labels.
Stores global configuration for labeling engine.
The QgsLabelingEngine class provides map labeling functionality.
std::unique_ptr< pal::Pal > mPal
const QgsLabelingEngineSettings & engineSettings() const
Gets associated labeling engine settings.
std::unique_ptr< QgsLabelingResults > mResults
Resulting labeling layout.
QgsMapSettings mMapSettings
Associated map settings instance.
QList< pal::LabelPosition * > mUnlabeled
std::unique_ptr< pal::Problem > mProblem
const QgsMapSettings & mapSettings() const
Gets associated map settings.
QgsLabelingEngine & operator=(const QgsLabelingEngine &rh)=delete
QgsLabelingEngine cannot be copied.
QList< pal::LabelPosition * > mLabels
QList< QgsAbstractLabelProvider * > mSubProviders
virtual void run(QgsRenderContext &context)=0
Runs the labeling job.
QgsLabelingResults * results() const
For internal use by the providers.
QgsLabelingEngine(const QgsLabelingEngine &rh)=delete
QgsLabelingEngine cannot be copied.
QList< QgsAbstractLabelProvider * > mProviders
List of providers (the are owned by the labeling engine)
Class that stores computed placement from labeling engine.
Contains helper utilities for working with QGIS' labeling engine.
Base class for all map layer types.
Definition: qgsmaplayer.h:70
The QgsMapSettings class contains configuration for rendering of the map.
Placement
Placement modes which determine how label candidates are generated for a feature.
Contains information about the context of a rendering operation.
A QgsLabelingEngine implementation, which only calculates the labeling solution during its run() meth...
QgsStagedRenderLabelingEngine & operator=(const QgsStagedRenderLabelingEngine &rh)=delete
QgsStagedRenderLabelingEngine cannot be copied.
QgsStagedRenderLabelingEngine(const QgsStagedRenderLabelingEngine &rh)=delete
QgsStagedRenderLabelingEngine cannot be copied.
Main Pal labeling class.
Definition: pal.h:80
Q_DECLARE_OPERATORS_FOR_FLAGS(QgsField::ConfigurationFlags) CORE_EXPORT QDataStream &operator<<(QDataStream &out
Writes the field to stream out. QGIS version compatibility is not guaranteed.
QPointer< QgsMapLayer > QgsWeakMapLayerPointer
Weak pointer for QgsMapLayer.
Definition: qgsmaplayer.h:1853