全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

利用mongodb查询某坐标是否在规定多边形区域内的方法

前言

大家都知道MongoDB是一个基于分布式文件存储的数据库,并提供创建基于地理空间的索引的能力,本文将使用MongoDB 基于地理空间索引进行坐标所在区域的判断及使用。

1.使用百度拾取坐标工具,在地图上定义多边形的坐标点,并把每个点的坐标保存。

百度拾取坐标工具:http://api.map.baidu.com/lbsapi/getpoint/

多边形的坐标点如下:

113.314882,23.163055
113.355845,23.167042
113.370289,23.149564
113.356779,23.129758
113.338238,23.13913
113.330979,23.124706
113.313588,23.140858
113.323865,23.158204
113.314882,23.163055

注意:首尾坐标必须一样,这样才能使多边形闭合。

2.使用百度地图开放平台地图JS Demo,把多边形坐标输入,看看多边形是否合适。

百度地图开放平台地图JS Demo:http://developer.baidu.com/map/jsdemo.htm#c2_9

把以下代码替换源码编辑器中的内容,然后点击运行

<!DOCTYPE html>
<html>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
 <style type="text/css">
 body, html{width: 100%;height: 100%;margin:0;font-family:"微软雅黑";}
 #allmap {height:100%; width: 100%;}
 #control{width:100%;}
 </style>
 <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的密钥"></script>
 <title>设置线、面可编辑</title>
</head>
<body>
 <div id="allmap"></div>
 <div id="control">
 <button onclick = "polyline.enableEditing();polygon.enableEditing();">开启线、面编辑功能</button>
 <button onclick = "polyline.disableEditing();polygon.disableEditing();">关闭线、面编辑功能</button>
 </div>
</body>
</html>
<script type="text/javascript">
 // 百度地图API功能
 var map = new BMap.Map("allmap");
 map.centerAndZoom(new BMap.Point(113.330764,23.155878), 15);
 map.enableScrollWheelZoom();

 var polygon = new BMap.Polygon([
 new BMap.Point(113.314882,23.163055),
 new BMap.Point(113.355845,23.167042),
 new BMap.Point(113.370289,23.149564),
 new BMap.Point(113.356779,23.129758),
 new BMap.Point(113.338238,23.13913),
 new BMap.Point(113.330979,23.124706),
 new BMap.Point(113.313588,23.140858),
 new BMap.Point(113.323865,23.158204)
 ], {strokeColor:"blue", strokeWeight:2, strokeOpacity:0.5}); //创建多边形
 map.addOverlay(polygon); //增加多边形
</script>

多边形区域

3.定义测试坐标

广州东站坐标:113.330908,23.155678 (多边形内)

宏发大厦:113.33831,23.137335 (多边形外)

4.在mongodb测试

1.创建数据库

use testdb;

db.createUser( 
 { 
 "user":"root", 
 "pwd":"123456", 
 "roles":[{"role" : "readWrite", "db":"testdb"}] 
 } 
);

db.auth( 
 { 
 "user":"root", 
 "pwd":"123456" 
 } 
);

2.插入多边形范围并添加索引

db.geo.ensureIndex( 
 { 
 polygons: "2dsphere" 
 } 
);

db.geo.insert(
 {
 polygons:
 {
 type:"Polygon",
 coordinates:[[
 [113.314882,23.163055],
 [113.355845,23.167042],
 [113.370289,23.149564],
 [113.356779,23.129758],
 [113.338238,23.13913],
 [113.330979,23.124706],
 [113.313588,23.140858],
 [113.323865,23.158204],
 [113.314882,23.163055],
 ]]
 }
 }
);

3.判断坐标是否在多边形区域

广州东站坐标:113.330908,23.155678

db.geo.find(
 {
 polygons:
 {
 $geoIntersects:
 {
 $geometry:{ 
  "type" : "Point",
  "coordinates" : [113.330908,23.155678] }
 }
 }
 }
);

输出:

{ "_id" : ObjectId("57c2b1895fb7fd4790f9f099"), "polygons" : { "type" : "Polygon", "coordinates" : [ [ [ 113.314882, 23.163055 ], [ 113.355845, 23.167042 ], [ 113.370289, 23.149564 ], [ 113.356779, 23.129758 ], [ 113.338238, 23.13913 ], [ 113.330979, 23.124706 ], [ 113.313588, 23.140858 ], [ 113.323865, 23.158204 ], [ 113.314882, 23.163055 ] ] ] } }

表示坐标 113.330908,23.155678 在多边形区域内

宏发大厦:113.33831,23.137335

db.geo.find(
 {
 polygons:
 {
 $geoIntersects:
 {
 $geometry:{ 
  "type" : "Point",
  "coordinates" : [113.33831,23.137335] }
 }
 }
 }
);

输出:

表示坐标 113.33831,23.137335 在多边形区域外

总结

以上就是利用mongodb判断坐标是否在指定多边形区域内的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# mongodb  # 坐标查询  # 坐标  # php+mongodb判断坐标是否在指定多边形区域内的实例  # 广州  # 是一个  # 您的  # 大家都  # 坐标点  # 微软  # 在地  # 能使  # 谢谢大家  # 并把  # 图上  # 器中  # 是否合适  # 有疑问  # xhtml  # lt  # gt  # html  # head  # DOCTYPE 


相关文章: 建站之星logo尺寸如何设置最合适?  微信推文制作网站有哪些,怎么做微信推文,急?  长沙做网站要多少钱,长沙国安网络怎么样?  如何配置FTP站点权限与安全设置?  定制建站流程解析:需求评估与SEO优化功能开发指南  想学网站制作怎么学,建立一个网站要花费多少?  英语简历制作免费网站推荐,如何将简历翻译成英文?  如何制作一个表白网站视频,关于勇敢表白的小标题?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  学校为何禁止电信移动建设网站?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何通过商城自助建站源码实现零基础高效建站?  开心动漫网站制作软件下载,十分开心动画为何停播?  建站之星后台管理:高效配置与模板优化提升用户体验  如何在VPS电脑上快速搭建网站?  用v-html解决Vue.js渲染中html标签不被解析的问题  ,sp开头的版面叫什么?  如何批量查询域名的建站时间记录?  个人摄影网站制作流程,摄影爱好者都去什么网站?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  php json中文编码为null的解决办法  活动邀请函制作网站有哪些,活动邀请函文案?  如何确认建站备案号应放置的具体位置?  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  c++ stringstream用法详解_c++字符串与数字转换利器  建站主机是否属于云主机类型?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  营销式网站制作方案,销售哪个网站招聘效果最好?  建站之星好吗?新手能否轻松上手建站?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  威客平台建站流程解析:高效搭建教程与设计优化方案  c# 服务器GC和工作站GC的区别和设置  建站主机CVM配置优化、SEO策略与性能提升指南  在线制作视频的网站有哪些,电脑如何制作视频短片?  如何快速完成中国万网建站详细流程?  MySQL查询结果复制到新表的方法(更新、插入)  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  已有域名和空间如何快速搭建网站?  如何快速查询域名建站关键信息?  建站ABC备案流程中有哪些关键注意事项? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。