我有一个数据源,其坐标格式如下。
N642500,W0241600
N660700,W0240000
N652000,W0222700
N660800,W0195500
S645500,E0170800
S644000,E0162200
我不知道这些是什么格式,也不知道如何将它们变成我可以使用的格式。这可以是 JavaScript 或 PHP!
我有一个数据源,其坐标格式如下。
N642500,W0241600
N660700,W0240000
N652000,W0222700
N660800,W0195500
S645500,E0170800
S644000,E0162200
我不知道这些是什么格式,也不知道如何将它们变成我可以使用的格式。这可以是 JavaScript 或 PHP!
看起来像纬度、经度的度、分、秒 (DMS)。有关转换,请参见http://www.ngs.noaa.gov/PC_PROD/Inv_Fwd/readme.htm。
通常地图应用程序将采用十进制形式的纬度和经度,因此您需要将 DMS 转换为十进制(N 是 +,S 是 -)。也就是说,我有点惊讶地发现 Google 地图会直接采用 DMS - 请参阅http://groups.google.com/group/Google-Maps-API/msg/670c54481d91e6b3?pli=1。所以你甚至不需要转换它。例如:
51 57' 32.48",00 55' 55.23"
http://maps.google.com/maps?f=q&hl=en&q=51++57%27+32.48%22,00+55%27+5...
如果你需要计算它:
function DMS(lat,latm,lats,lon,lonm,lons) {
if (lat<0) {
latm = -latm;
lats = -lats;
}
if (lon<0) {
lonm = -lonm;
lons = -lons;
}
lat = lat + latm/60 + lats/3600;
lon = lon + lonm/60 + lons/3600;
return new GLatLng(lat,lon);
}
map.setCenter( DMS(35,3,39.08, -118,9,2.20));
根据http://groups.google.com/group/google-maps-api/msg/2e3436f3bf7d6155。但我认为API应该直接接受它。
格式似乎是逗号分隔值 (CSV)
这些值看起来像纬度(北 + 或南 -)和经度(西 + 或东 -),后跟 ddmmss
我认为 ddmmss 比十进制度更有可能,因为 MM 和 SS 数字小于 59
-编辑-
LONGITUDE 的值必须是 +/- 180 (DDDMMSS),但 LATITUDE 的值必须是 +/- 90 (DDDMMSS)
此 js 函数会将您的字符串清理为已知的 lat lon 格式,用法示例:
clean('N51618017,W0248291');
很简单,所以这里是函数
function clean(string){
var values = string.split(','),
lat,
lon;
if(values[0].search(/S/)){
lat = '-';
}
if(values[1].search(/W/)){
lon = '-';
}
lat += values[0].substring(1, 3)+'.'+values[0].substring(4);
lon += values[1].substring(1, 3)+'.'+values[1].substring(4);
//now you got your values
//so can do this:
var url = 'http://www.gorissen.info/Pierre/maps/googleMapLocation.php?lat='+lat+'&lon='+lon+'&setLatLon=Set';
//or just return them as an object:
pos = {name:'your pos name',latitude:lat,longitude:lon}
}