Proj4js - 你可以在没有区域的情况下将Lat / Long转换为UTM吗?

时间:2015-04-15 16:04:14

标签: javascript proj4js

我尝试使用Proj4js执行一些坐标转换,但是关于如何使用它的信息非常少。

我希望能够做的是将纬度和经度转换为UTM坐标,但我不知道该区域是什么。这应该很容易,因为经度决定了区域,如果你知道区域默认出来。

我已经尝试在Proj4js中执行此操作,但我收到错误说

  

"未捕获的TypeError:undefined不是函数"

我的代码像这样松散:

 proj4Arr = [-105.2098, 39.7458];
 var source = ('+proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees +no_defs');
 var dest = ("+proj=utm +ellps=GRS80 +datum=nad83 +units=m +no_defs");

 console.log(proj4(source, dest, proj4Arr));

我不知道如果没有包含区域,是否可以这样做。我可以先计算区域然后将其放入字符串中,如果我需要,但我试图保持简单。

如果有人知道任何关于示例的纯粹js资源(不一定使用OpenLayers 3),我也会对此表示感谢。

谢谢!

2 个答案:

答案 0 :(得分:2)

我认为您必须为proj4投影指定投影的区域信息才能使用该库。没有区域,它不是有效的proj4投影。

以下是关于如何从lon / lat识别区域的question

以下是两个示例:[1][2]

您可以自己查看js代码。

答案 1 :(得分:0)

今年是 2021 年,可以发布一个可运行的代码,不仅可以回答问题,还可以演示导致坐标转换结果的所有步骤。

  function utmzone_from_lon(lon_deg) {
    //get utm-zone from longitude degrees
    return parseInt(((lon_deg+180)/6)%60)+1;
  }
  
  function proj4_setdef(lon_deg) {
    //get UTM projection definition from longitude
    const utm_zone = utmzone_from_lon(lon_deg);
    const zdef = `+proj=utm +zone=${utm_zone} +datum=WGS84 +units=m +no_defs`;
    return zdef;
  }
  
  // computation test
  let lon_input = 95.99;
  let lat_input = 15.15;
  console.log("Input (long,lat):", lon_input, lat_input);
  const azone = utmzone_from_lon(lon_input);
  console.log(`UTM zone from longitude: ${azone}`);
  console.log("AUTO projection definition:", proj4_setdef(lon_input));
  
  // define proj4_defs for easy uses
  // "EPSG:4326" for long/lat degrees, no projection
  // "EPSG:AUTO" for UTM 'auto zone' projection
  proj4.defs([
  [
    "EPSG:4326",
    "+title=WGS 84 (long/lat) +proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees"
  ],
  ["EPSG:AUTO", proj4_setdef(lon_input)]]);
 
  // usage:
  // conversion from (long/lat) to UTM (E/N)
  const en_m = proj4("EPSG:4326", "EPSG:AUTO", [lon_input, lat_input]);
  const e4digits = en_m[0].toFixed(4); //easting
  const n4digits = en_m[1].toFixed(4); //northing
  console.log(`Zone ${azone}, (E,N) m: ${e4digits}, ${n4digits}`);
  
  // inversion from (E,N) to (long,lat)
  const lonlat_chk = proj4("EPSG:AUTO", "EPSG:4326", en_m);
  console.log("Inverse check:", lonlat_chk);
<script src="https://cdnjs.cloudflare.com/ajax/libs/proj4js/2.6.2/proj4.js"></script>