0

我正在实现一个插入 GPX 轨道的 3D 表面,如本博客所述:http: //blog.mastermaps.com/2013/11/showing-gps-tracks-in-3d-with-threejs.html

我的 3D 地图是使用 RGF93 投影使用 QGIS 制作的自定义地图,我无法在 d3.js 中找到好的投影

我的地图的 gdalinfo 是

["RGF93 / Lambert-93",
GEOGCS["RGF93",
    DATUM["Reseau_Geodesique_Francais_1993",
    SPHEROID["GRS 1980",6378137,298.257222101,
            AUTHORITY["EPSG","7019"]],
        TOWGS84[0,0,0,0,0,0,0],
        AUTHORITY["EPSG","6171"]],
    PRIMEM["Greenwich",0,
        AUTHORITY["EPSG","8901"]],
    UNIT["degree",0.0174532925199433,
        AUTHORITY["EPSG","9122"]],
    AUTHORITY["EPSG","4171"]],
PROJECTION["Lambert_Conformal_Conic_2SP"],
PARAMETER["standard_parallel_1",49],
PARAMETER["standard_parallel_2",44],
PARAMETER["latitude_of_origin",46.5],
PARAMETER["central_meridian",3],
PARAMETER["false_easting",700000],
PARAMETER["false_northing",6600000],
UNIT["metre",1,
    AUTHORITY["EPSG","9001"]],
AXIS["X",EAST],
AXIS["Y",NORTH],
AUTHORITY["EPSG","2154"]]
Origin = (585097.372746756765991,6171321.216855648905039)
Pixel Size = (15.149120309400001,-14.887674158699999)
Metadata:
    AREA_OR_POINT=Area
Image Structure Metadata:
    INTERLEAVE=BAND
Corner Coordinates:
Upper Left  (  585097.373, 6171321.217) (  1d36' 3.31"E, 42d37'56.65"N)
Lower Left  (  585097.373, 6165946.766) (  1d36' 7.48"E, 42d35' 2.74"N)
Upper Right (  590475.310, 6171321.217) (  1d39'59.00"E, 42d37'59.67"N)
Lower Right (  590475.310, 6165946.766) (  1d40' 2.98"E, 42d35' 5.75"N)
Center      (  587786.342, 6168633.992) (  1d38' 3.19"E, 42d36'31.22"N)
Band 1 Block=355x5 Type=Float32, ColorInterp=Gray
    Computed Min/Max=1735.500,2908.485
NoData Value=-3.4028234663852886e+38

还有我正在尝试的投影(在许多其他组合中),但没有成功。我可以看到当 scale(1) 时点被放置在表面的中心,但在增加比例值时移动很远。

var projection = d3.geoConicConformal()
    .rotate([-3, 0])
    .center([1.6342194, 42.6086722])
    .parallels([49, 44])
    .translate([100, 100])
    .scale(terrain.map);

我想知道我做错了什么以及我的投影的适当值是什么。


编辑

我几乎找到了解决方案:

var projection = d3.geoConicConformal()
    .rotate([-terrain.center[1], 0])
    .center([0, terrain.center[0]])
    .parallels([44, 49])
    .translate([100, 100])
    .scale(terrain.map);

其中 terrain.center[lat, lon] 是来自 gdalinfo 的角坐标的值:中心。

即使不完全准确,点也几乎与他们的预期位置相符;它们似乎有点逆时针旋转。我尝试使用旋转值,但它只是将所有投影转换为左或右。

4

0 回答 0