google map限制地图缩放级别和显示范围
来源:互联网 发布:淘宝店宝贝详情模板 编辑:程序博客网 时间:2024/05/16 14:08
google map限制地图缩放级别和显示范围
在使用google地图的时候,很多情况下我们希望只显示地图的一部分并限制地图的缩放级别。这个时候就需要自定义google map的地图缩放级别和显示范围。
自定义地图缩放范围
控制地图的缩放级别范围需要重载GMapType的getMinimumResolution()和getMaximumResolution()方法。下面的代码将地图的缩放级别设置为12-16。
1 function setMapResolution()
2 {
3 //获取所有地图类型
4 var mapTypes = map.getMapTypes();
5 //对所有地图类型限制缩放级别
6 for(var i=0; i<mapTypes.length; i++)
7 {
8 mapTypes[i].getMinimumResolution = function() { return 12; };
9 mapTypes[i].getMaximumResulution = function() { return 16; };
10 }
11 }
2 {
3 //获取所有地图类型
4 var mapTypes = map.getMapTypes();
5 //对所有地图类型限制缩放级别
6 for(var i=0; i<mapTypes.length; i++)
7 {
8 mapTypes[i].getMinimumResolution = function() { return 12; };
9 mapTypes[i].getMaximumResulution = function() { return 16; };
10 }
11 }
然后在加载地图后调用此函数就可以将地图的缩放级别限制为12-16。
自定义地图的显示范围
限制地图的显示范围稍微复杂一些。首先使用GLatLngBounds定义一个地图的范围。在地图拖动或移动后判断地图的中心是否移出限制的范围。如果超出范围则移动地图到限制范围内。
1 //限制地图的显示范围
2 function checkMapBounds(map, mapRange)
3 {
4 if(map)
5 {
6 if(mapRange.contains(map.getCenter()))
7 {
8 return;
9 }
10
11 var center = map.getCenter();
12 var centerX = center.lng();
13 var centerY = center.lat();
14
15 var maxX = mapRange.getNorthEast().lng();
16 var maxY = mapRange.getNorthEast().lat();
17 var minX = mapRange.getSouthWest().lng();
18 var minY = mapRange.getSouthWest().lat();
19
20 if(centerX < minX) { centerX = minX; }
21 if(centerX > maxX) { centerX = maxX; }
22 if(centerY < minY) { centerY = minY; }
23 if(centerY > maxY) { centerY = maxY; }
24
25 map.panTo(new google.maps.LatLng(centerY, centerX));
26 }
27 }
2 function checkMapBounds(map, mapRange)
3 {
4 if(map)
5 {
6 if(mapRange.contains(map.getCenter()))
7 {
8 return;
9 }
10
11 var center = map.getCenter();
12 var centerX = center.lng();
13 var centerY = center.lat();
14
15 var maxX = mapRange.getNorthEast().lng();
16 var maxY = mapRange.getNorthEast().lat();
17 var minX = mapRange.getSouthWest().lng();
18 var minY = mapRange.getSouthWest().lat();
19
20 if(centerX < minX) { centerX = minX; }
21 if(centerX > maxX) { centerX = maxX; }
22 if(centerY < minY) { centerY = minY; }
23 if(centerY > maxY) { centerY = maxY; }
24
25 map.panTo(new google.maps.LatLng(centerY, centerX));
26 }
27 }
然后将此方法绑定到dragend事件。在每次地图拖动结束时判断当前位置是否在限制范围之内。
1 //设置地图显示范围
2 google.maps.Event.addListener(map, "dragend", function(){
3 checkMapBounds(map, mapRangeBound);
4 });
2 google.maps.Event.addListener(map, "dragend", function(){
3 checkMapBounds(map, mapRangeBound);
4 });
- google map限制地图缩放级别和显示范围
- google map限制地图缩放级别和显示范围
- Google Maps API V3学习【限制地图缩放级别和显示范围 包含V2版本程序】
- Google Maps API V3学习【限制地图缩放级别和显示范围 包含V2版本程序】
- Google maps V3控制地图的缩放和显示范围
- 百度地图 根据标注点坐标范围计算显示缩放级别zoom自适应显示地图
- OpenLayers3根据范围设置地图缩放级别
- Google map获取手机屏幕当前显示地图的范围
- 百度地图API二:根据标注点坐标范围计算显示缩放级别zoom自适应显示地图
- ios通过google map显示地图和乘车信息
- 通过 Google Map 显示地图和乘车信息的方法
- ios通过google map显示地图和乘车信息
- 通过 Google Map 显示地图和乘车信息的方法
- Google地图上市级别分块显示
- Google Map API如何自动缩放级别教程
- OpenLayers设置地图缩放最小范围和最大范围
- Android用户定位Google Map显示地图
- android Google Map API V2(显示地图)
- ffmpeg 0.6.3 代码, 经过我努力,能够在vs 2005 下单步调试代码
- JVM加载class文件的原理机制
- 弹出光驱代码
- jQuery类库新手使用指南之AJAX方法 - 第一部分
- 配置widows的host
- google map限制地图缩放级别和显示范围
- blog的地址http://blog.sina.com.cn/gulant
- IOS ICON 圆角半径
- Java打印程序设计全攻略
- Could not initialize class org.eclipse.wst.server.ui.internal.provisional.UIDecoratorManager
- 实现silverlight实现拓扑图、网状结构图(有图形)
- hdoj 2298 Toxophily(数学推导或三分+二分)
- 点击输入框清空和全选提示内容
- 微软下调Azure云服务价格 与亚马逊竞争