What I want to do is to expand the bounds of a Google Maps by a certain distance. This is because I want to include markers that are outside the bounds of the map since they have overlays attached to them which will overlap onto the current map bounds.
For example, if I am currently viewing the green area on the map below, I want to include all markers in the red area.
Therefore, after getting the bounds from Google Maps I need to extend the bounds by a certain distance to get a new set of bounds.
Here is how I have done it.
For longitude:
data:image/s3,"s3://crabby-images/f4560/f45602ad1a5233963dc79a56474724337760e9c2" alt="ll5"
data:image/s3,"s3://crabby-images/18f97/18f97acaed3b4c21265442a766f6f636fafffa70" alt="ll6"
data:image/s3,"s3://crabby-images/90323/90323fdeec65c6243ba45ef24a7d78e70346b05c" alt="ll7"
For Latitude:
data:image/s3,"s3://crabby-images/9e8e7/9e8e7c11d30fbd6c2afbd4e74af3d349e65e7bfe" alt="ll1"
data:image/s3,"s3://crabby-images/f05a3/f05a3a99a438c78fb959a2b404f22d38da9381d4" alt="ll2"
data:image/s3,"s3://crabby-images/895ac/895ac11cf9e86ae533586cd48f8d1a2a2a466a0a" alt="ll3"
data:image/s3,"s3://crabby-images/2200a/2200a0a297383032f21e3ea0e7f2e9d129e6582e" alt="ll4"
The Javascript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 // returns latlng of new coordinate which is dist from the longitude given
function lngDistance(lat1, lng1, dist) {
var R = 6371000; // m
lat1 = deg2rad(lat1);
lng1 = deg2rad(lng1);
var lng2 = (R*lng1*Math.cos(lat1)-dist)/(R*Math.cos(lat1));
return(rad2lng(lng2));
}
// returns latlng of new coordinate which is dist from the latitude given
function latDistance(lat1, dist) {
var R = 6371000; // m
var lat1 = deg2rad(lat1);
var lat2 = (R*lat1-dist)/R;
return(rad2lat(lat2));
}
function extendBounds(bounds,dist) {
var latNE = bounds.getNorthEast().lat();
var lngNE = bounds.getNorthEast().lng();
var latSW = bounds.getSouthWest().lat();
var lngSW = bounds.getSouthWest().lng();
var latlngNE = new google.maps.LatLng(latDistance(latNE, -dist), lngDistance(latNE,lngNE, -dist));
var latlngSW = new google.maps.LatLng(latDistance(latSW, dist), lngDistance(latSW, lngSW, dist));
return (new google.maps.LatLngBounds(latlngSW, latlngNE));
}
Not that I correct latlngs using the rad2lat and rad2lng functions given in my post converting radians in degrees latitude and longitude
Leave a Reply