/*
* Copyright 2003-2006, 2009, 2017, 2020 United States Government, as represented
* by the Administrator of the National Aeronautics and Space Administration.
* All rights reserved.
*
* The NASAWorldWind/WebWorldWind platform is licensed under the Apache License,
* Version 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License
* at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*
* NASAWorldWind/WebWorldWind also contains the following 3rd party Open Source
* software:
*
* ES6-Promise – under MIT License
* libtess.js – SGI Free Software License B
* Proj4 – under MIT License
* JSZip – under MIT License
*
* A complete listing of 3rd Party software notices and licenses included in
* WebWorldWind can be found in the WebWorldWind 3rd-party notices and licenses
* PDF found in code directory.
*/
/**
* @exports GeoJSONGeometry
*/
define(['../../error/ArgumentError',
'./GeoJSONConstants',
'../../util/Logger'
],
function (ArgumentError,
GeoJSONConstants,
Logger) {
"use strict";
/**
* Constructs a GeoJSON Geometry object. Applications typically do not call this constructor. It is called by
* {@link GeoJSON} as GeoJSON is read.
* @alias GeoJSONGeometry
* @constructor
* @classdesc A geometry is a GeoJSON object where the type member's value is one of the following strings:
* "Point", "MultiPoint", "LineString", "MultiLineString", "Polygon", "MultiPolygon", or "GeometryCollection".
* A GeoJSON geometry object of any type other than "GeometryCollection" must have a member with the name
* "coordinates". The value of the coordinates member is always an array.
* The structure for the elements in this array is determined by the type of geometry.
* @param {Number[]} coordinates An array containing geometry coordinates.
* @param {String} type A string containing type of geometry.
* @param {Object} bbox An array containing information on the coordinate range for geometries.
* @throws {ArgumentError} If the specified mandatory coordinates or type are null or undefined.
*/
var GeoJSONGeometry = function (coordinates, type, bbox) {
if (!coordinates) {
throw new ArgumentError(
Logger.logMessage(Logger.LEVEL_SEVERE, "GeoJSONGeometry", "constructor",
"missingCoordinates"));
}
if (!type) {
throw new ArgumentError(
Logger.logMessage(Logger.LEVEL_SEVERE, "GeoJSONGeometry", "constructor",
"missingType"));
}
// Documented in defineProperties below.
this._coordinates = coordinates;
// Documented in defineProperties below.
this._type = type;
// Documented in defineProperties below.
this._bbox = bbox ? bbox : null;
};
Object.defineProperties(GeoJSONGeometry.prototype, {
/**
* The GeoJSON geometry coordinates as specified to this GeoJSONGeometry's constructor.
* @memberof GeoJSONGeometry.prototype
* @type {Number[]}
* @readonly
*/
coordinates: {
get: function () {
return this._coordinates;
}
},
/**
* The GeoJSON geometry type as specified to this GeoJSONGeometry's constructor.
* @memberof GeoJSONGeometry.prototype
* @type {String}
* @readonly
*/
type: {
get: function () {
return this._type;
}
},
/**
* The GeoJSON bbox object as specified to this GeoJSONGeometry's constructor.
* @memberof GeoJSONGeometry.prototype
* @type {Object}
* @readonly
*/
bbox: {
get: function () {
return this._bbox;
}
}
});
/**
* Indicates whether this GeoJSON geometry is
* [GeoJSONConstants.TYPE_POINT]
*
* @return {Boolean} True if the geometry is a Point type.
*/
GeoJSONGeometry.prototype.isPointType = function () {
return (this.type === GeoJSONConstants.TYPE_POINT);
};
/**
* Indicates whether this GeoJSON geometry is
* [GeoJSONConstants.TYPE_MULTI_POINT]
*
* @return {Boolean} True if the geometry is a MultiPoint type.
*/
GeoJSONGeometry.prototype.isMultiPointType = function () {
return (this.type === GeoJSONConstants.TYPE_MULTI_POINT);
};
/**
* Indicates whether this GeoJSON geometry is
* [GeoJSONConstants.TYPE_LINE_STRING]
*
* @return {Boolean} True if the geometry is a LineString type.
*/
GeoJSONGeometry.prototype.isLineStringType = function () {
return (this.type === GeoJSONConstants.TYPE_LINE_STRING);
};
/**
* Indicates whether this GeoJSON geometry is
* [GeoJSONConstants.TYPE_MULTI_LINE_STRING]
*
* @return {Boolean} True if the geometry is a MultiLineString type.
*/
GeoJSONGeometry.prototype.isMultiLineStringType = function () {
return (this.type === GeoJSONConstants.TYPE_MULTI_LINE_STRING);
};
/**
* Indicates whether this GeoJSON geometry is
* [GeoJSONConstants.TYPE_POLYGON]
*
* @return {Boolean} True if the geometry is a Polygon type.
*/
GeoJSONGeometry.prototype.isPolygonType = function () {
return (this.type === GeoJSONConstants.TYPE_POLYGON);
};
/**
* Indicates whether this GeoJSON geometry is
* [GeoJSONConstants.TYPE_MULTI_POLYGON]
*
* @return {Boolean} True if the geometry is a MultiPolygon type.
*/
GeoJSONGeometry.prototype.isMultiPolygonType = function () {
return (this.type === GeoJSONConstants.TYPE_MULTI_POLYGON);
};
return GeoJSONGeometry;
}
);