UNPKG

ol

Version:

OpenLayers mapping library

61 lines (57 loc) 1.64 kB
/** * @module ol/geom/flat/area */ /** * @param {Array<number>} flatCoordinates Flat coordinates. * @param {number} offset Offset. * @param {number} end End. * @param {number} stride Stride. * @return {number} Area. */ export function linearRing(flatCoordinates, offset, end, stride) { let twiceArea = 0; const x0 = flatCoordinates[end - stride]; const y0 = flatCoordinates[end - stride + 1]; let dx1 = 0; let dy1 = 0; for (; offset < end; offset += stride) { const dx2 = flatCoordinates[offset] - x0; const dy2 = flatCoordinates[offset + 1] - y0; twiceArea += dy1 * dx2 - dx1 * dy2; dx1 = dx2; dy1 = dy2; } return twiceArea / 2; } /** * @param {Array<number>} flatCoordinates Flat coordinates. * @param {number} offset Offset. * @param {Array<number>} ends Ends. * @param {number} stride Stride. * @return {number} Area. */ export function linearRings(flatCoordinates, offset, ends, stride) { let area = 0; for (let i = 0, ii = ends.length; i < ii; ++i) { const end = ends[i]; area += linearRing(flatCoordinates, offset, end, stride); offset = end; } return area; } /** * @param {Array<number>} flatCoordinates Flat coordinates. * @param {number} offset Offset. * @param {Array<Array<number>>} endss Endss. * @param {number} stride Stride. * @return {number} Area. */ export function linearRingss(flatCoordinates, offset, endss, stride) { let area = 0; for (let i = 0, ii = endss.length; i < ii; ++i) { const ends = endss[i]; area += linearRings(flatCoordinates, offset, ends, stride); offset = ends[ends.length - 1]; } return area; }