關(guān)鍵代碼:
using System;using YanZhiwei.DotNet2.Utilities.Models;namespace YanZhiwei.DotNet2.Utilities.Common{ /// <summary> /// 火星坐標(biāo)系 (GCJ-02)與百度坐標(biāo)系 (BD-09) 轉(zhuǎn)換幫助類 /// </summary> public class BDGCJLatLonHelper { /* *參考: *BD09坐標(biāo)系:即百度坐標(biāo)系,GCJ02坐標(biāo)系經(jīng)加密后的坐標(biāo)系。 */ #region 常量 const double x_pi = 3.14159265358979324 * 3000.0 / 180.0; #endregion #region 將GCJ-02坐標(biāo)轉(zhuǎn)換成BD-09坐標(biāo) /// <summary> /// 將GCJ-02坐標(biāo)轉(zhuǎn)換成BD-09坐標(biāo) /// </summary> /// <param name="gcjPoint">GCJ-02坐標(biāo)</param> /// <returns>BD-09坐標(biāo)</returns> public LatLngPoint GCJ02ToBD09(LatLngPoint gcjPoint) { LatLngPoint _bdPoint = new LatLngPoint(); double _x = gcjPoint.LonX, y = gcjPoint.LatY; double _z = Math.Sqrt(_x * _x + y * y) + 0.00002 * Math.Sin(y * x_pi); double _theta = Math.Atan2(y, _x) + 0.000003 * Math.Cos(_x * x_pi); _bdPoint.LonX = _z * Math.Cos(_theta) + 0.0065; _bdPoint.LatY = _z * Math.Cos(_theta) + 0.006; return _bdPoint; } #endregion #region 將BD-09坐標(biāo)轉(zhuǎn)換成GCJ-02坐標(biāo) /// <summary> /// 將BD-09坐標(biāo)轉(zhuǎn)換成GCJ-02坐標(biāo) /// </summary> /// <param name="bdPoint">BD-09坐標(biāo)</param> /// <returns>GCJ-02坐標(biāo)</returns> public LatLngPoint BD09ToGCJ02(LatLngPoint bdPoint) { LatLngPoint _gcjPoint = new LatLngPoint(); double _x = bdPoint.LonX - 0.0065, _y = bdPoint.LatY - 0.006; double _z = Math.Sqrt(_x * _x + _y * _y) - 0.00002 * Math.Sin(_y * x_pi); double _theta = Math.Atan2(_y, _x) - 0.000003 * Math.Cos(_x * x_pi); _gcjPoint.LonX = _z * Math.Cos(_theta); _gcjPoint.LatY = _z * Math.Sin(_theta); return _gcjPoint; } #endregion }}
|
新聞熱點(diǎn)
疑難解答
圖片精選