-
Notifications
You must be signed in to change notification settings - Fork 110
/
Copy pathprojections.go
45 lines (38 loc) · 1.11 KB
/
projections.go
1
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package project
import (
"fmt"
"math"
"github.com/paulmach/orb"
)
const earthRadiusPi = orb.EarthRadius * math.Pi
// Mercator performs the Spherical Pseudo-Mercator projection used by most web maps.
var Mercator = struct {
ToWGS84 orb.Projection
}{
ToWGS84: func(p orb.Point) orb.Point {
return orb.Point{
180.0 * p[0] / earthRadiusPi,
180.0 / math.Pi * (2*math.Atan(math.Exp(p[1]/orb.EarthRadius)) - math.Pi/2.0),
}
},
}
// WGS84 is what common uses lon/lat projection.
var WGS84 = struct {
// ToMercator projections from WGS to Mercator, used by most web maps
ToMercator orb.Projection
}{
ToMercator: func(g orb.Point) orb.Point {
y := math.Log(math.Tan((90.0+g[1])*math.Pi/360.0)) * orb.EarthRadius
return orb.Point{
earthRadiusPi / 180.0 * g[0],
math.Max(-earthRadiusPi, math.Min(y, earthRadiusPi)),
}
},
}
// MercatorScaleFactor returns the mercator scaling factor for a given degree latitude.
func MercatorScaleFactor(g orb.Point) float64 {
if g[1] < -90.0 || g[1] > 90.0 {
panic(fmt.Sprintf("orb: latitude out of range, given %f", g[1]))
}
return 1.0 / math.Cos(g[1]/180.0*math.Pi)
}