怎么用javascript判断该坐标是否在地图区域范围内
发表于:2024-11-30 作者:千家信息网编辑
千家信息网最后更新 2024年11月30日,这篇文章主要介绍"怎么用javascript判断该坐标是否在地图区域范围内",在日常操作中,相信很多人在怎么用javascript判断该坐标是否在地图区域范围内问题上存在疑惑,小编查阅了各式资料,整理
千家信息网最后更新 2024年11月30日怎么用javascript判断该坐标是否在地图区域范围内
这篇文章主要介绍"怎么用javascript判断该坐标是否在地图区域范围内",在日常操作中,相信很多人在怎么用javascript判断该坐标是否在地图区域范围内问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么用javascript判断该坐标是否在地图区域范围内"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
具体需求如下:
根据腾讯地图划分配送区域,总站下边设多个配送分站,然后将订单中的收货地址将其分配给不同的配送分站。
1、地图区域划分(腾讯地图)
1.1、HTML
重置地图
1.2、JS
//初始化新地图 initNewMap:function(){ var map = new qq.maps.Map(document.getElementById("container"), { center: new qq.maps.LatLng(36.05562,103.88191),// 地图的中心地理坐标。 zoom:13// 地图的中心地理坐标。 }); var drawingManagerOpt = new qq.maps.drawing.DrawingManager({ drawingMode: qq.maps.drawing.OverlayType.POLYGON, drawingControl: true, drawingControlOptions: { position: qq.maps.ControlPosition.TOP_CENTER, drawingModes: [ qq.maps.drawing.OverlayType.POLYGON ] }, circleOptions: { fillColor: new qq.maps.Color(255, 208, 70, 0.3), strokeColor: new qq.maps.Color(88, 88, 88, 1), strokeWeight: 3, clickable: false } }); drawingManagerOpt.setMap(map); var points = ""; qq.maps.event.addListener(drawingManagerOpt, 'overlaycomplete', function(event) { event.overlay.getPath().forEach(function(e){ var lng=e.getLng(); var lat=e.getLat(); points+=lng+","+lat+"-"; }); points=points.substring(0, points.length-1); vm.getPeopleDataByPolygon(points); }); }, //初始化老的地图 initOldMap:function(value){ var map = new qq.maps.Map(document.getElementById("container"), { center: new qq.maps.LatLng(36.05562,103.88191),// 地图的中心地理坐标。 zoom:13// 地图的中心地理坐标。 }); //获取旧坐标 let data = $("#jqGrid").jqGrid('getRowData', getSelectedRow("#jqGrid")); var areaCoordinateArray = new Array(); areaCoordinateArray = data.areaCoordinate.split("-"); var path = new Array(); for(var i=0;i1.3、结果:
2、判断坐标是否在多边形区域内
/** * 判断是否在多边形区域内 * * @param pointLon * 要判断的点的纵坐标 * @param pointLat * 要判断的点的横坐标 * @param lon * 区域各顶点的纵坐标数组 * @param lat * 区域各顶点的横坐标数组 * @return */ public static boolean isInPolygon(double pointLon, double pointLat, double[] lon, double[] lat) { // 将要判断的横纵坐标组成一个点 Point2D.Double point = new Point2D.Double(pointLon, pointLat); // 将区域各顶点的横纵坐标放到一个点集合里面 ListpointList = new ArrayList (); double polygonPoint_x = 0.0, polygonPoint_y = 0.0; for (int i = 0; i < lon.length; i++) { polygonPoint_x = lon[i]; polygonPoint_y = lat[i]; Point2D.Double polygonPoint = new Point2D.Double(polygonPoint_x, polygonPoint_y); pointList.add(polygonPoint); } return check(point, pointList); } /** * 一个点是否在多边形内 * * @param point * 要判断的点的横纵坐标 * @param polygon * 组成的顶点坐标集合 * @return */ private static boolean check(Point2D.Double point, List polygon) { java.awt.geom.GeneralPath peneralPath = new java.awt.geom.GeneralPath(); Point2D.Double first = polygon.get(0); // 通过移动到指定坐标(以双精度指定),将一个点添加到路径中 peneralPath.moveTo(first.x, first.y); polygon.remove(0); for (Point2D.Double d : polygon) { // 通过绘制一条从当前坐标到新指定坐标(以双精度指定)的直线,将一个点添加到路径中。 peneralPath.lineTo(d.x, d.y); } // 将几何多边形封闭 peneralPath.lineTo(first.x, first.y); peneralPath.closePath(); // 测试指定的 Point2D 是否在 Shape 的边界内。 return peneralPath.contains(point); } 到此,关于"怎么用javascript判断该坐标是否在地图区域范围内"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
坐标
地图
区域
纵坐标
范围
地理
多边形
顶点
学习
分站
数组
更多
横坐标
精度
路径
腾讯
帮助
不同
实用
接下来
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
简述网络安全产生的主要原因
车载电子软件开发
北京网络技术服务中心电话
数据库盈利
计算机软件开发注意事项
信息网络安全管理的基本原则
企业数据库维护项目
猪八戒的软件开发网站
查看as数据库
网络安全设备哪种好
网络安全法几次公开
dell服务器12v电源怎么改
网络安全威胁情报 概念
广州安卓软件开发常见问题
网络安全会影响出国留学吗
国家电网内部网络安全
网络安全检查抽查情况总结
实体行业数据库
js 当前服务器时间
用虚拟机做服务器
苏州戴尔服务器运营方式
软件开发pm职责
对vf数据库的认识
三级数据库技术考试技巧
广州中学生网络安全
网络安全产品怎么申请
兴庆区oa软件开发怎么样
世界上最大的核酸数据库
网络安全会影响出国留学吗
网络技术专业热门吗