nodejs利用JSTS提取Geometry中心点坐标

nodejs利用JSTS提取Geometry中心点坐标

 getCentroidPoint

const jsts = require('jsts')
/**
 * 提取中心点坐标
 * @param {Object} geometry GeoJSON 的geometry属性
 */
function getCentroid(geometry) {
  const reader = new jsts.io.GeoJSONReader()
  const geom = reader.read(geometry)
  const centroid = new jsts.algorithm.Centroid(geom)
  const centroidPoint = centroid.getCentroid()
  return centroidPoint
}
const polygon = {
	"type":"Feature",
  "properties":{},
  "geometry":{
    "type":"Polygon",
    "coordinates":
        [
          [
            [100,30],
            [116,30],
            [116,32],
            [100,32],
            [100,30]
          ]
        ]
  }
}
// 注意传入的参数是GeoJSON的geometry属性,且其type为Polygon
const centroidPointOfPolygon = getCentroid(polygon.geometry)

console.log(centroidPointOfPolygon) //{ x: 108, y: 31, z: undefined }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值