1
0
forked from MTSR/mapserver
mapserver/coords/convert.go

47 lines
1.2 KiB
Go
Raw Normal View History

2019-01-09 12:52:51 +03:00
package coords
2019-01-09 11:07:56 +03:00
2023-12-29 18:00:11 +03:00
import "mapserver/types"
// https://bitbucket.org/s_l_teichmann/mtsatellite/src/e1bf980a2b278c570b3f44f9452c9c087558acb3/common/coords.go?at=default&fileviewer=file-view-default
2019-01-09 11:07:56 +03:00
const (
numBitsPerComponent = 12
modulo = 1 << numBitsPerComponent
maxPositive = modulo / 2
minValue = -1 << (numBitsPerComponent - 1)
maxValue = 1<<(numBitsPerComponent-1) - 1
2019-02-14 10:34:16 +03:00
2019-02-14 11:05:39 +03:00
MinPlainCoord = -34351347711
2019-01-09 11:07:56 +03:00
)
2023-12-29 18:00:11 +03:00
func CoordToPlain(c *types.MapBlockCoords) int64 {
2019-01-09 12:52:51 +03:00
return int64(c.Z)<<(2*numBitsPerComponent) +
int64(c.Y)<<numBitsPerComponent +
int64(c.X)
2019-01-09 11:07:56 +03:00
}
2019-01-09 12:52:51 +03:00
func unsignedToSigned(i int16) int {
2019-01-09 11:07:56 +03:00
if i < maxPositive {
2019-01-09 12:52:51 +03:00
return int(i)
2019-01-09 11:07:56 +03:00
}
2019-01-09 12:52:51 +03:00
return int(i - maxPositive*2)
2019-01-09 11:07:56 +03:00
}
// To match C++ code.
func pythonModulo(i int16) int16 {
const mask = modulo - 1
if i >= 0 {
return i & mask
}
return modulo - -i&mask
}
2023-12-29 18:00:11 +03:00
func PlainToCoord(i int64) *types.MapBlockCoords {
c := types.MapBlockCoords{}
2019-01-09 12:52:51 +03:00
c.X = unsignedToSigned(pythonModulo(int16(i)))
i = (i - int64(c.X)) >> numBitsPerComponent
c.Y = unsignedToSigned(pythonModulo(int16(i)))
i = (i - int64(c.Y)) >> numBitsPerComponent
c.Z = unsignedToSigned(pythonModulo(int16(i)))
2019-02-06 10:38:08 +03:00
return &c
2019-01-09 11:07:56 +03:00
}