- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试合并两个数据库以合并两个客户的网站。但是,客户端 A 一直使用常规的纬度/经度对进行地理定位,而客户端 B 使用兰伯特 72 (X/Y) 坐标。
我已经构建了一个应该转换这些坐标的脚本(因为我不确定最终合并的数据库中将使用哪个坐标,我正在尝试以任何一种方式转换它们)。
我从这里拿了一些片段:http://zoologie.umh.ac.be/tc/algorithms.aspx
请注意,下面提到的所有坐标都指向比利时的位置。
我正在转换一些坐标以查看计算是否正确,但我得到的坐标似乎很遥远。作为引用,比利时的中心大致是(北 50.84323737103243,东 4.355735778808594),所以我希望所有坐标都接近这些值。
我将 Lambert 72 值 (X: 151488250, Y: 170492909) 转换为 Lat/Lon 对,但结果是: (-87.538.... , -50.724....) 这与预期值相差甚远.
如果我转换整圈(Lambert->LatLon->Lambert,反之亦然),我会得到与输入相同的结果值,所以我知道我的转换至少是一致的,并且转换是彼此完美的反转。
我也尝试了一些在线转换器工具,它们给了我相同的 (-87.538...., -50.724....) 结果。
由于多个来源产生相同的结果,并且我的转换是彼此的正确反转,我认为计算本身是正确的,但结果值仍然需要进一步转换/偏移?
我认为自己在代数方面已经足够了,但我完全无法使用制图投影。
有人可以对此有所了解吗?
额外信息
public static Lambert72 LatLon_To_Lambert72(LatLon latlon)
{
var lat = latlon.Lat;
var lng = latlon.Lon;
double LongRef = 0.076042943;
//=4°21'24"983
double bLamb = 6378388 * (1 - (1 / 297));
double aCarre = Math.Pow(6378388, 2);
double eCarre = (aCarre - Math.Pow(bLamb, 2)) / aCarre;
double KLamb = 11565915.812935;
double nLamb = 0.7716421928;
double eLamb = Math.Sqrt(eCarre);
double eSur2 = eLamb / 2;
//conversion to radians
lat = (Math.PI / 180) * lat;
lng = (Math.PI / 180) * lng;
double eSinLatitude = eLamb * Math.Sin(lat);
double TanZDemi = (Math.Tan((Math.PI / 4) - (lat / 2))) * (Math.Pow(((1 + (eSinLatitude)) / (1 - (eSinLatitude))), (eSur2)));
double RLamb = KLamb * (Math.Pow((TanZDemi), nLamb));
double Teta = nLamb * (lng - LongRef);
double x = 0;
double y = 0;
x = 150000 + 0.01256 + RLamb * Math.Sin(Teta - 0.000142043);
y = 5400000 + 88.4378 - RLamb * Math.Cos(Teta - 0.000142043);
return new Lambert72(x, y);
}
public static LatLon Lambert72_To_LatLon(Lambert72 lb72)
{
double X = lb72.X;
double Y = lb72.Y;
double LongRef = 0.076042943;
//=4°21'24"983
double nLamb = 0.7716421928;
double aCarre = Math.Pow(6378388, 2);
double bLamb = 6378388 * (1 - (1 / 297));
double eCarre = (aCarre - Math.Pow(bLamb, 2)) / aCarre;
double KLamb = 11565915.812935;
double eLamb = Math.Sqrt(eCarre);
double eSur2 = eLamb / 2;
double Tan1 = (X - 150000.01256) / (5400088.4378 - Y);
double Lambda = LongRef + (1 / nLamb) * (0.000142043 + Math.Atan(Tan1));
double RLamb = Math.Sqrt(Math.Pow((X - 150000.01256), 2) + Math.Pow((5400088.4378 - Y), 2));
double TanZDemi = Math.Pow((RLamb / KLamb), (1 / nLamb));
double Lati1 = 2 * Math.Atan(TanZDemi);
double eSin = 0;
double Mult1 = 0;
double Mult2 = 0;
double Mult = 0;
double LatiN = 0;
double Diff = 0;
double lat = 0;
double lng = 0;
do {
eSin = eLamb * Math.Sin(Lati1);
Mult1 = 1 - eSin;
Mult2 = 1 + eSin;
Mult = Math.Pow((Mult1 / Mult2), (eLamb / 2));
LatiN = (Math.PI / 2) - (2 * (Math.Atan(TanZDemi * Mult)));
Diff = LatiN - Lati1;
Lati1 = LatiN;
} while (Math.Abs(Diff) > 2.77777E-08);
lat = (LatiN * 180) / Math.PI;
lng = (Lambda * 180) / Math.PI;
return new LatLon(lat, lng);
}
最佳答案
我是您在帖子中提到的页面的作者。
我不知道您是否解决了您的问题,但您提供的兰伯特坐标不正确。我认为你必须将它们除以 1000。这给出了 x=151488.250 和 y=170492.909,它们是可能的坐标,对应于......布鲁塞尔的一条街道。
在与 lat/lng 值之间转换时要小心选择基准。
关于c# - Lambert 72 转换为 Lat/Lon 对,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16084372/
我试过以下方法,输入:纬度/经度数据然后我会计算它周围的一个方框,比方说 50 米,所以东距/北距值 +/- 50 米。 现在我将它重新转换为纬度/经度并使用脚本: http://robotics.a
我正在使用 proj4 将纬度/对数坐标投影到 UTM。但我无法从 UTM 投影回 lat/log。对于以下示例,我希望代码返回给定的经纬度/对数 [48.37966, 2.504635]。相反,它返
我希望能够找到离经度/纬度元组最近的位置的经度/纬度坐标索引。这已经在 Java API 中作为 GridCoordSystem.findXYindexFromLatLon() 提供,但我还没有在
我是 python 新手,我正在尝试编写一个函数,该函数将从尺寸为 [时间、高度、经度、纬度] 的 netcdf 文件中获取 numpy 数组,并将函数插值到指定的纬度和经度。我已经研究过 scipy
我有一张包含邮政编码 (int) 和位置 (point) 的表格。我正在寻找 MySql 查询或函数。这是日期的示例。我想返回 100 英里。 37922|POINT(35.85802 -84.119
有谁知道是否有任何现有的解决方案可以从一个点(经度、纬度)确定时区? 我可以对这个项目所需的少数几个进行硬编码,但最好使用预构建的解决方案。 谢谢。 最佳答案 使用网络服务,例如 geonames 提
我正在构建一个小脚本,客户将在其页面上安装该脚本。地理定位对它来说不是必需的,但是如果它存在,那将是很好的。有没有办法让我检查客户端页面是否请求了地理位置信息,以及用户是否选择了允许获取纬度和经度而不
我有一组经纬度坐标,看起来像, 纬度=9339452,经度=4294611105 纬度=9386855,经度=4294690789 纬度=9388898,经度=4294697554 纬度=938943
我们正在开发一个现有网站,但无法重新构建数据库以进行更好的优化,因此不幸的是,我们正在运行大量“联接”来链接到每个表。 我们正在链接几个临时存储的邮政编码、用户帐户、体育事件、年龄组等的小表。 我不擅
我只是通过使用 [NSString stringWithFormat:@"%.5f, %.5f"]; 将 CLLocations 转换为逗号分隔的字符串,例如 "75.45874, -45.17292
我想为 Flask-Admin 创建一个 View 以在几何字段中输入坐标。如何创建两个文本字段并将它们转换为几何对象? 这是我目前为止尝试过的方法(除了不可数的其他事情) class CustomA
我想使用 Basemap 包将城市名称绘制到德国 map 上。我指定了经度和纬度值: Cname=Form_Cities["name"].values Clat=Form_Cities["lat
我正在尝试使用 Tweepy API 下载推文,但我无法在输出中获取地理坐标。 我正在寻找在输出数据中包含纬度和经度的方法。 感谢任何帮助..提前致谢。该代码是在 python 3.x 中开发的,输出
我正在尝试在 map 上放置一堆 (x,y) 点,它们的原点为经纬度。我想设置一个自定义的横向墨卡托投影,以我的原点为中心,并使用它将我的点投影到 lon-lat。 这似乎是 GeoToolkit(或
我如何访问用户的 iPhone 照片库并获取这些照片的经纬度信息? 谢谢 最佳答案 纬度/经度信息(如果有)将位于 JPG 文件的 EXIF 部分中。查看这个 exif iPhone 库: http:
我绞尽脑汁想不出如何构造这个 SQL 查询。 我有 3 张 table 。 用户表 用户 ID 姓名 图片等等 tag_ref表格 用户 ID tag_id 地理位置表 用户 ID geolat 吉隆
实体A有一个字段name 实体B有一个字段city 实体C有字段lat和lon 实体A与实体有一对多关联 B命名bees 实体B与实体有多对一关联 C命名cees 现在我想选择全部 A距离 Y 点 X
我有来自 GPS 的位置(lon_base,lat_base)。我有一个位置列表(lon1、lat1|lon2、lat2|lon3、lat3...)这个名单很长,遍布世界各地。 我的问题是:1. 如何
我想提取一个相当大的 netcdf 文件的空间子集。来自 Loop through netcdf files and run calculations - Python or R from pylab
我在导入具有 SRID 4326 的 wkt 多点特征的文件时遇到一些问题,其坐标是有序的(纬度、经度): >st_crs(4326) Coordinate Reference System: U
我是一名优秀的程序员,十分优秀!