千家信息网

怎么利用js根据坐标判断构成单个多边形是否合法

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章给大家介绍怎么利用js根据坐标判断构成单个多边形是否合法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。前言需求:在高德地图中判断用户绘制的围栏是否合法。核心解决点:倒序依
千家信息网最后更新 2025年11月07日怎么利用js根据坐标判断构成单个多边形是否合法

这篇文章给大家介绍怎么利用js根据坐标判断构成单个多边形是否合法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

前言

需求:在高德地图中判断用户绘制的围栏是否合法。

核心解决点:倒序依次判断如果是相邻的二根线段,判断是否有交点,非相邻的线段不相交。

安装

npm install  @turf/helpers  @turf/line-intersect

代码

/** * geometric 几何工具库 * @author maybe * @license https://gitee.com/null_639_5368 */import * as  turf from "@turf/helpers"import lineIntersect from "@turf/line-intersect"/** * 坐标转线段 * @param {*} path  * @returns {arr} */export function pathToLines(path) {    const lines = [];    path.forEach((p, pi) => {        let line;        if (pi == path.length - 1) {            line = turf.lineString([path[pi], path[0]]);            lines.push(line)            return;        }        line = turf.lineString([path[pi], path[pi + 1]]);        lines.push(line)    })    // console.log(JSON.stringify(lines))    return lines;}/** * 判断坐标组成的单个多边形是否合法 * @param {*} path  * @description 请传入[[1,2],[2,2],[3,3]] 类似的二维数组  * @returns {boolean} */export function isTruePolygon(path) {    //  判断数组且数组的长度小于3不构成满足一个面的必要条件终止    if (!Array.isArray(path) || path.length < 3) return false;    //  具体坐标也需是一个一维数组,并且数组的长度等于2    if (!path.every(item => Array.isArray(item) && item.length == 2)) return false;    // 将坐标转成线段    const lines = pathToLines(path);    // 是否合法标志    let isTrue = true;    // 验证函数    function check() {        // 倒序循环        for (let i = lines.length - 1; i >= 0; i--) {            // 基准线段            const line = lines[i];            const lineNextIndex = i == 0 ? lines.length - 1 : i - 1;            const lineLastIndex = i == lines.length - 1 ? 0 : i + 1;            const lineNext = lines[lineNextIndex];            const lineLast = lines[lineLastIndex];            // 相邻二根线段必须要有交点            if (                !isIntersect(line, lineNext)                || !isIntersect(line, lineLast)            ) {                console.log('相邻二根线段必须要有交点', line, lineNext, lineLast, isIntersect(line, lineNext), isIntersect(line, lineLast))                isTrue = false;                return;            }            // 非相邻的线段必须无交点            const noNearLines = lines.filter((item, i) => i !== lineNextIndex && i !== lineLastIndex);            noNearLines.forEach(le => {                if (isIntersect(line, le)) {                    console.log('非相邻的线段必须无交点')                    isTrue = false;                    return;                }            })        }    }    check();    isTrue ? console.info('多边形合法') : console.log("多边形不合法")    return isTrue;}function isIntersect(line1, line2) {    return lineIntersect(line1, line2).features.length > 0;}export default {    pathToLines,    isTruePolygon,}

测试

import { isTruePolygon } from './geometric'const path_false = [    [116.403322, 39.920255],    [116.385726, 39.909893],    [116.410703, 39.897555],    [116.402292, 39.892353],    [116.389846, 39.891365]]const path_true = [    [116.403322, 39.920255],    [116.410703, 39.897555],    [116.402292, 39.892353],    [116.389846, 39.891365]]console.log(isTruePolygon(path_true)); // trueconsole.log(isTruePolygon(path_false)); // false

关于怎么利用js根据坐标判断构成单个多边形是否合法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

线段 合法 坐标 多边形 交点 单个 数组 倒序 内容 更多 帮助 不错 必要 必要条件 代码 兴趣 几何 函数 前言 围栏 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 服务器怎么下载到本地电脑 武汉塞力斯医疗科技软件开发 按键精灵粘贴数据库 计算机三级数据库技术题库软件 组态王历史数据库在哪 网络安全管理岗位体检 学软件开发后悔吗 mysql数据库设计及使用规范 高考网络技术真题 没有字的网络安全手抄报简单漂亮 数据库技术专业就业前景 浙江5g网络服务器机柜厂家 华为服务器管理口远程 win 10清理个人数据库 商务本用作软件开发 问卷星数据库设计 网络安全行业服务发展报告 数据库将学生的学分分类 成都软件开发分销 影视设备租赁app软件开发 dell服务器无法识别启动硬盘 数据库删除姓名的公式 吴江区智能服务器厂家直销价格 护苗网络安全课堂第三讲 网络安全课程招生 polardb 数据库评测 我的世界手机版服务器怎么进 上海诚信软件开发代理商 汕头教育软件开发咨询 怎么把镜像文件挂载到服务器上
0