Merge pull request #200 from pgiraud/gpx
Adding missing schemalocation, version. Better management of the namespaces.
This commit is contained in:
@@ -57,11 +57,20 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
extractAttributes: true,
|
||||
|
||||
/**
|
||||
* APIProperty: gpxns
|
||||
* {String} GPX namespace to use. Defaults to
|
||||
* "http://www.topografix.com/GPX/1/1"
|
||||
* Property: namespaces
|
||||
* {Object} Mapping of namespace aliases to namespace URIs.
|
||||
*/
|
||||
gpxns: "http://www.topografix.com/GPX/1/1",
|
||||
namespaces: {
|
||||
gpx: "http://www.topografix.com/GPX/1/1",
|
||||
xsi: "http://www.w3.org/2001/XMLSchema-instance"
|
||||
},
|
||||
|
||||
/**
|
||||
* Property: schemaLocation
|
||||
* {String} Schema location. Defaults to
|
||||
* "http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd"
|
||||
*/
|
||||
schemaLocation: "http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd",
|
||||
|
||||
/**
|
||||
* Constructor: OpenLayers.Format.GPX
|
||||
@@ -207,17 +216,20 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
* add to the gpx. Supported keys are 'name', 'desc', 'author'.
|
||||
*/
|
||||
write: function(features, metadata) {
|
||||
var gpx;
|
||||
features = OpenLayers.Util.isArray(features) ?
|
||||
features : [features];
|
||||
gpx = this.createElementNS(this.gpxns, "gpx");
|
||||
var gpx = this.createElementNSPlus("gpx:gpx");
|
||||
gpx.setAttribute("version", "1.1");
|
||||
this.setAttributes(gpx, {
|
||||
"xsi:schemaLocation": this.schemaLocation
|
||||
});
|
||||
|
||||
for(var i=0, len=features.length; i<len; i++) {
|
||||
gpx.appendChild(this.buildFeatureNode(features[i]));
|
||||
}
|
||||
if (metadata && typeof metadata == 'object') {
|
||||
gpx.appendChild(this.buildMetadataNode(metadata));
|
||||
}
|
||||
for(var i=0, len=features.length; i<len; i++) {
|
||||
gpx.appendChild(this.buildFeatureNode(features[i]));
|
||||
}
|
||||
return OpenLayers.Format.XML.prototype.write.apply(this, [gpx]);
|
||||
},
|
||||
|
||||
@@ -230,11 +242,11 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
*/
|
||||
buildMetadataNode: function(metadata) {
|
||||
var types = ['name', 'desc', 'author'],
|
||||
node = this.createElementNS(this.gpxns, 'metadata');
|
||||
node = this.createElementNSPlus('gpx:metadata');
|
||||
for (var i=0; i < types.length; i++) {
|
||||
var type = types[i];
|
||||
if (metadata[type]) {
|
||||
var n = this.createElementNS(this.gpxns, type);
|
||||
var n = this.createElementNSPlus("gpx:" + type);
|
||||
n.appendChild(this.createTextNode(metadata[type]));
|
||||
node.appendChild(n);
|
||||
}
|
||||
@@ -263,7 +275,7 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
var wpt = this.buildWptNode(feature);
|
||||
return wpt;
|
||||
} else {
|
||||
var trkNode = this.createElementNS(this.gpxns, "trk");
|
||||
var trkNode = this.createElementNSPlus("gpx:trk");
|
||||
this.appendAttributesNode(trkNode, feature);
|
||||
var trkSegNodes = this.buildTrkSegNode(geometry);
|
||||
trkSegNodes = OpenLayers.Util.isArray(trkSegNodes) ?
|
||||
@@ -291,7 +303,7 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
nodes;
|
||||
if (geometry.CLASS_NAME == "OpenLayers.Geometry.LineString" ||
|
||||
geometry.CLASS_NAME == "OpenLayers.Geometry.LinearRing") {
|
||||
node = this.createElementNS(this.gpxns, "trkseg");
|
||||
node = this.createElementNSPlus("gpx:trkseg");
|
||||
for (i = 0, len=geometry.components.length; i < len; i++) {
|
||||
point = geometry.components[i];
|
||||
node.appendChild(this.buildTrkPtNode(point));
|
||||
@@ -317,7 +329,7 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
* {DOMElement} A trkpt node
|
||||
*/
|
||||
buildTrkPtNode: function(point) {
|
||||
var node = this.createElementNS(this.gpxns, "trkpt");
|
||||
var node = this.createElementNSPlus("gpx:trkpt");
|
||||
node.setAttribute("lon", point.x);
|
||||
node.setAttribute("lat", point.y);
|
||||
return node;
|
||||
@@ -334,7 +346,7 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
* {DOMElement} A wpt node
|
||||
*/
|
||||
buildWptNode: function(feature) {
|
||||
var node = this.createElementNS(this.gpxns, "wpt");
|
||||
var node = this.createElementNSPlus("gpx:wpt");
|
||||
node.setAttribute("lon", feature.geometry.x);
|
||||
node.setAttribute("lat", feature.geometry.y);
|
||||
this.appendAttributesNode(node, feature);
|
||||
@@ -350,11 +362,11 @@ OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
* feature - {<OpenLayers.Feature.Vector>}
|
||||
*/
|
||||
appendAttributesNode: function(node, feature) {
|
||||
var name = this.createElementNS(this.gpxns, 'name');
|
||||
var name = this.createElementNSPlus('gpx:name');
|
||||
name.appendChild(this.createTextNode(
|
||||
feature.attributes.name || feature.id));
|
||||
node.appendChild(name);
|
||||
var desc = this.createElementNS(this.gpxns, 'desc');
|
||||
var desc = this.createElementNSPlus('gpx:desc');
|
||||
desc.appendChild(this.createTextNode(
|
||||
feature.attributes.description || this.defaultDesc));
|
||||
node.appendChild(desc);
|
||||
|
||||
Reference in New Issue
Block a user