• 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
  • writers
  • kml
KmlLineStringTagWriter.cpp
Go to the documentation of this file.
1 //
2 // This file is part of the Marble Virtual Globe.
3 //
4 // This program is free software licensed under the GNU LGPL. You can
5 // find a copy of this license in LICENSE.txt in the top directory of
6 // the source code.
7 //
8 // Copyright 2010 Dennis Nienhüser <earthwings@gentoo.org>
9 // Copyright 2014 Marek Hakala <hakala.marek@gmail.com>
10 //
11 
12 #include "KmlLineStringTagWriter.h"
13 
14 #include "GeoDataLineString.h"
15 #include "GeoDataTypes.h"
16 #include "GeoWriter.h"
17 #include "KmlElementDictionary.h"
18 #include "KmlObjectTagWriter.h"
19 
20 namespace Marble
21 {
22 
23 static GeoTagWriterRegistrar s_writerLookAt(
24  GeoTagWriter::QualifiedName( GeoDataTypes::GeoDataLineStringType,
25  kml::kmlTag_nameSpaceOgc22 ),
26  new KmlLineStringTagWriter );
27 
28 bool KmlLineStringTagWriter::write( const GeoNode *node, GeoWriter& writer ) const
29 {
30  const GeoDataLineString *lineString = static_cast<const GeoDataLineString*>( node );
31 
32  if ( lineString->size() > 1 )
33  {
34  writer.writeStartElement( kml::kmlTag_LineString );
35  KmlObjectTagWriter::writeIdentifiers( writer, lineString );
36  writer.writeOptionalElement( kml::kmlTag_extrude, QString::number( lineString->extrude() ), "0" );
37  writer.writeStartElement( "coordinates" );
38 
39  // Write altitude for *all* elements, if *any* element
40  // has altitude information (!= 0.0)
41  bool hasAltitude = false;
42  for ( int i = 0; i < lineString->size(); ++i ) {
43  if ( lineString->at( i ).altitude() ) {
44  hasAltitude = true;
45  break;
46  }
47  }
48 
49  for ( int i = 0; i < lineString->size(); ++i ) {
50  GeoDataCoordinates coordinates = lineString->at( i );
51  if ( i > 0 )
52  {
53  writer.writeCharacters( " " );
54  }
55 
56  qreal lon = coordinates.longitude( GeoDataCoordinates::Degree );
57  writer.writeCharacters( QString::number( lon, 'f', 10 ) );
58  writer.writeCharacters( "," );
59  qreal lat = coordinates.latitude( GeoDataCoordinates::Degree );
60  writer.writeCharacters( QString::number( lat, 'f', 10 ) );
61 
62  if ( hasAltitude ) {
63  qreal alt = coordinates.altitude();
64  writer.writeCharacters( "," );
65  writer.writeCharacters( QString::number( alt, 'f', 2 ) );
66  }
67  }
68 
69  writer.writeEndElement();
70  writer.writeEndElement();
71 
72  return true;
73  }
74 
75  return false;
76 }
77 
78 }
Marble::kml::kmlTag_LineString
const char * kmlTag_LineString
Definition: KmlElementDictionary.cpp:100
Marble::GeoDataCoordinates
A 3d point representation.
Definition: GeoDataCoordinates.h:52
Marble::GeoWriter::writeOptionalElement
void writeOptionalElement(const QString &key, const QString &value, const QString &defaultValue=QString())
Convenience method to write value if value is not equal to defaultValue.
Definition: GeoWriter.cpp:98
Marble::s_writerLookAt
static GeoTagWriterRegistrar s_writerLookAt(GeoTagWriter::QualifiedName(GeoDataTypes::GeoDataGroundOverlayType, kml::kmlTag_nameSpaceOgc22), new KmlGroundOverlayWriter)
Marble::kml::kmlTag_extrude
const char * kmlTag_extrude
Definition: KmlElementDictionary.cpp:68
KmlObjectTagWriter.h
Marble::GeoNode
A shared base class for all classes that are mapped to a specific tag (ie.
Definition: GeoDocument.h:60
Marble::GeoDataLineString::size
int size() const
Returns the number of nodes in a LineString.
Definition: GeoDataLineString.cpp:138
Marble::GeoDataCoordinates::latitude
qreal latitude(GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) const
retrieves the latitude of the GeoDataCoordinates object use the unit parameter to switch between Radi...
Definition: GeoDataCoordinates.cpp:751
Marble::GeoDataCoordinates::Degree
Definition: GeoDataCoordinates.h:66
Marble::KmlObjectTagWriter::writeIdentifiers
static void writeIdentifiers(GeoWriter &writer, const GeoDataObject *object)
Parses the id and targetId attributes and assign their values to the given object.
Definition: KmlObjectTagWriter.cpp:15
GeoWriter.h
Marble::GeoDataGeometry::extrude
bool extrude() const
Definition: GeoDataGeometry.cpp:100
Marble::GeoDataCoordinates::altitude
qreal altitude() const
return the altitude of the Point in meters
Definition: GeoDataCoordinates.cpp:1197
QString::number
QString number(int n, int base)
Marble::KmlLineStringTagWriter::write
virtual bool write(const GeoNode *node, GeoWriter &writer) const
Definition: KmlLineStringTagWriter.cpp:28
KmlElementDictionary.h
Marble::GeoWriter
Standard Marble way of writing XML This class is intended to be a standardised way of writing XML for...
Definition: GeoWriter.h:29
GeoDataLineString.h
Marble::GeoTagWriter::QualifiedName
QPair< QString, QString > QualifiedName
Object Name and Namespace Pair This type is intended to be used in a similar way to.
Definition: GeoTagWriter.h:48
Marble::GeoDataTypes::GeoDataLineStringType
const char * GeoDataLineStringType
Definition: GeoDataTypes.cpp:53
Marble::GeoDataLineString
A LineString that allows to store a contiguous set of line segments.
Definition: GeoDataLineString.h:75
Marble::GeoDataLineString::at
GeoDataCoordinates & at(int pos)
Returns a reference to the coordinates of a node at a given position. This method detaches the return...
Definition: GeoDataLineString.cpp:143
Marble::kml::kmlTag_nameSpaceOgc22
const char * kmlTag_nameSpaceOgc22
Definition: KmlElementDictionary.cpp:34
Marble::GeoDataCoordinates::longitude
qreal longitude(GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) const
retrieves the longitude of the GeoDataCoordinates object use the unit parameter to switch between Rad...
Definition: GeoDataCoordinates.cpp:739
KmlLineStringTagWriter.h
GeoDataTypes.h
QXmlStreamWriter::writeCharacters
void writeCharacters(const QString &text)
QXmlStreamWriter::writeEndElement
void writeEndElement()
QXmlStreamWriter::writeStartElement
void writeStartElement(const QString &qualifiedName)
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:13:40 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