地图(高德)判断某一点位是否位于某一城市/区域/地区/行政区划内

news2024/12/28 19:38:59

地图(高德)判断某一点位是否位于某一城市/地区/行政区划内

这里以高德地图示例,其他地图思路是类似的

调用API(可以申请api选择web服务获取key)

https://restapi.amap.com/v3/config/district?key=yourAppKey&keywords=330500&extensions=all

传入需要的行政区域代码,得到如下数据,得到polyline是该地区的经纬度范围

用类似的思路也可以自定义范围来判断
在这里插入图片描述

PolygonMultiPolygon 是用来表示地理空间数据的重要几何类型,选择需要的使用

import org.locationtech.jts.algorithm.PointLocator;
import org.locationtech.jts.geom.*;

/**
 * 高德地图判断点位是否在区域内
 */
public class AMapUtils {
    // 湖州市 https://restapi.amap.com/v3/config/district?key=yourAppKey&keywords=330500&extensions=all
    public static final String hz_330500_polyline = "119.35233,30.421692;119.352496,30.422054;119.352971,30.424851;119.35268,30.425771;119.352023,30.427157;119.3508,30.429113;119.349119,30.432065;119.348813,30.433614;119.349692,30.438824;119.348722,30.440093;119.348386,30.440561;119.348133,30.440734;119.345771,30.442303;119.343669......注意经纬度要首尾相连";

    public static boolean pointIsInHuZhou(double longitude, double latitude) {
        //因为边界信息里面包含;和|分隔符,都需要切割
        String[] hzpoints = hz_330500_polyline.split(";|\\|");
        // 创建GeometryFactory
        GeometryFactory geometryFactory = new GeometryFactory();
        // 创建点坐标
        Coordinate pointCoordinate = new Coordinate(longitude, latitude);
        Coordinate[] coordinates = new Coordinate[hzpoints.length + 1];
        //起始经纬度
        double longitudeF = Double.parseDouble(hzpoints[0].split(",")[0]); // 经度
        double latitudeF = Double.parseDouble(hzpoints[0].split(",")[1]); // 纬度
        coordinates[0] = new Coordinate(longitudeF, latitudeF);
        // 遍历多边形Map,查找包含点的多边形
        for (int i = 1; i < hzpoints.length; i++) {
            double longitude1 = Double.parseDouble(hzpoints[i].split(",")[0]); // 经度
            double latitude1 = Double.parseDouble(hzpoints[i].split(",")[1]); // 纬度
            coordinates[i] = new Coordinate(longitude1, latitude1);
        }
        // 一定要首尾相连,不然就会报错
        coordinates[hzpoints.length] = new Coordinate(longitudeF, latitudeF);
        return multiPolygonProcess(geometryFactory, coordinates, pointCoordinate);
    }

    /**
     * 通过MultiPolygon判断
     *
     * @param geometryFactory
     * @param coordinates
     * @param pointCoordinate
     * @return
     */
    private static boolean multiPolygonProcess(GeometryFactory geometryFactory, Coordinate[] coordinates, Coordinate pointCoordinate) {
        try {
            // 创建MultiPolygon对象
            MultiPolygon multiPolygon = geometryFactory
                    .createMultiPolygon(new Polygon[]{new GeometryFactory().createPolygon(coordinates)});
            // 使用PointLocator检查点是否在多边形内
            PointLocator pointLocator = new PointLocator();
            int location = pointLocator.locate(pointCoordinate, multiPolygon);
            return location != Location.EXTERIOR;
        } catch (Exception e) {
            System.out.println("异常原因:" + e);
        }
        return false;
    }

    /**
     * 通过Polygon判断
     *
     * @param geometryFactory
     * @param coordinates
     * @param pointCoordinate
     * @return
     */
    private static boolean polygonProcess(GeometryFactory geometryFactory, Coordinate[] coordinates, Coordinate pointCoordinate) {
        try {
            LinearRing ring = geometryFactory.createLinearRing(coordinates);
            Polygon polygon = geometryFactory.createPolygon(ring, null);
            Point point = geometryFactory.createPoint(pointCoordinate); // 待判断的点
            return point.within(polygon);
        } catch (Exception e) {
            System.out.println("异常原因:" + e);
        }
        return false;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2158278.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

罗德岛战记游戏源码(客户端+服务端+数据库+全套源码)游戏大小9.41G

罗德岛战记游戏源码&#xff08;客户端服务端数据库全套源码&#xff09;游戏大小9.41G 下载地址&#xff1a; 通过网盘分享的文件&#xff1a;【源码】罗德岛战记游戏源码&#xff08;客户端服务端数据库全套源码&#xff09;游戏大小9.41G 链接: https://pan.baidu.com/s/1y0…

RustDesk自建服务器,实现手机控制手机,电脑远程控制,手机控制电脑,电脑控制手机,实现任意互相操作

RustDesk自建服务器&#xff0c;实现手机控制手机&#xff0c;电脑远程控制&#xff0c;手机控制电脑&#xff0c;电脑控制手机&#xff0c;可以互相操作。 如果你不想搭建服务器&#xff0c;也可以联系我&#xff0c;共享服务器给你。 自己搭建服务器很简单&#xff0c;一年…

【BetterBench博士】2024华为杯C题:数据驱动下磁性元件的磁芯损耗建模 Python代码实现

题目 【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析 【BetterBench博士】2024年中国研究生数学建模竞赛 E题&#xff1a;高速公路应急车道紧急启用模型 问题分析 【BetterBench博士】2024年中国研究生数学建模竞赛 C题&#xff1a;数据驱动…

有了BIO为啥还需要NIO

写在前面 注意&#xff1a;这里的NIO指的是Java nio技术。 源码 。 本文看下NIO相关内容。NIO太重要了&#xff0c;netty&#xff0c;tomcat&#xff0c;jetty等底层使用的都是Java nio&#xff0c;所以很有必要好好了解一下咯&#xff0c;涨薪不涨薪的咱不知道&#xff0c;至少…

【网络安全】网络基础第一阶段——第二节:网络协议基础---- 路由和ARP协议

本篇文章我们来介绍IP路由的基本概念&#xff0c;包括路由的原理、静态路由和动态路由的配置与特点。 目录 一、路由 1.1 IP路由原理、静态路由及动态路由区分 1.1.1 什么是路由 1.1.2 路由的原理 1.1.2 路由表 1.1.3 静态路由与动态路由 1.2 路由原理详解 1.2.1 路由的…

Python增强办公效率的11个实用代码段

如果你正在学习Python&#xff0c;那么你需要的话可以&#xff0c;点击这里&#x1f449;Python重磅福利&#xff1a;入门&进阶全套学习资料、电子书、软件包、项目源码等等免费分享&#xff01; 引言 在日常工作中&#xff0c;许多任务可以通过编程自动化来提高效率。本…

QT6.7创建Non-Qt Project工程

QT6.7创建Non-Qt Project工程

数据结构——“二叉搜索树”

二叉搜索树是一个很重要的数据结构&#xff0c;它的特殊结构可以在很短的时间复杂度找到我们想要的数据。最坏情况下的时间复杂度是O(n)&#xff0c;最好是O(logn)。接下来看一看它的接口函数的实现。 为了使用方便&#xff0c;这里采用模版的方式&#xff1a; 一、节点 temp…

TaskRes: Task Residual for Tuning Vision-Language Models

文章汇总 当前VLMs微调中存在的问题 提示微调的问题 在提示调优中缺乏对先验知识保存的保证(me&#xff1a;即提示微调有可能会丢失预训练模型中的通用知识)。虽然预先训练的文本分支模块(如文本编码器和投影)的权重在提示调优范式中被冻结&#xff0c;但原始的良好学习的分类…

图文深入理解SQL语句的执行过程

List item 本文将深入介绍SQL语句的执行过程。 一.在RDBMS&#xff08;关系型DB&#xff09;中&#xff0c;看似很简单的一条已写入DB内存的SQL语句执行过程却非常复杂&#xff0c;也就是说&#xff0c;你执行了一条诸如select count(*) where id 001 from table_name的非常简…

【Transformers基础入门篇4】基础组件之Model

文章目录 一、Model简介1.1 Transformer1.2 注意力机制1.3 模型类型 二、Model Head2.1 什么是 Model Head2.2 Transformers中的Model Head 三、Model基本使用方法3.0 模型下载-浏览器下载3.1 模型加载与保存3.2 配置加载参数3.3 加载config文件3.2 模型调用3.2.1 带ModelHead的…

【PAM】Linux登录认证限制

PAM&#xff08;Pluggable Authentication Modules&#xff0c;可插拔认证模块&#xff09;是一种灵活的认证框架&#xff0c;用于在 Linux 和其他类 Unix 系统上管理用户的身份验证。PAM 允许系统管理员通过配置不同的认证模块来定制应用程序和服务的认证方式&#xff0c;而不…

软件设计师:01计算机组成与结构

文章目录 一、校验码1.奇偶校验码2.海明码3.循环冗余检验码 二、原码反码补码移码三、浮点数表示法1.浮点数相加时 四、寻址方式五、CPU1.访问速度2.cpu的组成 六、RISC和CISC&#xff08;<font color red>只用记住不同就可以&#xff09;七、冗余技术1.结构冗余2.信息冗…

HyperWorks的实体几何创建与六面体网格剖分

创建和编辑实体几何 在 HyperMesh 有限元前处理环境中&#xff0c;有许多操作是针对“实体几何”的&#xff0c;例如创建六面体网格。在创建实体网格的工作中&#xff0c;我们既可以使用闭合曲面创建实体网格&#xff0c;也可以使用完整的实体几何创建实体网格。与闭合曲面相比…

【rabbitmq-server】安装使用介绍

在 1050a 系统下安装 rabbitmq-server 服务以及基本配置;【注】:改方案用于A版统信服务器操作系统 文章目录 功能概述功能介绍一、安装软件包二、启动服务三、验证四、基本配置功能概述 RabbitMQ 是AMQP的实现,高性能的企业消息的新标准。RabbitMQ服务器是一个强大和可扩展…

截取递增数-第15届蓝桥省赛Scratch中级组真题第6题

[导读]&#xff1a;超平老师的《Scratch蓝桥杯真题解析100讲》已经全部完成&#xff0c;后续会不定期解读蓝桥杯真题&#xff0c;这是Scratch蓝桥杯真题解析第191讲。 如果想持续关注Scratch蓝桥真题解读&#xff0c;可以点击《Scratch蓝桥杯历年真题》并订阅合集&#xff0c;…

【c数据结构】OJ练习篇 帮你更深层次理解链表!(相交链表、相交链表、环形链表、环形链表之寻找环形入口点、判断链表是否是回文结构、 随机链表的复制)

目录 一. 相交链表 二. 环形链表 三. 环形链表之寻找环形入口点 四. 判断链表是否是回文结构 五. 随机链表的复制 一. 相交链表 最简单粗暴的思路&#xff0c;遍历两个链表&#xff0c;分别寻找是否有相同的对应的结点。 我们对两个链表的每个对应的节点进行判断比较&…

力扣 209.长度最小的子数组

一、长度最小的子数组 二、解题思路 采用滑动窗口的思路&#xff0c;详细见代码。 三、代码 class Solution {public int minSubArrayLen(int target, int[] nums) {int n nums.length, left 0, right 0, sum 0;int ans n 1; for (right 0; right < n; right ) { …

数通。。。

通信&#xff1a;需要介质才能通信电话离信号塔&#xff08;基站&#xff09;越远&#xff0c;信号越弱。信号在基站之间传递。你离路由器越远&#xff0c;信号越差。一个意思 比如想传一张图片&#xff0c;这张图片就是数据载荷 网关&#xff0c;分割两个网络。路由器可以是网…

Chat2VIS: Generating Data Visualizations via Natural Language

Chat2VIS:通过使用ChatGPT, Codex和GPT-3大型语言模型的自然语言生成数据可视化 梅西大学数学与计算科学学院&#xff0c;新西兰奥克兰 IEEE Access 1 Abstract 数据可视化领域一直致力于设计直接从自然语言文本生成可视化的解决方案。自然语言接口 (NLI) 的研究为这些技术的…