Refactor ol.geom.Geometry to support Z, M and flat coordinates
This commit is contained in:
@@ -1,12 +1,12 @@
|
|||||||
// FIXME add MultiPoint
|
// FIXME add MultiPoint
|
||||||
// FIXME add GeometryCollection
|
// FIXME add GeometryCollection
|
||||||
// FIXME add Z and M support
|
|
||||||
// FIXME use flat coordinate arrays
|
|
||||||
|
|
||||||
goog.provide('ol.geom.Geometry');
|
goog.provide('ol.geom.Geometry');
|
||||||
|
|
||||||
|
goog.require('goog.asserts');
|
||||||
goog.require('goog.events.EventTarget');
|
goog.require('goog.events.EventTarget');
|
||||||
goog.require('goog.events.EventType');
|
goog.require('goog.events.EventType');
|
||||||
|
goog.require('ol.extent');
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -24,7 +24,7 @@ ol.geom.GeometryType = {
|
|||||||
/**
|
/**
|
||||||
* @enum {string}
|
* @enum {string}
|
||||||
*/
|
*/
|
||||||
ol.geom.GeometryLayout = {
|
ol.geom.Layout = {
|
||||||
XY: 'XY',
|
XY: 'XY',
|
||||||
XYZ: 'XYZ',
|
XYZ: 'XYZ',
|
||||||
XYM: 'XYM',
|
XYM: 'XYM',
|
||||||
@@ -36,17 +36,28 @@ ol.geom.GeometryLayout = {
|
|||||||
/**
|
/**
|
||||||
* @constructor
|
* @constructor
|
||||||
* @extends {goog.events.EventTarget}
|
* @extends {goog.events.EventTarget}
|
||||||
* @param {ol.geom.GeometryLayout=} opt_layout Layout.
|
|
||||||
*/
|
*/
|
||||||
ol.geom.Geometry = function(opt_layout) {
|
ol.geom.Geometry = function() {
|
||||||
|
|
||||||
goog.base(this);
|
goog.base(this);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @protected
|
* @protected
|
||||||
* @type {ol.geom.GeometryLayout}
|
* @type {ol.geom.Layout}
|
||||||
*/
|
*/
|
||||||
this.layout = goog.isDef(opt_layout) ? opt_layout : ol.geom.GeometryLayout.XY;
|
this.layout = ol.geom.Layout.XY;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @protected
|
||||||
|
* @type {number}
|
||||||
|
*/
|
||||||
|
this.stride = 2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @protected
|
||||||
|
* @type {Array.<number>}
|
||||||
|
*/
|
||||||
|
this.flatCoordinates = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @protected
|
* @protected
|
||||||
@@ -83,11 +94,27 @@ ol.geom.Geometry.prototype.dispatchChangeEvent = function() {
|
|||||||
* @param {ol.Extent=} opt_extent Extent.
|
* @param {ol.Extent=} opt_extent Extent.
|
||||||
* @return {ol.Extent} extent Extent.
|
* @return {ol.Extent} extent Extent.
|
||||||
*/
|
*/
|
||||||
ol.geom.Geometry.prototype.getExtent = goog.abstractMethod;
|
ol.geom.Geometry.prototype.getExtent = function(opt_extent) {
|
||||||
|
if (this.extentRevision != this.revision) {
|
||||||
|
this.extent = ol.extent.createOrUpdateFromFlatCoordinates(
|
||||||
|
this.flatCoordinates, this.stride, this.extent);
|
||||||
|
this.extentRevision = this.revision;
|
||||||
|
}
|
||||||
|
goog.asserts.assert(goog.isDef(this.extent));
|
||||||
|
return ol.extent.returnOrUpdate(this.extent, opt_extent);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return {ol.geom.GeometryLayout} Layout.
|
* @return {Array.<number>} Flat coordinates.
|
||||||
|
*/
|
||||||
|
ol.geom.Geometry.prototype.getFlatCoordinates = function() {
|
||||||
|
return this.flatCoordinates;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {ol.geom.Layout} Layout.
|
||||||
*/
|
*/
|
||||||
ol.geom.Geometry.prototype.getLayout = function() {
|
ol.geom.Geometry.prototype.getLayout = function() {
|
||||||
return this.layout;
|
return this.layout;
|
||||||
@@ -106,7 +133,7 @@ ol.geom.Geometry.prototype.getRevision = function() {
|
|||||||
* @return {number} Stride.
|
* @return {number} Stride.
|
||||||
*/
|
*/
|
||||||
ol.geom.Geometry.prototype.getStride = function() {
|
ol.geom.Geometry.prototype.getStride = function() {
|
||||||
return this.layout.length;
|
return this.stride;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -116,10 +143,60 @@ ol.geom.Geometry.prototype.getStride = function() {
|
|||||||
ol.geom.Geometry.prototype.getType = goog.abstractMethod;
|
ol.geom.Geometry.prototype.getType = goog.abstractMethod;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {ol.geom.Layout|undefined} layout Layout.
|
||||||
|
* @param {Array} coordinates Coordinates.
|
||||||
|
* @param {number} nesting Nesting.
|
||||||
|
* @protected
|
||||||
|
*/
|
||||||
|
ol.geom.Geometry.prototype.setLayout =
|
||||||
|
function(layout, coordinates, nesting) {
|
||||||
|
var stride;
|
||||||
|
if (goog.isDef(layout)) {
|
||||||
|
if (layout == ol.geom.Layout.XY) {
|
||||||
|
stride = 2;
|
||||||
|
} else if (layout == ol.geom.Layout.XYZ) {
|
||||||
|
stride = 3;
|
||||||
|
} else if (layout == ol.geom.Layout.XYM) {
|
||||||
|
stride = 3;
|
||||||
|
} else if (layout == ol.geom.Layout.XYZM) {
|
||||||
|
stride = 4;
|
||||||
|
} else {
|
||||||
|
throw new Error('unsupported layout: ' + layout);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var i;
|
||||||
|
for (i = 0; i < nesting; ++i) {
|
||||||
|
if (coordinates.length === 0) {
|
||||||
|
this.layout = ol.geom.Layout.XY;
|
||||||
|
this.stride = 2;
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
coordinates = coordinates[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stride = coordinates.length;
|
||||||
|
if (stride == 2) {
|
||||||
|
layout = ol.geom.Layout.XY;
|
||||||
|
} else if (stride == 3) {
|
||||||
|
layout = ol.geom.Layout.XYZ;
|
||||||
|
} else if (stride == 4) {
|
||||||
|
layout = ol.geom.Layout.XYZM;
|
||||||
|
} else {
|
||||||
|
throw new Error('unsupported stride: ' + stride);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.layout = layout;
|
||||||
|
this.stride = stride;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {ol.TransformFunction} transformFn Transform.
|
* @param {ol.TransformFunction} transformFn Transform.
|
||||||
*/
|
*/
|
||||||
ol.geom.Geometry.prototype.transform = goog.abstractMethod;
|
ol.geom.Geometry.prototype.transform = function(transformFn) {
|
||||||
|
transformFn(this.flatCoordinates, this.flatCoordinates, this.stride);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Reference in New Issue
Block a user