You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1061 lines
29 KiB
C++

// Copyright 2008, Google Inc. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// 3. Neither the name of Google Inc. nor the names of its contributors may be
// used to endorse or promote products derived from this software without
// specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// This file contains the declarations for the abstract Geometry element
// and concrete coordinates, Point, LineString, LinearRing, Polygon,
// outerBoundaryIs, and innerBoundaryIs elements.
// In addition to classes for the abstract and concrete elements in the
// KML standard there are internal convenience classes used here to hold
// common code. Each such class is named *GeometryCommon and follows
// this general pattern: constructor is protected, implements set,get,has,clear
// for the field it owns, and parses that field (implements AddElement).
// Each concrete element owns serialization of all fields for itself as per
// the order the KML standard. The KML standard does not specify the common
// simple elements in an order that maps well to a type hierarchy hence
// the more typical pattern of abstract types serializing their own
// fields is not followed here.
//
// Here is a quick summary of the type hierarchy used and what fields
// are associated with each type:
//
// class Geometry : public Object
// AbstractGeometryGroup in the KML standard. No child elements.
// class AltitudeGeometryCommon : public Geometry
// Geometry with <altitudeMode>
// class ExtrudeGeometryCommon : public AltitudeGeometryCommon
// Geometry with <altitudeMode> + <extrude>
// class CoordinatesGeometryCommon : public ExtrudeGeometryCommon
// Geometry with <altitudeMode> + <extrude> + <coordinates>
// class Point : public CoordinatesGeometryCommon
// <Point> has <altitudeMode> + <extrude> + <coordinates>
// class LineCommon : public CoordinatesGeometryCommon
// LineCommon has <altitudeMode> + <extrude> + <coordinates> + <tessellate>
// class LineString : public LineCommon
// <LineString> is an instantiation of LineCommon
// class LinearRing : public LineCommon
// <LinearRing> is an instantiation of LineCommon
// class BoundaryCommon : public Element
// BoundaryCommon has <LinearRing>
// class OuterBoundaryIs : public BoundaryCommon
// <outerBoundaryIs> is an instantiation of BoundaryCommon
// class InnerBoundaryIs : public BoundaryCommon
// <innerBoundaryIs> is an instantiation of BoundaryCommon
// class Polygon : public ExtrudeGeometryCommon
// <Polygon> has <altitudeMode> + <extrude> + <tessellate> +
// <outerBoundaryIs> and N x <innerBoundaryIs>
// class MultiGeometry : public Geometry
// Note: class Model : public AltitudeGeometryCommon
#ifndef KML_DOM_GEOMETRY_H__
#define KML_DOM_GEOMETRY_H__
#include <vector>
#include "kml/base/util.h"
#include "kml/base/vec3.h"
#include "kml/dom/extendeddata.h"
#include "kml/dom/kml22.h"
#include "kml/dom/kml_ptr.h"
#include "kml/dom/link.h" // Remove when model.h is repaired.
#include "kml/dom/object.h"
namespace kmldom {
class Serializer;
class Visitor;
class VisitorDriver;
// <coordinates>
class Coordinates : public BasicElement<Type_coordinates> {
public:
virtual ~Coordinates();
// The main KML-specific API
void add_latlngalt(double latitude, double longitude, double altitude) {
coordinates_array_.push_back(kmlbase::Vec3(longitude, latitude, altitude));
}
void add_latlng(double latitude, double longitude) {
coordinates_array_.push_back(kmlbase::Vec3(longitude, latitude));
}
void add_vec3(const kmlbase::Vec3& vec3) {
coordinates_array_.push_back(vec3);
}
size_t get_coordinates_array_size() const {
return coordinates_array_.size();
}
const kmlbase::Vec3 get_coordinates_array_at(size_t index) const {
return coordinates_array_[index];
}
// Internal methods used in parser. Public for unittest purposes.
// See .cc for more details.
void Parse(const string& char_data);
static bool ParseVec3(const char* coords, char** nextp, kmlbase::Vec3* vec);
// This clears the internal coordinates array.
void Clear() {
coordinates_array_.clear();
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
Coordinates();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
std::vector<kmlbase::Vec3> coordinates_array_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Coordinates);
};
// OGC KML 2.2 Standard: 10.1 kml:AbstractGeometryGroup
// OGC KML 2.2 XSD: <element name="AbstractGeometryGroup"...
class Geometry : public Object {
public:
virtual ~Geometry();
virtual KmlDomType Type() const { return Type_Geometry; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Geometry || Object::IsA(type);
}
protected:
// Geometry is abstract.
Geometry();
private:
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Geometry);
};
// Internal convenience class for any Geometry with <altitudeMode>.
// This is not in the KML standard, hence there is no type info.
class AltitudeGeometryCommon : public Geometry {
public:
virtual ~AltitudeGeometryCommon();
protected:
AltitudeGeometryCommon();
public:
// <altitudeMode>
int get_altitudemode() const { return altitudemode_; }
bool has_altitudemode() const { return has_altitudemode_; }
void set_altitudemode(int value) {
altitudemode_ = value;
has_altitudemode_ = true;
}
void clear_altitudemode() {
altitudemode_ = ALTITUDEMODE_CLAMPTOGROUND;
has_altitudemode_ = false;
}
// <gx:altitudeMode>
int get_gx_altitudemode() const { return gx_altitudemode_; }
bool has_gx_altitudemode() const { return has_gx_altitudemode_; }
void set_gx_altitudemode(int value) {
gx_altitudemode_ = value;
has_gx_altitudemode_ = true;
}
void clear_gx_altitudemode() {
gx_altitudemode_ = GX_ALTITUDEMODE_CLAMPTOSEAFLOOR;
has_gx_altitudemode_ = false;
}
virtual void AddElement(const ElementPtr& element);
private:
int altitudemode_;
bool has_altitudemode_;
int gx_altitudemode_;
bool has_gx_altitudemode_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(AltitudeGeometryCommon);
};
// Internal convenience class for any Geometry with <altitudeMode> + <extrude>
// This is not in the KML standard, hence there is no type info.
class ExtrudeGeometryCommon : public AltitudeGeometryCommon {
public:
virtual ~ExtrudeGeometryCommon();
// <extrude>
bool get_extrude() const { return extrude_; }
bool has_extrude() const { return has_extrude_; }
void set_extrude(bool value) {
extrude_ = value;
has_extrude_ = true;
}
void clear_extrude() {
extrude_ = false;
has_extrude_ = false;
}
protected:
ExtrudeGeometryCommon();
virtual void AddElement(const ElementPtr& element);
private:
bool extrude_;
bool has_extrude_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(ExtrudeGeometryCommon);
};
// Internal convenience class for any Geometry with
// <altitudeMode> + <extrude> + <coordinates>.
// This is not in the KML standard, hence there is no type info.
class CoordinatesGeometryCommon : public ExtrudeGeometryCommon {
public:
virtual ~CoordinatesGeometryCommon();
public:
// <coordinates>
const CoordinatesPtr& get_coordinates() const { return coordinates_; }
bool has_coordinates() const { return coordinates_ != NULL; }
void set_coordinates(const CoordinatesPtr& coordinates) {
SetComplexChild(coordinates, &coordinates_);
}
void clear_coordinates() {
set_coordinates(NULL);
}
// Visitor API methods, see visitor.h.
virtual void AcceptChildren(VisitorDriver* driver);
protected:
CoordinatesGeometryCommon();
// Parser support
virtual void AddElement(const ElementPtr& element);
private:
CoordinatesPtr coordinates_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(CoordinatesGeometryCommon);
};
// <Point>
class Point : public CoordinatesGeometryCommon {
public:
virtual ~Point();
virtual KmlDomType Type() const { return Type_Point; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Point || Geometry::IsA(type);
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
Point();
friend class Serializer;
void Serialize(Serializer& serializer) const;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Point);
};
// Internal convenience class for code common to LineString and LinearRing.
// This is not in the KML standard, hence there is no type info.
class LineCommon : public CoordinatesGeometryCommon {
public:
virtual ~LineCommon();
public:
// <tessellate>
bool get_tessellate() const { return tessellate_; }
bool has_tessellate() const { return has_tessellate_; }
void set_tessellate(bool value) {
tessellate_ = value;
has_tessellate_ = true;
}
void clear_tessellate() {
tessellate_ = false;
has_tessellate_ = false;
}
protected:
LineCommon();
// Parser support
virtual void AddElement(const ElementPtr& element);
private:
friend class Serializer;
void Serialize(Serializer& serializer) const;
bool tessellate_;
bool has_tessellate_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(LineCommon);
};
// <LineString>
class LineString : public LineCommon {
public:
virtual ~LineString();
virtual KmlDomType Type() const { return Type_LineString; }
virtual bool IsA(KmlDomType type) const {
return type == Type_LineString || Geometry::IsA(type);
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
LineString();
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(LineString);
};
// <LinearRing>
class LinearRing : public LineCommon {
public:
virtual ~LinearRing();
virtual KmlDomType Type() const { return Type_LinearRing; }
virtual bool IsA(KmlDomType type) const {
return type == Type_LinearRing || Geometry::IsA(type);
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
LinearRing();
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(LinearRing);
};
// Internal class for code common to OuterBoundaryIs and InnerBoundaryIs.
// This is not in the KML standard, hence there is no type info.
class BoundaryCommon : public Element {
public:
virtual ~BoundaryCommon();
public:
const LinearRingPtr& get_linearring() const { return linearring_; }
bool has_linearring() const { return linearring_ != NULL; }
void set_linearring(const LinearRingPtr& linearring) {
SetComplexChild(linearring, &linearring_);
}
void clear_linearring() {
set_linearring(NULL);
}
// Parser support
virtual void AddElement(const ElementPtr& element);
// Visitor API methods, see visitor.h.
virtual void AcceptChildren(VisitorDriver* driver);
protected:
BoundaryCommon();
virtual void Serialize(Serializer& serializer) const;
private:
LinearRingPtr linearring_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(BoundaryCommon);
};
// <outerBoundaryIs>
class OuterBoundaryIs : public BoundaryCommon {
public:
virtual ~OuterBoundaryIs();
virtual KmlDomType Type() const { return Type_outerBoundaryIs; }
virtual bool IsA(KmlDomType type) const {
return type == Type_outerBoundaryIs;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
OuterBoundaryIs();
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(OuterBoundaryIs);
};
// <innerBoundaryIs>
class InnerBoundaryIs : public BoundaryCommon {
public:
virtual ~InnerBoundaryIs();
virtual KmlDomType Type() const { return Type_innerBoundaryIs; }
virtual bool IsA(KmlDomType type) const {
return type == Type_innerBoundaryIs;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
InnerBoundaryIs();
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(InnerBoundaryIs);
};
// <Polygon>
class Polygon : public ExtrudeGeometryCommon {
public:
virtual ~Polygon();
virtual KmlDomType Type() const { return Type_Polygon; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Polygon || Geometry::IsA(type);
}
// <tessellate>
bool get_tessellate() const { return tessellate_; }
bool has_tessellate() const { return has_tessellate_; }
void set_tessellate(bool value) {
tessellate_ = value;
has_tessellate_ = true;
}
void clear_tessellate() {
tessellate_ = false;
has_tessellate_ = false;
}
// <outerBoundaryIs>
const OuterBoundaryIsPtr& get_outerboundaryis() const {
return outerboundaryis_;
}
bool has_outerboundaryis() const { return outerboundaryis_ != NULL; }
void set_outerboundaryis(const OuterBoundaryIsPtr& outerboundaryis) {
SetComplexChild(outerboundaryis, &outerboundaryis_);
}
void clear_outerboundaryis() {
set_outerboundaryis(NULL);
}
// <innerBoundaryIs>
void add_innerboundaryis(const InnerBoundaryIsPtr& innerboundaryis) {
AddComplexChild(innerboundaryis, &innerboundaryis_array_);
}
size_t get_innerboundaryis_array_size() const {
return innerboundaryis_array_.size();
}
const InnerBoundaryIsPtr& get_innerboundaryis_array_at(size_t index) {
return innerboundaryis_array_[index];
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
virtual void AcceptChildren(VisitorDriver* driver);
private:
friend class KmlFactory;
Polygon();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
bool tessellate_;
bool has_tessellate_;
OuterBoundaryIsPtr outerboundaryis_;
std::vector<InnerBoundaryIsPtr> innerboundaryis_array_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Polygon);
};
// <MultiGeometry>
class MultiGeometry : public Geometry {
public:
virtual ~MultiGeometry();
virtual KmlDomType Type() const { return Type_MultiGeometry; }
virtual bool IsA(KmlDomType type) const {
return type == Type_MultiGeometry || Geometry::IsA(type);
}
// The main KML-specific API
void add_geometry(const GeometryPtr& geometry);
size_t get_geometry_array_size() const {
return geometry_array_.size();
}
const GeometryPtr& get_geometry_array_at(size_t index) const {
return geometry_array_[index];
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
virtual void AcceptChildren(VisitorDriver* driver);
private:
friend class KmlFactory;
MultiGeometry();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
std::vector<GeometryPtr> geometry_array_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(MultiGeometry);
};
// <gx:Track>
class GxTrack : public AltitudeGeometryCommon {
public:
virtual ~GxTrack();
static KmlDomType ElementType() { return Type_GxTrack; }
virtual KmlDomType Type() const { return ElementType(); }
virtual bool IsA(KmlDomType type) const {
return type == ElementType() || Geometry::IsA(type);
}
// <when>
size_t get_when_array_size() {
return when_array_.size();
}
void add_when(const string& when) {
when_array_.push_back(when);
}
const string& get_when_array_at(size_t index) const {
return when_array_[index];
}
// <gx:coord>
size_t get_gx_coord_array_size() {
return gx_coord_array_.size();
}
void add_gx_coord(const kmlbase::Vec3& gx_coord) {
gx_coord_array_.push_back(gx_coord);
}
const kmlbase::Vec3& get_gx_coord_array_at(size_t index) const {
return gx_coord_array_[index];
}
// <gx:angles>
size_t get_gx_angles_array_size() {
return gx_angles_array_.size();
}
void add_gx_angles(const kmlbase::Vec3& gx_angles) {
gx_angles_array_.push_back(gx_angles);
}
const kmlbase::Vec3& get_gx_angles_array_at(size_t index) const {
return gx_angles_array_[index];
}
// <Model>
const ModelPtr& get_model() const { return model_; }
void set_model(const ModelPtr& model) {
SetComplexChild(model, &model_);
}
bool has_model() const { return model_ != NULL; }
void clear_model() { set_model(NULL); }
// <ExtendedData>
const ExtendedDataPtr& get_extendeddata() const { return extendeddata_; }
bool has_extendeddata() const { return extendeddata_ != NULL; }
void set_extendeddata(const ExtendedDataPtr& extendeddata) {
SetComplexChild(extendeddata, &extendeddata_);
}
void clear_extendeddata() {
set_extendeddata(NULL);
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
virtual void AcceptChildren(VisitorDriver* driver);
// Internal methods used in parser. Public for unittest purposes.
// See .cc for more details.
void Parse(const string& char_data, std::vector<kmlbase::Vec3>* out);
private:
friend class KmlFactory;
GxTrack();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
std::vector<string> when_array_;
std::vector<kmlbase::Vec3> gx_coord_array_;
std::vector<kmlbase::Vec3> gx_angles_array_;
ModelPtr model_;
ExtendedDataPtr extendeddata_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(GxTrack);
};
// <gx:MultiTrack>
class GxMultiTrack : public Geometry {
public:
virtual ~GxMultiTrack();
static KmlDomType ElementType() { return Type_GxMultiTrack; }
virtual KmlDomType Type() const { return ElementType(); }
virtual bool IsA(KmlDomType type) const {
return type == ElementType() || Geometry::IsA(type);
}
bool get_gx_interpolate() const { return gx_interpolate_; }
bool has_gx_interpolate() const { return has_gx_interpolate_; }
void set_gx_interpolate(bool value) {
gx_interpolate_ = value;
has_gx_interpolate_ = true;
}
void clear_gx_interpolate() {
gx_interpolate_ = false; // Default <gx:interpolate> is false.
has_gx_interpolate_ = false;
}
void add_gx_track(const GxTrackPtr& gx_track);
size_t get_gx_track_array_size() const {
return gx_track_array_.size();
}
const GxTrackPtr& get_gx_track_array_at(size_t index) const {
return gx_track_array_[index];
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
virtual void AcceptChildren(VisitorDriver* driver);
private:
friend class KmlFactory;
GxMultiTrack();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
bool gx_interpolate_;
bool has_gx_interpolate_;
std::vector<GxTrackPtr> gx_track_array_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(GxMultiTrack);
};
// HACK: the rest of this file contains what was in, and what should return to,
// kml/dom/model.h. GxTrack was added to this file, which has a <Model>. Since
// Model is defined in its own file, this double inclusion, coupled with the
// inline implementation of most methods in the headers, caused the builds of
// other dependent projects to break. The correct solution is to ensure that
// the headers are pure and all implementation is in the .cc files.
// <Location>
class Location : public Object {
public:
virtual ~Location();
virtual KmlDomType Type() const { return Type_Location; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Location || Object::IsA(type);
}
// <longitude>
double get_longitude() const {
return longitude_;
}
bool has_longitude() const {
return has_longitude_;
}
void set_longitude(double longitude) {
longitude_ = longitude;
has_longitude_ = true;
}
void clear_longitude() {
longitude_ = 0.0;
has_longitude_ = false;
}
// <latitude>
double get_latitude() const {
return latitude_;
}
bool has_latitude() const {
return has_latitude_;
}
void set_latitude(double latitude) {
latitude_ = latitude;
has_latitude_ = true;
}
void clear_latitude() {
latitude_ = 0.0;
has_latitude_ = false;
}
// <altitude>
double get_altitude() const {
return altitude_;
}
bool has_altitude() const {
return has_altitude_;
}
void set_altitude(double altitude) {
altitude_ = altitude;
has_altitude_ = true;
}
void clear_altitude() {
altitude_ = 0.0;
has_altitude_ = false;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
Location();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
double longitude_;
bool has_longitude_;
double latitude_;
bool has_latitude_;
double altitude_;
bool has_altitude_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Location);
};
// <Orientation>
class Orientation : public Object {
public:
virtual ~Orientation();
virtual KmlDomType Type() const { return Type_Orientation; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Orientation || Object::IsA(type);
}
// <heading>
double get_heading() const {
return heading_;
}
bool has_heading() const {
return has_heading_;
}
void set_heading(double heading) {
heading_ = heading;
has_heading_ = true;
}
void clear_heading() {
heading_ = 0.0;
has_heading_ = false;
}
// <tilt>
double get_tilt() const {
return tilt_;
}
bool has_tilt() const {
return has_tilt_;
}
void set_tilt(double tilt) {
tilt_ = tilt;
has_tilt_ = true;
}
void clear_tilt() {
tilt_ = 0.0;
has_tilt_ = false;
}
// <roll>
double get_roll() const {
return roll_;
}
bool has_roll() const {
return has_roll_;
}
void set_roll(double roll) {
roll_ = roll;
has_roll_ = true;
}
void clear_roll() {
roll_ = 0.0;
has_roll_ = false;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
Orientation();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
double heading_;
bool has_heading_;
double tilt_;
bool has_tilt_;
double roll_;
bool has_roll_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Orientation);
};
// <Scale>
class Scale : public Object {
public:
virtual ~Scale();
virtual KmlDomType Type() const { return Type_Scale; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Scale || Object::IsA(type);
}
// <x>
double get_x() const {
return x_;
}
bool has_x() const {
return has_x_;
}
void set_x(double x) {
x_ = x;
has_x_ = true;
}
void clear_x() {
x_ = 1.0;
has_x_ = false;
}
// <y>
double get_y() const {
return y_;
}
bool has_y() const {
return has_y_;
}
void set_y(double y) {
y_ = y;
has_y_ = true;
}
void clear_y() {
y_ = 1.0;
has_y_ = false;
}
// <z>
double get_z() const {
return z_;
}
bool has_z() const {
return has_z_;
}
void set_z(double z) {
z_ = z;
has_z_ = true;
}
void clear_z() {
z_ = 1.0;
has_z_ = false;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
Scale();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
double x_;
bool has_x_;
double y_;
bool has_y_;
double z_;
bool has_z_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Scale);
};
// <Alias>
class Alias : public Object {
public:
virtual ~Alias();
virtual KmlDomType Type() const { return Type_Alias; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Alias || Object::IsA(type);
}
// <targetHref>
const string& get_targethref() const {
return targethref_;
}
bool has_targethref() const {
return has_targethref_;
}
void set_targethref(const string& targethref) {
targethref_ = targethref;
has_targethref_ = true;
}
void clear_targethref() {
targethref_.clear();
has_targethref_ = false;
}
// <sourceHref>
const string& get_sourcehref() const {
return sourcehref_;
}
bool has_sourcehref() const {
return has_sourcehref_;
}
void set_sourcehref(const string& sourcehref) {
sourcehref_ = sourcehref;
has_sourcehref_ = true;
}
void clear_sourcehref() {
sourcehref_.clear();
has_sourcehref_ = false;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
private:
friend class KmlFactory;
Alias();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
string targethref_;
bool has_targethref_;
string sourcehref_;
bool has_sourcehref_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Alias);
};
// <ResourceMap>
class ResourceMap : public Object {
public:
virtual ~ResourceMap();
virtual KmlDomType Type() const { return Type_ResourceMap; }
virtual bool IsA(KmlDomType type) const {
return type == Type_ResourceMap || Object::IsA(type);
}
void add_alias(const AliasPtr& alias);
size_t get_alias_array_size() const {
return alias_array_.size();
}
const AliasPtr& get_alias_array_at(size_t index) const {
return alias_array_[index];
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
virtual void AcceptChildren(VisitorDriver* driver);
private:
friend class KmlFactory;
ResourceMap();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
std::vector<AliasPtr> alias_array_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(ResourceMap);
};
// <Model>
class Model : public AltitudeGeometryCommon {
public:
virtual ~Model();
virtual KmlDomType Type() const { return Type_Model; }
virtual bool IsA(KmlDomType type) const {
return type == Type_Model || Geometry::IsA(type);
}
// <Location>
const LocationPtr& get_location() const { return location_; }
bool has_location() const { return location_ != NULL; }
void set_location(const LocationPtr& location) {
SetComplexChild(location, &location_);
}
void clear_location() {
set_location(NULL);
}
// <Orientation>
const OrientationPtr& get_orientation() const { return orientation_; }
bool has_orientation() const { return orientation_ != NULL; }
void set_orientation(const OrientationPtr& orientation) {
SetComplexChild(orientation, &orientation_);
}
void clear_orientation() {
set_orientation(NULL);
}
// <Scale>
const ScalePtr& get_scale() const { return scale_; }
bool has_scale() const { return scale_ != NULL; }
void set_scale(const ScalePtr& scale) {
SetComplexChild(scale, &scale_);
}
void clear_scale() {
set_scale(NULL);
}
// <Link>
const LinkPtr& get_link() const { return link_; }
bool has_link() const { return link_ != NULL; }
void set_link(const LinkPtr& link) {
SetComplexChild(link, &link_);
}
void clear_link() {
set_link(NULL);
}
// <ResourceMap>
const ResourceMapPtr& get_resourcemap() const { return resourcemap_; }
bool has_resourcemap() const { return resourcemap_ != NULL; }
void set_resourcemap(const ResourceMapPtr& resourcemap) {
SetComplexChild(resourcemap, &resourcemap_);
}
void clear_resourcemap() {
resourcemap_ = NULL;
}
// Visitor API methods, see visitor.h.
virtual void Accept(Visitor* visitor);
virtual void AcceptChildren(VisitorDriver* driver);
private:
friend class KmlFactory;
Model();
friend class KmlHandler;
virtual void AddElement(const ElementPtr& element);
friend class Serializer;
virtual void Serialize(Serializer& serializer) const;
LocationPtr location_;
OrientationPtr orientation_;
ScalePtr scale_;
LinkPtr link_;
ResourceMapPtr resourcemap_;
LIBKML_DISALLOW_EVIL_CONSTRUCTORS(Model);
};
} // namespace kmldom
#endif // KML_DOM_GEOMETRY_H__