关键代码:
using System; using YanZhiwei.DotNet2.Utilities.Models; namespace YanZhiwei.DotNet2.Utilities.Common { /// <summary> /// 火星坐标系 (GCJ-02)与百度坐标系 (BD-09) 转换帮助类 /// </summary> public class BDGCJLatLonHelper { /* *参考: *BD09坐标系:即百度坐标系,GCJ02坐标系经加密后的坐标系。 */ #region 常量 const double x_pi = 3.14159265358979324 * 3000.0 / 180.0; #endregion #region 将GCJ-02坐标转换成BD-09坐标 /// <summary> /// 将GCJ-02坐标转换成BD-09坐标 /// </summary> /// <param name="gcjPoint">GCJ-02坐标</param> /// <returns>BD-09坐标</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坐标转换成GCJ-02坐标 /// <summary> /// 将BD-09坐标转换成GCJ-02坐标 /// </summary> /// <param name="bdPoint">BD-09坐标</param> /// <returns>GCJ-02坐标</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 } }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
时间: 2024-11-09 00:01:15