| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | import convex from "@turf/convex";import centroid from "@turf/centroid";import { point } from "@turf/helpers";import { getType, getCoord } from "@turf/invariant";import { coordEach } from "@turf/meta";/** * Takes any {@link Feature} or a {@link FeatureCollection} and returns its [center of mass](https://en.wikipedia.org/wiki/Center_of_mass) using this formula: [Centroid of Polygon](https://en.wikipedia.org/wiki/Centroid#Centroid_of_polygon). * * @name centerOfMass * @param {GeoJSON} geojson GeoJSON to be centered * @param {Object} [options={}] Optional Parameters * @param {Object} [options.properties={}] Translate Properties to Feature * @returns {Feature<Point>} the center of mass * @example * var polygon = turf.polygon([[[-81, 41], [-88, 36], [-84, 31], [-80, 33], [-77, 39], [-81, 41]]]); * * var center = turf.centerOfMass(polygon); * * //addToMap * var addToMap = [polygon, center] */function centerOfMass(geojson, options) {    if (options === void 0) { options = {}; }    switch (getType(geojson)) {        case "Point":            return point(getCoord(geojson), options.properties);        case "Polygon":            var coords = [];            coordEach(geojson, function (coord) {                coords.push(coord);            });            // First, we neutralize the feature (set it around coordinates [0,0]) to prevent rounding errors            // We take any point to translate all the points around 0            var centre = centroid(geojson, { properties: options.properties });            var translation = centre.geometry.coordinates;            var sx = 0;            var sy = 0;            var sArea = 0;            var i, pi, pj, xi, xj, yi, yj, a;            var neutralizedPoints = coords.map(function (point) {                return [point[0] - translation[0], point[1] - translation[1]];            });            for (i = 0; i < coords.length - 1; i++) {                // pi is the current point                pi = neutralizedPoints[i];                xi = pi[0];                yi = pi[1];                // pj is the next point (pi+1)                pj = neutralizedPoints[i + 1];                xj = pj[0];                yj = pj[1];                // a is the common factor to compute the signed area and the final coordinates                a = xi * yj - xj * yi;                // sArea is the sum used to compute the signed area                sArea += a;                // sx and sy are the sums used to compute the final coordinates                sx += (xi + xj) * a;                sy += (yi + yj) * a;            }            // Shape has no area: fallback on turf.centroid            if (sArea === 0) {                return centre;            }            else {                // Compute the signed area, and factorize 1/6A                var area = sArea * 0.5;                var areaFactor = 1 / (6 * area);                // Compute the final coordinates, adding back the values that have been neutralized                return point([translation[0] + areaFactor * sx, translation[1] + areaFactor * sy], options.properties);            }        default:            // Not a polygon: Compute the convex hull and work with that            var hull = convex(geojson);            if (hull)                return centerOfMass(hull, { properties: options.properties });            // Hull is empty: fallback on the centroid            else                return centroid(geojson, { properties: options.properties });    }}export default centerOfMass;
 |