JavaScript 凹凸多边形判断

// 凸多边形示例点
var points = [
    { "x": 121.13461725174781, "y": 28.85972342614326, "z": 6.5083743913337795 },
    { "x": 121.13514790352059, "y": 28.85893044194414, "z": 5.239703380752392 },
    { "x": 121.13631312370927, "y": 28.85945345020736, "z": 5.098438720064432 },
    { "x": 121.1359027717907, "y": 28.86041176963575, "z": 5.352710221996978 },
    { "x": 121.13461725174781, "y": 28.85972342614326, "z": 6.5083743913337795 }
]
// 凹多边形示例点
var points = [
    { "x": 121.1347274517314, "y": 28.859676273631692, "z": 6.0256031727820805 },
    { "x": 121.13506353979167, "y": 28.858930341787225, "z": 5.169401984643744 },
    { "x": 121.13610244166651, "y": 28.85937573746748, "z": 4.970347026883167 },
    { "x": 121.13660444154766, "y": 28.859446699269476, "z": 5.103525544574725 },
    { "x": 121.13605631779419, "y": 28.8600846928507, "z": 5.080870114806739 },
    { "x": 121.1347274517314, "y": 28.859676273631692, "z": 6.0256031727820805 }
]
/**
 * @param {*} p 顶点数组(数组对象)
 * @returns 1:凸集;-1:凹集;0:曲线不符合要求无法计算
 */
function concave(p) {
    var n = p.length;//顶点个数
    var j,k,z;
    var flag = 0;
    if (n<3){
      // console.log("不符合要求")
      return 0;
    }
    for (var i=0;i<n;i++) {
        j = (i + 1) % n;
        k = (i + 2) % n;
        z = (p[j].x - p[i].x) * (p[k].y - p[j].y);
        z -= (p[j].y - p[i].y) * (p[k].x - p[j].x);
        if (z < 0){
          flag |= 1;
        } else if (z > 0){
          flag |=  2;
        }
        if (flag == 3){
          console.log("凹多边形,不符合要求")
          return -1; //CONCAVE
        }
    }
    if (flag != 0){
        console.log("凸多边形")
        return 1; //CONVEX
    } else{
        return 0;
    }
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值