package lib import "math" const ( a = 6378245.0 // 长半轴 ee = 0.0066934216229659 // 扁率 ) // 判断是否在中国范围外 func outOfChina(lng, lat float64) bool { return !(lng > 72.004 && lng < 137.8347 && lat > 0.8293 && lat < 55.8271) } // 计算纬度偏差 func transformLat(x, y float64) float64 { ret := -100.0 + 2.0*x + 3.0*y + 0.2*y*y + 0.1*x*y + 0.2*math.Sqrt(math.Abs(x)) ret += (20.0*math.Sin(6.0*x*(math.Pi)) + 20.0*math.Sin(2.0*x*(math.Pi))) * 2.0 / 3.0 ret += (20.0*math.Sin(y*(math.Pi)) + 40.0*math.Sin(y/3.0*(math.Pi))) * 2.0 / 3.0 ret += (160.0*math.Sin(y/12.0*(math.Pi)) + 320.0*math.Sin(y/30.0*(math.Pi))) * 2.0 / 3.0 return ret } // 计算经度偏差 func transformLon(x, y float64) float64 { ret := 300.0 + x + 2.0*y + 0.1*x*x + 0.1*x*y + 0.1*math.Sqrt(math.Abs(x)) ret += (20.0*math.Sin(6.0*x*(math.Pi)) + 20.0*math.Sin(2.0*x*(math.Pi))) * 2.0 / 3.0 ret += (20.0*math.Sin(x*(math.Pi)) + 40.0*math.Sin(x/3.0*(math.Pi))) * 2.0 / 3.0 ret += (150.0*math.Sin(x/12.0*(math.Pi)) + 300.0*math.Sin(x/30.0*(math.Pi))) * 2.0 / 3.0 return ret } // WGS-84 转 GCJ-02 func Wgs84ToGcj02(lng, lat float64) (float64, float64) { if outOfChina(lng, lat) { return lng, lat } dLat := transformLat(lng-105.0, lat-35.0) dLng := transformLon(lng-105.0, lat-35.0) radLat := lat / 180.0 * math.Pi magic := math.Sin(radLat) magic = 1 - ee*magic*magic sqrtMagic := math.Sqrt(magic) dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * math.Pi) dLng = (dLng * 180.0) / (a / sqrtMagic * math.Cos(radLat) * math.Pi) mgLat := lat + dLat mgLng := lng + dLng return mgLng, mgLat }