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

marble

  • sources
  • kde-4.14
  • kdeedu
  • marble
  • src
  • lib
  • marble
  • geodata
  • handlers
  • dgml
DgmlProjectionTagHandler.cpp
Go to the documentation of this file.
1 /*
2  Copyright (C) 2008 Jens-Michael Hoffmann <jensmh@gmx.de>
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 // Own
23 #include "DgmlProjectionTagHandler.h"
24 
25 // Marble
26 #include "DgmlAttributeDictionary.h"
27 #include "DgmlElementDictionary.h"
28 #include "GeoParser.h"
29 #include "GeoSceneTiled.h"
30 
31 namespace Marble
32 {
33 namespace dgml
34 {
35 DGML_DEFINE_TAG_HANDLER(Projection)
36 
37 GeoNode* DgmlProjectionTagHandler::parse( GeoParser& parser ) const
38 {
39  // Check whether the tag is valid
40  Q_ASSERT( parser.isStartElement() && parser.isValidElement( dgmlTag_Projection ));
41 
42  // Checking for parent item
43  GeoStackItem parentItem = parser.parentElement();
44  if ( !parentItem.represents( dgmlTag_Texture ) && !parentItem.represents( dgmlTag_Vectortile))
45  return 0;
46 
47  // Attribute name, default to "Equirectangular"
48  const QString nameStr = parser.attribute( dgmlAttr_name ).trimmed();
49  if ( !nameStr.isEmpty() ) {
50  GeoSceneTiled::Projection projection = GeoSceneTiled::Equirectangular;
51  if ( nameStr == "Equirectangular" )
52  projection = GeoSceneTiled::Equirectangular;
53  else if ( nameStr == "Mercator" )
54  projection = GeoSceneTiled::Mercator;
55  else
56  parser.raiseWarning( QString( "Value not allowed for attribute name: %1" ).arg( nameStr ));
57 
58  parentItem.nodeAs<GeoSceneTiled>()->setProjection( projection );
59  }
60  return 0;
61 }
62 
63 }
64 }
DgmlAttributeDictionary.h
Marble::GeoSceneTiled::Equirectangular
Definition: GeoSceneTiled.h:47
DGML_DEFINE_TAG_HANDLER
#define DGML_DEFINE_TAG_HANDLER(Name)
Definition: DgmlElementDictionary.h:85
Marble::GeoNode
A shared base class for all classes that are mapped to a specific tag (ie.
Definition: GeoDocument.h:60
GeoParser.h
Marble::GeoSceneTiled::Projection
Projection
Definition: GeoSceneTiled.h:47
Marble::dgml::dgmlTag_Projection
const char * dgmlTag_Projection
Definition: DgmlElementDictionary.cpp:62
Marble::GeoSceneTiled
Definition: GeoSceneTiled.h:43
Marble::dgml::dgmlTag_Texture
const char * dgmlTag_Texture
Definition: DgmlElementDictionary.cpp:71
Marble::dgml::dgmlAttr_name
const char * dgmlAttr_name
Definition: DgmlAttributeDictionary.cpp:54
Marble::GeoParser
Definition: GeoParser.h:40
DgmlProjectionTagHandler.h
QString::isEmpty
bool isEmpty() const
QString::trimmed
QString trimmed() const
DgmlElementDictionary.h
Marble::GeoStackItem
Definition: GeoParser.h:97
QString
Marble::GeoSceneTiled::Mercator
Definition: GeoSceneTiled.h:47
Marble::dgml::DgmlProjectionTagHandler
Definition: DgmlProjectionTagHandler.h:32
Marble::dgml::dgmlTag_Vectortile
const char * dgmlTag_Vectortile
Definition: DgmlElementDictionary.cpp:76
GeoSceneTiled.h
Marble::Projection
Projection
This enum is used to choose the projection shown in the view.
Definition: MarbleGlobal.h:44
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:13:38 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
  • 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