Add write support for gml:MultiSurface
This commit is contained in:
+80
-17
@@ -12,6 +12,7 @@ goog.require('ol.format.XMLFeature');
|
|||||||
goog.require('ol.format.XSD');
|
goog.require('ol.format.XSD');
|
||||||
goog.require('ol.geom.Geometry');
|
goog.require('ol.geom.Geometry');
|
||||||
goog.require('ol.geom.LineString');
|
goog.require('ol.geom.LineString');
|
||||||
|
goog.require('ol.geom.LinearRing');
|
||||||
goog.require('ol.geom.MultiLineString');
|
goog.require('ol.geom.MultiLineString');
|
||||||
goog.require('ol.geom.MultiPoint');
|
goog.require('ol.geom.MultiPoint');
|
||||||
goog.require('ol.geom.MultiPolygon');
|
goog.require('ol.geom.MultiPolygon');
|
||||||
@@ -496,7 +497,7 @@ ol.format.GML.readFlatLinearRing_ = function(node, objectStack) {
|
|||||||
* @param {Node} node Node.
|
* @param {Node} node Node.
|
||||||
* @param {Array.<*>} objectStack Object stack.
|
* @param {Array.<*>} objectStack Object stack.
|
||||||
* @private
|
* @private
|
||||||
* @return {ol.geom.Polygon|undefined} Polygon.
|
* @return {ol.geom.LinearRing|undefined} LinearRing.
|
||||||
*/
|
*/
|
||||||
ol.format.GML.readLinearRing_ = function(node, objectStack) {
|
ol.format.GML.readLinearRing_ = function(node, objectStack) {
|
||||||
goog.asserts.assert(node.nodeType == goog.dom.NodeType.ELEMENT);
|
goog.asserts.assert(node.nodeType == goog.dom.NodeType.ELEMENT);
|
||||||
@@ -504,10 +505,9 @@ ol.format.GML.readLinearRing_ = function(node, objectStack) {
|
|||||||
var flatCoordinates =
|
var flatCoordinates =
|
||||||
ol.format.GML.readFlatCoordinatesFromNode_(node, objectStack);
|
ol.format.GML.readFlatCoordinatesFromNode_(node, objectStack);
|
||||||
if (goog.isDef(flatCoordinates)) {
|
if (goog.isDef(flatCoordinates)) {
|
||||||
var polygon = new ol.geom.Polygon(null);
|
var ring = new ol.geom.LinearRing(null);
|
||||||
polygon.setFlatCoordinates(ol.geom.GeometryLayout.XYZ, flatCoordinates,
|
ring.setFlatCoordinates(ol.geom.GeometryLayout.XYZ, flatCoordinates);
|
||||||
[flatCoordinates.length]);
|
return ring;
|
||||||
return polygon;
|
|
||||||
} else {
|
} else {
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
@@ -1126,7 +1126,8 @@ ol.format.GML.writeLinearRing_ = function(node, geometry, objectStack) {
|
|||||||
var context = objectStack[objectStack.length - 1];
|
var context = objectStack[objectStack.length - 1];
|
||||||
goog.asserts.assert(goog.isObject(context));
|
goog.asserts.assert(goog.isObject(context));
|
||||||
var srsName = goog.object.get(context, 'srsName');
|
var srsName = goog.object.get(context, 'srsName');
|
||||||
if (goog.isDefAndNotNull(srsName)) {
|
var writeSrsName = goog.object.get(context, 'writeSrsName');
|
||||||
|
if (writeSrsName !== false && goog.isDefAndNotNull(srsName)) {
|
||||||
node.setAttribute('srsName', srsName);
|
node.setAttribute('srsName', srsName);
|
||||||
}
|
}
|
||||||
ol.xml.pushSerializeAndPop({node: node, srsName: srsName},
|
ol.xml.pushSerializeAndPop({node: node, srsName: srsName},
|
||||||
@@ -1145,24 +1146,49 @@ ol.format.GML.writePolygon_ = function(node, geometry, objectStack) {
|
|||||||
var context = objectStack[objectStack.length - 1];
|
var context = objectStack[objectStack.length - 1];
|
||||||
goog.asserts.assert(goog.isObject(context));
|
goog.asserts.assert(goog.isObject(context));
|
||||||
var srsName = goog.object.get(context, 'srsName');
|
var srsName = goog.object.get(context, 'srsName');
|
||||||
if (goog.isDefAndNotNull(srsName)) {
|
var writeSrsName = goog.object.get(context, 'writeSrsName');
|
||||||
|
if (writeSrsName !== false && goog.isDefAndNotNull(srsName)) {
|
||||||
node.setAttribute('srsName', srsName);
|
node.setAttribute('srsName', srsName);
|
||||||
}
|
}
|
||||||
var rings = geometry.getLinearRings();
|
var rings = geometry.getLinearRings();
|
||||||
for (var i = 0, ii = rings.length; i < ii; ++i) {
|
for (var i = 0, ii = rings.length; i < ii; ++i) {
|
||||||
if (i === 0) {
|
if (i === 0) {
|
||||||
ol.xml.pushSerializeAndPop({node: node, srsName: srsName},
|
ol.xml.pushSerializeAndPop({node: node, srsName: srsName,
|
||||||
ol.format.GML.RING_SERIALIZERS_,
|
writeSrsName: false}, ol.format.GML.RING_SERIALIZERS_,
|
||||||
ol.xml.makeSimpleNodeFactory('exterior'), [rings[i]], objectStack);
|
ol.xml.makeSimpleNodeFactory('exterior'), [rings[i]], objectStack);
|
||||||
} else {
|
} else {
|
||||||
ol.xml.pushSerializeAndPop({node: node, srsName: srsName},
|
ol.xml.pushSerializeAndPop({node: node, srsName: srsName,
|
||||||
ol.format.GML.RING_SERIALIZERS_,
|
writeSrsName: false}, ol.format.GML.RING_SERIALIZERS_,
|
||||||
ol.xml.makeSimpleNodeFactory('interior'), [rings[i]], objectStack);
|
ol.xml.makeSimpleNodeFactory('interior'), [rings[i]], objectStack);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {Node} node Node.
|
||||||
|
* @param {ol.geom.MultiPolygon} geometry MultiPolygon geometry.
|
||||||
|
* @param {Array.<*>} objectStack Node stack.
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
ol.format.GML.writeMultiSurface_ = function(node, geometry,
|
||||||
|
objectStack) {
|
||||||
|
var context = objectStack[objectStack.length - 1];
|
||||||
|
goog.asserts.assert(goog.isObject(context));
|
||||||
|
var srsName = goog.object.get(context, 'srsName');
|
||||||
|
if (goog.isDefAndNotNull(srsName)) {
|
||||||
|
node.setAttribute('srsName', srsName);
|
||||||
|
}
|
||||||
|
var polygons = geometry.getPolygons();
|
||||||
|
for (var i = 0, ii = polygons.length; i < ii; ++i) {
|
||||||
|
ol.xml.pushSerializeAndPop({node: node, srsName: srsName},
|
||||||
|
ol.format.GML.SURFACEMEMBER_SERIALIZERS_,
|
||||||
|
ol.xml.makeSimpleNodeFactory('surfaceMember'), [polygons[i]],
|
||||||
|
objectStack);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {Node} node Node.
|
* @param {Node} node Node.
|
||||||
* @param {ol.geom.LinearRing} ring LinearRing geometry.
|
* @param {ol.geom.LinearRing} ring LinearRing geometry.
|
||||||
@@ -1170,13 +1196,45 @@ ol.format.GML.writePolygon_ = function(node, geometry, objectStack) {
|
|||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
ol.format.GML.writeRing_ = function(node, ring, objectStack) {
|
ol.format.GML.writeRing_ = function(node, ring, objectStack) {
|
||||||
var context = {node: node};
|
var context = objectStack[objectStack.length - 1];
|
||||||
|
goog.asserts.assert(goog.isObject(context));
|
||||||
|
var srsName = goog.object.get(context, 'srsName');
|
||||||
|
var writeSrsName = goog.object.get(context, 'writeSrsName');
|
||||||
ol.xml.pushSerializeAndPop(/** @type {ol.xml.NodeStackItem} */
|
ol.xml.pushSerializeAndPop(/** @type {ol.xml.NodeStackItem} */
|
||||||
(context), ol.format.GML.GEOMETRY_SERIALIZERS_,
|
({node: node, srsName: srsName, writeSrsName: writeSrsName}),
|
||||||
|
ol.format.GML.GEOMETRY_SERIALIZERS_,
|
||||||
ol.format.GML.GEOMETRY_NODE_FACTORY_, [ring], []);
|
ol.format.GML.GEOMETRY_NODE_FACTORY_, [ring], []);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {Node} node Node.
|
||||||
|
* @param {ol.geom.Polygon} polygon Polygon geometry.
|
||||||
|
* @param {Array.<*>} objectStack Node stack.
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
ol.format.GML.writeSurfaceMember_ = function(node, polygon, objectStack) {
|
||||||
|
var context = objectStack[objectStack.length - 1];
|
||||||
|
goog.asserts.assert(goog.isObject(context));
|
||||||
|
var srsName = goog.object.get(context, 'srsName');
|
||||||
|
ol.xml.pushSerializeAndPop(/** @type {ol.xml.NodeStackItem} */
|
||||||
|
({node: node, srsName: srsName, writeSrsName: false}),
|
||||||
|
ol.format.GML.GEOMETRY_SERIALIZERS_,
|
||||||
|
ol.format.GML.GEOMETRY_NODE_FACTORY_, [polygon], []);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {Object.<string, Object.<string, ol.xml.Serializer>>}
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
ol.format.GML.SURFACEMEMBER_SERIALIZERS_ = {
|
||||||
|
'http://www.opengis.net/gml': {
|
||||||
|
'surfaceMember': ol.xml.makeChildAppender(ol.format.GML.writeSurfaceMember_)
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @type {Object.<string, Object.<string, ol.xml.Serializer>>}
|
* @type {Object.<string, Object.<string, ol.xml.Serializer>>}
|
||||||
* @private
|
* @private
|
||||||
@@ -1198,7 +1256,8 @@ ol.format.GML.GEOMETRY_SERIALIZERS_ = {
|
|||||||
'Point': ol.xml.makeChildAppender(ol.format.GML.writePoint_),
|
'Point': ol.xml.makeChildAppender(ol.format.GML.writePoint_),
|
||||||
'LineString': ol.xml.makeChildAppender(ol.format.GML.writeLineString_),
|
'LineString': ol.xml.makeChildAppender(ol.format.GML.writeLineString_),
|
||||||
'LinearRing': ol.xml.makeChildAppender(ol.format.GML.writeLinearRing_),
|
'LinearRing': ol.xml.makeChildAppender(ol.format.GML.writeLinearRing_),
|
||||||
'Polygon': ol.xml.makeChildAppender(ol.format.GML.writePolygon_)
|
'Polygon': ol.xml.makeChildAppender(ol.format.GML.writePolygon_),
|
||||||
|
'MultiSurface': ol.xml.makeChildAppender(ol.format.GML.writeMultiSurface_)
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -1216,8 +1275,12 @@ ol.format.GML.GEOMETRY_NODE_FACTORY_ = function(value, objectStack,
|
|||||||
goog.asserts.assertInstanceof(value, ol.geom.Geometry);
|
goog.asserts.assertInstanceof(value, ol.geom.Geometry);
|
||||||
var parentNode = objectStack[objectStack.length - 1].node;
|
var parentNode = objectStack[objectStack.length - 1].node;
|
||||||
goog.asserts.assert(ol.xml.isNode(parentNode));
|
goog.asserts.assert(ol.xml.isNode(parentNode));
|
||||||
|
var nodeName = value.getType();
|
||||||
|
if (nodeName === 'MultiPolygon') {
|
||||||
|
nodeName = 'MultiSurface';
|
||||||
|
}
|
||||||
return ol.xml.createElementNS(parentNode.namespaceURI,
|
return ol.xml.createElementNS(parentNode.namespaceURI,
|
||||||
value.getType());
|
nodeName);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -105,6 +105,8 @@ describe('ol.format.GML', function() {
|
|||||||
var g = readGeometry(format, text);
|
var g = readGeometry(format, text);
|
||||||
expect(g.getCoordinates()[0][0][0][0]).to.equal(-77.0081);
|
expect(g.getCoordinates()[0][0][0][0]).to.equal(-77.0081);
|
||||||
expect(g.getCoordinates()[0][0][0][1]).to.equal(38.9661);
|
expect(g.getCoordinates()[0][0][0][1]).to.equal(38.9661);
|
||||||
|
var serialized = formatWGS84.writeGeometry(g);
|
||||||
|
expect(serialized.firstElementChild).to.xmleql(ol.xml.load(text));
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
@@ -133,10 +135,10 @@ describe('ol.format.GML', function() {
|
|||||||
' <gml:posList>1 2 3 4 5 6 1 2</gml:posList>' +
|
' <gml:posList>1 2 3 4 5 6 1 2</gml:posList>' +
|
||||||
'</gml:LinearRing>';
|
'</gml:LinearRing>';
|
||||||
var g = readGeometry(format, text);
|
var g = readGeometry(format, text);
|
||||||
expect(g).to.be.an(ol.geom.Polygon);
|
expect(g).to.be.an(ol.geom.LinearRing);
|
||||||
expect(g.getCoordinates()).to.eql(
|
expect(g.getCoordinates()).to.eql(
|
||||||
[[[1, 2, 0], [3, 4, 0], [5, 6, 0], [1, 2, 0]]]);
|
[[1, 2, 0], [3, 4, 0], [5, 6, 0], [1, 2, 0]]);
|
||||||
var serialized = format.writeGeometry(g.getLinearRings()[0]);
|
var serialized = format.writeGeometry(g);
|
||||||
expect(serialized.firstElementChild).to.xmleql(ol.xml.load(text));
|
expect(serialized.firstElementChild).to.xmleql(ol.xml.load(text));
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -764,6 +766,7 @@ goog.require('goog.dom');
|
|||||||
goog.require('goog.dom.TagName');
|
goog.require('goog.dom.TagName');
|
||||||
goog.require('ol.format.GML');
|
goog.require('ol.format.GML');
|
||||||
goog.require('ol.geom.LineString');
|
goog.require('ol.geom.LineString');
|
||||||
|
goog.require('ol.geom.LinearRing');
|
||||||
goog.require('ol.geom.MultiPoint');
|
goog.require('ol.geom.MultiPoint');
|
||||||
goog.require('ol.geom.MultiLineString');
|
goog.require('ol.geom.MultiLineString');
|
||||||
goog.require('ol.geom.MultiPolygon');
|
goog.require('ol.geom.MultiPolygon');
|
||||||
|
|||||||
Reference in New Issue
Block a user