经纬度点与投影坐标系下坐标点的互相转换
经纬度点与投影坐标系下坐标点的互相转换
来源:http://bbs.esrichina-bj.cn/ESRI/thread-39778-1-1.html
WGS84 和北京54的经纬度点与投影坐标系下坐标点的互相转换VB.NET源码如下:
1
\'\'\' <summary>
2
\'\'\' 将经纬度点转换为某投影下的坐标点
3
\'\'\' </summary>
4
\'\'\' <param name="pPoint">经纬度点</param>
5
\'\'\' <returns>某投影下的坐标点</returns>
6
\'\'\' <remarks>其中pPoint的X是经度,Y是纬度,单位都是度,千万不要搞错,否则转换出来的值是不对的或转换不出值</remarks>
7
Private Function GetProjectPoint(ByVal pPoint As IPoint) As IPoint
8
Dim pSRF As ISpatialReferenceFactory = New SpatialReferenceEnvironment
9
pPoint.SpatialReference = pSRF.CreateGeographicCoordinateSystem(esriSRGeoCSType.esriSRGeoCS_WGS1984)
10
pPoint.Project(pSRF.CreateProjectedCoordinateSystem(esriSRProjCSType.esriSRProjCS_Beijing1954GK_23N))
11
Return pPoint
12
End Function
13
\'\'\' <summary>
14
\'\'\' 将点转换为经纬度点
15
\'\'\' </summary>
16
\'\'\' <param name="x">点X坐标</param>
17
\'\'\' <param name="y">点Y坐标</param>
18
\'\'\' <returns>经纬度点</returns>
19
\'\'\' <remarks></remarks>
20
Private Function GetGeoPoint(ByVal x As Double, ByVal y As Double) As IPoint
21
Dim pProPoint As IPoint = New Point
22
pProPoint.PutCoords(x, y)
23
Dim pSRF As ISpatialReferenceFactory = New SpatialReferenceEnvironment
24
pProPoint.SpatialReference = pSRF.CreateProjectedCoordinateSystem(esriSRProjCSType.esriSRProjCS_Beijing1954GK_23N)
25
pProPoint.Project(pSRF.CreateGeographicCoordinateSystem(esriSRGeoCSType.esriSRGeoCS_WGS1984))
26
Return pProPoint
27
End Function
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27