• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdeedu API Reference
  • KDE Home
  • Contact Us
 

marble

  • sources
  • kde-4.12
  • kdeedu
  • marble
  • src
  • lib
  • marble
  • geodata
  • scene
GeoSceneMap.cpp
Go to the documentation of this file.
1 /*
2  Copyright (C) 2008 Torsten Rahn <rahn@kde.org>
3 
4  This file is part of the KDE project
5 
6  This library is free software you can redistribute it and/or
7  modify it under the terms of the GNU Library General Public
8  License as published by the Free Software Foundation either
9  version 2 of the License, or (at your option) any later version.
10 
11  This library is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  Library General Public License for more details.
15 
16  You should have received a copy of the GNU Library General Public License
17  aint with this library see the file COPYING.LIB. If not, write to
18  the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19  Boston, MA 02110-1301, USA.
20 */
21 
22 #include "GeoSceneMap.h"
23 
24 #include "GeoSceneTypes.h"
25 #include "GeoSceneLayer.h"
26 #include "GeoSceneFilter.h"
27 #include "DgmlAuxillaryDictionary.h"
28 
29 namespace Marble
30 {
31 
32 // FIXME: Filters are a Dataset.
33 
34 class GeoSceneMapPrivate
35 {
36  public:
37  GeoSceneMapPrivate()
38  : m_backgroundColor( "" )
39  {
40  }
41 
42  ~GeoSceneMapPrivate()
43  {
44  qDeleteAll( m_layers );
45  qDeleteAll( m_filters );
46  }
47 
48  const char* nodeType() const
49  {
50  return GeoSceneTypes::GeoSceneMapType;
51  }
52 
56  QVector<GeoSceneLayer*> m_layers;
57 
59  QVector<GeoSceneFilter*> m_filters;
60 
61  QColor m_backgroundColor;
62  QColor m_labelColor;
63 };
64 
65 
66 GeoSceneMap::GeoSceneMap()
67  : d ( new GeoSceneMapPrivate )
68 {
69 }
70 
71 GeoSceneMap::~GeoSceneMap()
72 {
73  delete d;
74 }
75 
76 const char* GeoSceneMap::nodeType() const
77 {
78  return d->nodeType();
79 }
80 
81 void GeoSceneMap::addLayer( GeoSceneLayer* layer )
82 {
83  // Remove any layer that has the same name
84  QVector<GeoSceneLayer*>::iterator it = d->m_layers.begin();
85  while (it != d->m_layers.end()) {
86  GeoSceneLayer* currentLayer = *it;
87  if ( currentLayer->name() == layer->name() ) {
88  delete currentLayer;
89  it = d->m_layers.erase(it);
90  break;
91  }
92  else {
93  ++it;
94  }
95  }
96 
97  if ( layer ) {
98  d->m_layers.append( layer );
99  }
100 }
101 
102 GeoSceneLayer* GeoSceneMap::layer( const QString& name )
103 {
104  GeoSceneLayer* layer = 0;
105 
106  QVector<GeoSceneLayer*>::const_iterator it = d->m_layers.constBegin();
107  QVector<GeoSceneLayer*>::const_iterator end = d->m_layers.constEnd();
108  for (; it != end; ++it) {
109  if ( (*it)->name() == name ) {
110  layer = *it;
111  break;
112  }
113  }
114 
115  if ( !layer ) {
116  layer = new GeoSceneLayer( name );
117  addLayer( layer );
118  }
119 
120  return layer;
121 }
122 
123 const GeoSceneLayer* GeoSceneMap::layer( const QString& name ) const
124 {
125  const GeoSceneLayer* layer = 0;
126 
127  QVector<GeoSceneLayer*>::const_iterator it = d->m_layers.constBegin();
128  QVector<GeoSceneLayer*>::const_iterator end = d->m_layers.constEnd();
129  for (; it != end; ++it) {
130  if ( (*it)->name() == name ) {
131  layer = *it;
132  break;
133  }
134  }
135  return layer;
136 }
137 
138 QVector<GeoSceneLayer*> GeoSceneMap::layers() const
139 {
140  return d->m_layers;
141 }
142 
143 void GeoSceneMap::addFilter( GeoSceneFilter* filter )
144 {
145  // Remove any filter that has the same name
146  QVector<GeoSceneFilter*>::iterator it = d->m_filters.begin();
147  while (it != d->m_filters.end()) {
148  GeoSceneFilter* currentFilter = *it;
149  if ( currentFilter->name() == filter->name() ) {
150  delete currentFilter;
151  it = d->m_filters.erase(it);
152  break;
153  }
154  else {
155  ++it;
156  }
157  }
158 
159  if ( filter ) {
160  d->m_filters.append( filter );
161  }
162 }
163 
164 GeoSceneFilter* GeoSceneMap::filter( const QString& name )
165 {
166  GeoSceneFilter* filter = 0;
167 
168  QVector<GeoSceneFilter*>::const_iterator it = d->m_filters.constBegin();
169  QVector<GeoSceneFilter*>::const_iterator end = d->m_filters.constEnd();
170  for (; it != end; ++it) {
171  if ( (*it)->name() == name ) {
172  filter = *it;
173  break;
174  }
175  }
176 
177  if ( !filter ) {
178  filter = new GeoSceneFilter( name );
179  addFilter( filter );
180  }
181 
182  return filter;
183 }
184 
185 QVector<GeoSceneFilter*> GeoSceneMap::filters() const
186 {
187  return d->m_filters;
188 }
189 
190 bool GeoSceneMap::hasTextureLayers() const
191 {
192  QVector<GeoSceneLayer*>::const_iterator it = d->m_layers.constBegin();
193  QVector<GeoSceneLayer*>::const_iterator end = d->m_layers.constEnd();
194  for (; it != end; ++it) {
195  if ( ( (*it)->backend() == dgml::dgmlValue_texture
196  || (*it)->backend() == dgml::dgmlValue_vectortile ) && (*it)->datasets().count() > 0 )
197  return true;
198  }
199 
200  return false;
201 }
202 
203 bool GeoSceneMap::hasVectorLayers() const
204 {
205  QVector<GeoSceneLayer*>::const_iterator it = d->m_layers.constBegin();
206  QVector<GeoSceneLayer*>::const_iterator end = d->m_layers.constEnd();
207  for (; it != end; ++it) {
208  if ( ( (*it)->backend() == dgml::dgmlValue_vector ) && (*it)->datasets().count() > 0 )
209  return true;
210  }
211 
212  return false;
213 }
214 
215 QColor GeoSceneMap::backgroundColor() const
216 {
217  return d->m_backgroundColor;
218 }
219 
220 void GeoSceneMap::setBackgroundColor( const QColor& backgroundColor )
221 {
222  d->m_backgroundColor = backgroundColor;
223 }
224 
225 
226 QColor GeoSceneMap::labelColor() const
227 {
228  return d->m_labelColor;
229 }
230 
231 void GeoSceneMap::setLabelColor( const QColor& backgroundColor )
232 {
233  d->m_labelColor = backgroundColor;
234 }
235 
236 }
GeoSceneTypes.h
Marble::GeoSceneFilter::name
QString name() const
Definition: GeoSceneFilter.cpp:40
Marble::GeoSceneMap::GeoSceneMap
GeoSceneMap()
Definition: GeoSceneMap.cpp:66
Marble::GeoSceneMap::filter
GeoSceneFilter * filter(const QString &name)
Return a filter by its name.
Definition: GeoSceneMap.cpp:164
DgmlAuxillaryDictionary.h
Marble::GeoSceneTypes::GeoSceneMapType
const char * GeoSceneMapType
Definition: GeoSceneTypes.cpp:27
Marble::GeoSceneMap::layer
GeoSceneLayer * layer(const QString &name)
Return a layer by its name.
Definition: GeoSceneMap.cpp:102
Marble::GeoSceneMap::setBackgroundColor
void setBackgroundColor(const QColor &)
Definition: GeoSceneMap.cpp:220
Marble::GeoSceneMap::setLabelColor
void setLabelColor(const QColor &)
Definition: GeoSceneMap.cpp:231
Marble::GeoSceneMap::nodeType
virtual const char * nodeType() const
Definition: GeoSceneMap.cpp:76
Marble::GeoSceneMap::filters
QVector< GeoSceneFilter * > filters() const
Return all filters.
Definition: GeoSceneMap.cpp:185
Marble::GeoSceneLayer
Layer of a GeoScene document.
Definition: GeoSceneLayer.h:43
Marble::GeoSceneLayer::name
QString name() const
Definition: GeoSceneLayer.cpp:129
GeoSceneFilter.h
Marble::GeoSceneMap::addFilter
void addFilter(GeoSceneFilter *)
Add a new filter to the map.
Definition: GeoSceneMap.cpp:143
Marble::GeoSceneMap::labelColor
QColor labelColor() const
Definition: GeoSceneMap.cpp:226
Marble::GeoSceneMap::addLayer
void addLayer(GeoSceneLayer *)
Add a new layer to the map.
Definition: GeoSceneMap.cpp:81
Marble::GeoSceneFilter
Filter of a GeoScene document.
Definition: GeoSceneFilter.h:39
Marble::GeoSceneMap::~GeoSceneMap
~GeoSceneMap()
Definition: GeoSceneMap.cpp:71
Marble::GeoSceneMap::hasVectorLayers
bool hasVectorLayers() const
Checks for valid layers that contain vector data.
Definition: GeoSceneMap.cpp:203
Marble::dgml::dgmlValue_texture
const char * dgmlValue_texture
Definition: DgmlAuxillaryDictionary.cpp:38
Marble::GeoSceneMap::backgroundColor
QColor backgroundColor() const
Definition: GeoSceneMap.cpp:215
GeoSceneMap.h
Marble::dgml::dgmlValue_vector
const char * dgmlValue_vector
Definition: DgmlAuxillaryDictionary.cpp:39
Marble::GeoSceneMap::layers
QVector< GeoSceneLayer * > layers() const
Return all layers.
Definition: GeoSceneMap.cpp:138
Marble::GeoSceneMap::hasTextureLayers
bool hasTextureLayers() const
Checks for valid layers that contain texture data.
Definition: GeoSceneMap.cpp:190
GeoSceneLayer.h
Marble::dgml::dgmlValue_vectortile
const char * dgmlValue_vectortile
Definition: DgmlAuxillaryDictionary.cpp:40
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:38:50 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

marble

Skip menu "marble"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

kdeedu API Reference

Skip menu "kdeedu API Reference"
  • Analitza
  •     lib
  • kalgebra
  • kalzium
  •   libscience
  • kanagram
  • kig
  •   lib
  • klettres
  • kstars
  • libkdeedu
  •   keduvocdocument
  • marble
  • parley
  • rocs
  •   App
  •   RocsCore
  •   VisualEditor
  •   stepcore

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal