用一個多邊形繪製多個路徑----------隨着倍數圈畫
@大衛斯特拉坎回答解決了我的問題的一個重要組成部分。 下面是該解決方案的一部分:首先你必須用這種「畫圓」的功能,而不是谷歌地圖API V3的Circle對象:
function drawCircle(point, radius, dir)
{
var d2r = Math.PI/180; // degrees to radians
var r2d = 180/Math.PI; // radians to degrees
var earthsradius = 3963; // 3963 is the radius of the earth in miles
var points = 32;
// find the raidus in lat/lon
var rlat = (radius/earthsradius) * r2d;
var rlng = rlat/Math.cos(point.lat() * d2r);
var extp = new Array();
if (dir==1) {var start=0;var end=points+1} // one extra here makes sure we connect the
else{var start=points+1;var end=0}
for (var i=start; (dir==1 ? i < end : i > end); i=i+dir)
{
var theta = Math.PI * (i/(points/2));
ey = point.lng() + (rlng * Math.cos(theta)); // center a + radius x * cos(theta)
ex = point.lat() + (rlat * Math.sin(theta)); // center b + radius y * sin(theta)
extp.push(new google.maps.LatLng(ex, ey));
}
return extp;
}
該函數返回的路徑,所以你可以用它來打造專業化的數組路徑至極後你將用它來建立一個單一的多邊形對象:
var polys = [] ;
$(xml).find("trkpt").each(function() { // Parsing every points of my track
var p = new google.maps.LatLng($(this).attr("lat"), $(this).attr("lon"));
points.push(p);
if ((i++ % 10) == 0) // Only display a circle every 10 points
{
polys.push(drawCircle(p,radius/1609.344,1)) ; // Radius value is in meters for me, so i divide to make it in miles
}
});
peanutcircle = new google.maps.Polygon({
paths: polys,
strokeOpacity: 0,
strokeWeight: 0,
fillColor: color,
fillOpacity: 0.35,
});
peanutcircle.setMap(map);
,這是所有的,你已經開出複雜的,但單個多邊形,可能更容易使用。
對我來說唯一的問題是,檢查包含在這個單一的多邊形(與谷歌函數containsLocation和github.com/tparkin/Google-Maps-Point-in-Polygon)包含的標記是行不通的,所以我不得不繼續使用我的倍數圈子檢查標記是否在我的區域。
感謝@david strachan他的回答。
有趣的問題和發達的問題。 ..我唯一的想法是你可能會考慮將微觀幾何體合併爲一個更大的宏觀幾何體 - 在GIS中我們稱之爲[Dissolve](http://wiki.gis.com/wiki/index.php/Dissolve)功能。在不知道服務器端技術的情況下,很難指出你的方向。你可以近似解決客戶端,但我認爲這將是一個乏味的練習。 – elrobis