地图多边形点位关系判断

由于工作的业务于地图有关系,所以会经常出现,地图上画圆、画多边形,然后求在该区域内的一些业务数据;

计算时根据使用场景我一般使用一下方式:

一 、java程序内判断

优点:这种方式网上代码比较多,直接拿来就可以用。

缺点:当业务数据量比较大的时候,业务数据从仓库中取出在判断 ,资源消耗比较大,且通用性不是很好,不推荐;

二、将相关逻辑代码写成自定义数据库函数进行判断

优点:通用函数,可以直接在SQL上使用,使用方便;直接交由数据库处理,速度相对外部程序判断效率高;

缺点:对数据库服务器有压力

 

实现逻辑 

第一种网上找就不说了;

第二种画圆的比较简单也不说了;

第三种多边形判断:(数据库是11g)

将前端画多边形的点位信息 拼成有规则的字符串 points = “map_x|map_y,map_x|map_y "  (不能直接传数组进去)

传入自定义函数 F1(mapx,mapy,points)  中 ,函数根据传入的字符串按照规则 进行分割解析,得到成对的经纬度数组,

然后根据多边形点位判断逻辑判断是否在多边形内,返回结果值。

逻辑判断我是直接按java判断多边形点位关系的逻辑写的,经过测试可以正常判断。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值