Библиотека PROJ.4 и OSGB36
Надеюсь, с тобой все хорошо
Я пытаюсь преобразовать координаты широты / долготы в OSGB36 x и y, используя библиотеку proj.4.
Кто-нибудь еще успешно сделал это? Мне нужно заполнить переменные srcPrj4String и destPrj4String, например
string srcPrj4String = "+ proj = longlat + ellps = WGS84 + datum = WGS84 + no_defs";
string destPrj4String = "+ proj = utm + zone = 11 + ellps = GRS80 + datum = NAD83 + units = m";
но я не могу понять, какой должна быть destPrj4String с OSGB36 - я знаю, что датум должен быть +datum=OSGB36, но все, что я пытаюсь, не работает
Есть идеи?
Спасибо заранее
Leddy
3 ответа
Понял:
string srcPrj4String = "+proj=longlat +ellps=WGS84 +towgs84=0,0,0 +no_defs";
string destPrj4String = "+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.9996012717 +x_0=400000 +y_0=-100000 +ellps=airy +towgs84=446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894 +units=m +no_defs";
ура!
Googling говорит об этом от доктора Джона Стивенсона, академика наук о Земле из Университета Манчестера, который должен сделать это правильно, если кто-то это сделает. Вот цитата.
Проблема заключалась в том, что переход на OSGB36 требует как проекции, так и преобразования данных. До октября 2007 года proj выполнял только прогнозирование, что привело к большому смещению. Вы можете проверить, есть ли у вас новая версия, запустив 'proj -v' или посмотрев файл epsg:
cat /usr/share/proj/epsg | grep -A 1 "British National Grid"
# OSGB 1936 / British National Grid
<27700> +proj=tmerc +lat_0=49 +lon_0=-2 +k=0.9996012717 +x_0=400000
+y_0=-100000 +ellps=airy +datum=OSGB36 +units=m +no_defs <>
В новых версиях +datum=OSGB36.
Если у вас есть старая версия, вы можете исправить ее, заменив строку на:
+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.999601 +x_0=400000 +y_0=-100000
+ellps=airy
+towgs84=446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894 +units=m
+no_defs <>
Сложность состоит в том, что OSGB36 слегка искажен относительно проекций GPS (таких как WGS84 и ETRS89). Это смещение невелико и важно только для более точной съемки. Многие поиски о смещениях OSGB36 поднимают страницы, относящиеся к этому. Если вы хотите компенсировать это, вы можете скачать файл nadgrid и использовать его. По моим данным, это сдвинуло точки примерно на 1 метр.
EPSG:27700 на сайте realreference.org предоставляет различные строки для определения этого, включая строку для proj4.
Вот пример кода в ruby с использованием привязок proj4:
#!/usr/bin/ruby
require 'rubygems'
require 'proj4'
#Some example WGS84 lat lon coordinates to convert:
lon = -0.10322
lat = 51.52237
srcPoint = Proj4::Point.new(Math::PI * lon.to_f / 180,
Math::PI * lat.to_f / 180)
srcPrj = Proj4::Projection.new("+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs")
destPrj = Proj4::Projection.new("+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.999601 +x_0=400000 +y_0=-100000 +ellps=airy +towgs84=446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894 +units=m +no_defs <>")
point = srcPrj.transform(destPrj, srcPoint)
puts "http://www.openstreetmap.org/?mlat=" + lat.to_s + "&mlon=" + lon.to_s + "&zoom=16"
puts "Converts to:";
puts "http://streetmap.co.uk/grid/" + point.x.round.to_s + "_" + point.y.round.to_s + "_106"
Выход:
http://www.openstreetmap.org/?mlat=51.52237&mlon=-0.10322&zoom=16
Преобразует в:
http://streetmap.co.uk/grid/531691_182089_106
Так что это работает точно сейчас. Первоначально я пробовал просто строку 'destPrj' и вызывал метод 'forward', но это отказалось выполнить преобразование данных, в результате чего все получилось на расстоянии 100 м. Казалось необходимым использовать строку 'srcPrj' и метод 'transform', чтобы получить преобразование данных.
См. Также мое сообщение в блоге: код Ruby для преобразования в системы координат британского артиллерийского контроля из WGS84? который включает в себя чистую версию ruby (не proj4) для того же