forked from go-spatial/tegola
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtile.go
57 lines (45 loc) · 1.6 KB
/
tile.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
46
47
48
49
50
51
52
53
54
55
56
57
package tegola
import (
"math"
)
// slippy map tilenames
// http://wiki.openstreetmap.org/wiki/Slippy_map_tilenames
type Tile struct {
Z int
X int
Y int
Lat float64
Long float64
}
func (t *Tile) Deg2Num() (x, y int) {
x = int(math.Floor((t.Long + 180.0) / 360.0 * (math.Exp2(float64(t.Z)))))
y = int(math.Floor((1.0 - math.Log(math.Tan(t.Lat*math.Pi/180.0)+1.0/math.Cos(t.Lat*math.Pi/180.0))/math.Pi) / 2.0 * (math.Exp2(float64(t.Z)))))
return
}
func (t *Tile) Num2Deg() (lat, lng float64) {
n := math.Pi - 2.0*math.Pi*float64(t.Y)/math.Exp2(float64(t.Z))
lat = 180.0 / math.Pi * math.Atan(0.5*(math.Exp(n)-math.Exp(-n)))
lng = float64(t.X)/math.Exp2(float64(t.Z))*360.0 - 180.0
return lat, lng
}
// returns the bound box coordinates for upper left (ulx, uly) and lower right (lrx, lry)
// in web mercator projection
// ported from: https://raw.githubusercontent.com/mapbox/postgis-vt-util/master/postgis-vt-util.sql
func (t *Tile) BBox() (ulx, uly, llx, lly float64) {
max := 20037508.34
// resolution
res := (max * 2) / math.Exp2(float64(t.Z))
// upper left point
ulx = -max + (float64(t.X) * res)
uly = max - (float64(t.Y) * res)
// lower left point
llx = -max + (float64(t.X) * res) + res
lly = max - (float64(t.Y) * res) - res
return
}
// takes a web mercator zoom level and returns the pixel resolution for that
// scale, assuming 256x256 pixel tiles. Non-integer zoom levels are accepted.
// ported from: https://raw.githubusercontent.com/mapbox/postgis-vt-util/master/postgis-vt-util.sql
func (t *Tile) ZRes() float64 {
return 40075016.6855785 / (256 * math.Exp2(float64(t.Z)))
}