我有一点问题。我正在尝试使用 Javascript 和 Google Maps API v2 执行以下操作:
我可以使用在互联网上找到的公式很好地绘制单个圆圈。我面临的问题是圈子必须:
A. 同心,并且 B. 每个“象限”必须有不同的半径,即 NE、NW、SE 和 SW
我几乎在互联网上能想到的所有地方都进行了搜索,但没有想出如何做到这一点。很明显,以前有人这样做过,因此我为什么要在程序员论坛上提问。:)
谢谢!
更新:我已经使用以下代码绘制了我认为每个点的坐标。对于下图:
这是使用以下 JS 获得的:
注意:此 javascript 来自(稍作修改)以下站点,该站点可能包含更多关于算法最终可能的答案:http ://www.movable-type.co.uk/scripts/latlong.html
更新2:我能够在谷歌地图中得到这个:
使用以下代码创建:
var NEQ = [0, 90];
var SEQ = [90, 180];
var SWQ = [180, 270];
var NWQ = [270, 0];
// var centrePoint = new LatLon(25.0, -83.1);
// pointsForWindQuadrant(NEQ, centrePoint, 50);
function pointsForWindQuadrant(quadrantDegrees, centrePoint, radius){
var points = [];
// Points must be pushed into the array in order
points.push(new google.maps.LatLng(centrePoint.lat, centrePoint.lon));
for(i = quadrantDegrees[0]; i <= quadrantDegrees[1]; i++){
var point = centrePoint.destPoint(i, radius * 1.85);
points.push(new google.maps.LatLng(point.lat, point.lon)); // Radius should be in nautical miles from NHC
}
points.push(new google.maps.LatLng(centrePoint.lat, centrePoint.lon));
return points;
}
更新 3:我可能还应该指出,这是一个地理坐标系(因为整个事情都是针对热带气旋风半径),而不是笛卡尔坐标系。谢谢!