google map上实现通过点击地图任意点进行标记并形成多边形

首先我们实现的功能是点击地图标记通过动画的形式落到地图上,当点击多点的时候会形成一片不规则的多边形区域,并且判断某一点是否在这个区域。

实现这个功能我们需要对google map 上的marker和polygon进行了解。

官方参考:

https://developers.google.com/maps/documentation/javascript/3.exp/reference?hl=zh-cn#Map

首先载入一个google map并显示到一个div上,可以参考:

http://www.easymorse.com/index.php/archives/602

地图可以显示到页面上以后我们需要控制的对点击地图的处理:

image

当点击的时候我们将被点击的点的坐标(经纬度)存放到一个数组中,我们还应该将被点击的点加上marker标记,并且要以动画的形式落到地图上:

image

接下来我们就要将被点击过的点连起来形成一片多边形区域,需要介绍的是google map上的多边形是根据点的顺序自动连接而成的,代码如下:

image

这样我们就可以实现一下效果:

image

image

最后我们还可以判断某一点是否在这个红色的区域内,由于google map api上没有已经写好的判断的方法,所以我们需要自己写方法对其进行实现,大体的思路就是先得到多边形的Bounds的getBounds方法,通过此方法我们可以知道这个区域经度的最大值和最小值,纬度的最大值和最小值,然后我们再通过一个方法containsLatLng判断已知的点的经纬度是否在Bounds的经纬度的范围内:


google.maps.Polygon.prototype.getBounds = function() {
var bounds = new google.maps.LatLngBounds();
var paths = this.getPaths();
var path;

for (var p = 0; p < paths.getLength(); p++) {
path = paths.getAt(p);
for (var i = 0; i < path.getLength(); i++) {
bounds.extend(path.getAt(i));
}
}

return bounds;
}


google.maps.Polygon.prototype.containsLatLng = function(latLng) {

// Exclude points outside of bounds as there is no way they are in the poly

var lat, lng;

//arguments are a pair of lat, lng variables
if(arguments.length == 2) {
if(typeof arguments[0]=="number" && typeof arguments[1]=="number") {
lat = arguments[0];
lng = arguments[1];
}
} else if (arguments.length == 1) {
var bounds = this.getBounds();

if(bounds != null && !bounds.contains(latLng)) {
return false;
}
lat = latLng.lat();
lng = latLng.lng();
} else {
console.log("Wrong number of inputs in google.maps.Polygon.prototype.contains.LatLng");
}
var inPoly = false;

var numPaths = this.getPaths().getLength();
for(var p = 0; p < numPaths; p++) {
var path = this.getPaths().getAt(p);
var numPoints = path.getLength();
var j = numPoints-1;

for(var i=0; i < numPoints; i++) {
var vertex1 = path.getAt(i);
var vertex2 = path.getAt(j);

if (vertex1.lng() < lng && vertex2.lng() >= lng || vertex2.lng() < lng && vertex1.lng() >= lng) {
if (vertex1.lat() + (lng - vertex1.lng()) / (vertex2.lng() - vertex1.lng()) * (vertex2.lat() - vertex1.lat()) < lat) {
inPoly = !inPoly;
}
}

j = i;
}
}

return inPoly;
}

这样就实现了以上我们提到的所有内容。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要在百度地图开放平台申请一个开发者账号并创建一个应用,获取到应用的AK(Access Key)。 然后,在Spring Boot项目中,你可以使用HttpClient或者RestTemplate来调用百度地图接口并获取返回结果。具体实现步骤如下: 1. 添加HttpClient或RestTemplate相关依赖。 2. 创建一个POJO类来封装百度地图API返回的数据,例如: ```java public class BaiduMapResponse { private int status; private String message; private List<Marker> markers; // getters and setters } public class Marker { private double longitude; private double latitude; private String title; // getters and setters } ``` 3. 创建一个Service类来调用百度地图API,例如: ```java @Service public class BaiduMapService { private static final String BAIDU_MAP_API_URL = "http://api.map.baidu.com/place/v2/search"; private static final String AK = "your_access_key_here"; public List<Marker> search(String query, String region) { RestTemplate restTemplate = new RestTemplate(); String url = String.format("%s?query=%s&region=%s&output=json&ak=%s", BAIDU_MAP_API_URL, query, region, AK); BaiduMapResponse response = restTemplate.getForObject(url, BaiduMapResponse.class); if (response.getStatus() == 0) { return response.getMarkers(); } else { throw new RuntimeException("Failed to search on Baidu Map API: " + response.getMessage()); } } } ``` 4. 在Controller中调用BaiduMapService,并将返回的Marker列表传递给前端页面进行标记。例如: ```java @Controller public class MapController { @Autowired private BaiduMapService baiduMapService; @GetMapping("/search") public String search(@RequestParam("query") String query, @RequestParam("region") String region, Model model) { List<Marker> markers = baiduMapService.search(query, region); model.addAttribute("markers", markers); return "map"; } } ``` 5. 在前端页面使用JavaScript或其他地图API库来显示地图标记。例如,在使用百度地图JavaScript API时,可以使用如下代码: ```html <div id="map" style="height: 600px;"></div> <script src="http://api.map.baidu.com/api?v=2.0&ak=your_access_key_here"></script> <script> var map = new BMap.Map("map"); map.centerAndZoom("北京", 12); var markers = /*[[${markers}]]*/ []; for (var i = 0; i < markers.length; i++) { var marker = new BMap.Marker(new BMap.Point(markers[i].longitude, markers[i].latitude)); marker.setTitle(markers[i].title); map.addOverlay(marker); } </script> ``` 以上就是在Spring Boot项目中调用百度地图API标记的基本步骤。当然,具体实现方式还需要根据你的实际需求和项目结构进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值