QGIS API Documentation  2.14.0-Essen
qgsrendererv2registry.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgsrendererv2registry.cpp
3  ---------------------
4  begin : November 2009
5  copyright : (C) 2009 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 #include "qgsrendererv2registry.h"
16 
17 // default renderers
21 #include "qgsrulebasedrendererv2.h"
24 #include "qgsheatmaprenderer.h"
25 #include "qgs25drenderer.h"
26 
28 {
29  // add default renderers
30  addRenderer( new QgsRendererV2Metadata( "singleSymbol",
31  QObject::tr( "Single Symbol" ),
34 
35  addRenderer( new QgsRendererV2Metadata( "categorizedSymbol",
36  QObject::tr( "Categorized" ),
38 
39  addRenderer( new QgsRendererV2Metadata( "graduatedSymbol",
40  QObject::tr( "Graduated" ),
42 
43  addRenderer( new QgsRendererV2Metadata( "RuleRenderer",
44  QObject::tr( "Rule-based" ),
47 
48  addRenderer( new QgsRendererV2Metadata( "pointDisplacement",
49  QObject::tr( "Point Displacement" ),
51 
52  addRenderer( new QgsRendererV2Metadata( "invertedPolygonRenderer",
53  QObject::tr( "Inverted Polygons" ),
55 
56  addRenderer( new QgsRendererV2Metadata( "heatmapRenderer",
57  QObject::tr( "Heatmap" ),
59 
60 
61  addRenderer( new QgsRendererV2Metadata( "25dRenderer",
62  QObject::tr( "2.5 D" ),
64 }
65 
67 {
68  qDeleteAll( mRenderers );
69 }
70 
72 {
73  static QgsRendererV2Registry mInstance;
74  return &mInstance;
75 }
76 
77 
79 {
80  if ( !metadata || mRenderers.contains( metadata->name() ) )
81  return false;
82 
83  mRenderers[metadata->name()] = metadata;
84  mRenderersOrder << metadata->name();
85  return true;
86 }
87 
89 {
90  if ( !mRenderers.contains( rendererName ) )
91  return false;
92 
93  delete mRenderers[rendererName];
94  mRenderers.remove( rendererName );
95  mRenderersOrder.removeAll( rendererName );
96  return true;
97 }
98 
100 {
101  return mRenderers.value( rendererName );
102 }
103 
105 
107 {
108  return mRenderersOrder;
109 }
static QgsRendererV2Registry * instance()
bool contains(const Key &key) const
static QgsFeatureRendererV2 * create(QDomElement &element)
static QgsFeatureRendererV2 * create(QDomElement &element)
static QgsFeatureRendererV2 * create(QDomElement &symbologyElem)
create a renderer from XML element
QMap< QString, QgsRendererV2AbstractMetadata * > mRenderers
static QgsFeatureRendererV2 * create(QDomElement &element)
Create a new 2.5D renderer from XML.
static QgsFeatureRendererV2 * createFromSld(QDomElement &element, QGis::GeometryType geomType)
static QgsFeatureRendererV2 * createFromSld(QDomElement &element, QGis::GeometryType geomType)
Stores metadata about one renderer class.
bool removeRenderer(const QString &rendererName)
remove renderer from registry
QString tr(const char *sourceText, const char *disambiguation, int n)
Registry of renderers.
QgsRendererV2AbstractMetadata * rendererMetadata(const QString &rendererName)
get metadata for particular renderer. Returns NULL if not found in registry.
QStringList renderersList()
return a list of available renderers
static QgsFeatureRendererV2 * create(QDomElement &element)
create renderer from XML element
int removeAll(const T &value)
bool addRenderer(QgsRendererV2AbstractMetadata *metadata)
add a renderer to registry. Takes ownership of the metadata object.
QgsRendererV2Registry()
protected constructor
Convenience metadata class that uses static functions to create renderer and its widget.
static QgsFeatureRendererV2 * create(QDomElement &element)
create renderer from XML element
static QgsFeatureRendererV2 * create(QDomElement &element)
create renderer from XML element
static QgsFeatureRendererV2 * create(QDomElement &element)
Creates a renderer out of an XML, for loading.
QStringList mRenderersOrder
list to keep order in which renderers have been added
const T value(const Key &key) const
int remove(const Key &key)