12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- 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
- }
|