2020-08-17 00:53:39 +02:00
|
|
|
package gamemap
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
2020-08-17 04:11:52 +02:00
|
|
|
// WorldMap is the data structure used game world
|
2020-08-17 00:53:39 +02:00
|
|
|
type WorldMap struct {
|
2020-08-21 06:38:22 +02:00
|
|
|
data [256][256]int
|
2020-08-17 00:53:39 +02:00
|
|
|
max_x int
|
|
|
|
max_y int
|
|
|
|
}
|
|
|
|
|
2020-08-17 04:11:52 +02:00
|
|
|
// GetTile method is used to grab a tile value with error checking
|
2020-08-17 00:53:39 +02:00
|
|
|
func (m WorldMap) GetTile(x int, y int) (int, error) {
|
|
|
|
if x > m.max_x || y > m.max_y {
|
|
|
|
return -1, fmt.Errorf("Map out of bounds error: %d, %d", x, y)
|
|
|
|
}
|
|
|
|
return m.data[x][y], nil
|
|
|
|
}
|
|
|
|
|
2020-08-17 04:11:52 +02:00
|
|
|
// GetJSONRegion method returns a JSON object containing the tile values of everything
|
|
|
|
// within a given range
|
|
|
|
func (m WorldMap) GetJSONRegion(startX, endX, startY, endY int) ([]byte, error) {
|
2020-08-17 01:42:35 +02:00
|
|
|
regionMap := map[int]map[int]int{}
|
2020-08-17 04:11:52 +02:00
|
|
|
for x := startX; x < endX; x++ {
|
2020-08-17 01:42:35 +02:00
|
|
|
regionMap[x] = map[int]int{}
|
2020-08-17 04:11:52 +02:00
|
|
|
for y := startY; y < endY; y++ {
|
2020-08-21 06:25:31 +02:00
|
|
|
|
|
|
|
// GetTile and ignore out of bounds errors
|
|
|
|
result, _ := m.GetTile(x, y)
|
|
|
|
regionMap[x][y] = result
|
2020-08-17 00:53:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
jsonString, err := json.Marshal(regionMap)
|
|
|
|
return jsonString, err
|
|
|
|
}
|
|
|
|
|
2020-08-17 04:11:52 +02:00
|
|
|
// GetJSONRegionAround returns a JSON object of tile data from a center point
|
2020-08-21 06:25:31 +02:00
|
|
|
func (m WorldMap) GetJSONRegionAround(centerX float64, centerY float64, regionRadius int) ([]byte, error) {
|
|
|
|
var xCenter int = int(centerX)
|
|
|
|
var yCenter int = int(centerY)
|
|
|
|
jsonString, err := m.GetJSONRegion(xCenter-regionRadius, xCenter+regionRadius, yCenter-regionRadius, yCenter+regionRadius)
|
2020-08-17 04:11:52 +02:00
|
|
|
return jsonString, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// IntializeMap is a method that helps easily
|
|
|
|
// generate WorldMap objects
|
2020-08-17 00:53:39 +02:00
|
|
|
func IntializeMap() *WorldMap {
|
|
|
|
worldMap := new(WorldMap)
|
2020-08-21 06:38:22 +02:00
|
|
|
worldMap.max_x = 256
|
|
|
|
worldMap.max_y = 256
|
|
|
|
worldMap.data = [256][256]int{}
|
2020-08-17 00:53:39 +02:00
|
|
|
for x := 0; x < worldMap.max_x; x++ {
|
|
|
|
for y := 0; y < worldMap.max_y; y++ {
|
|
|
|
worldMap.data[x][y] = 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add dot at top left for testing
|
|
|
|
worldMap.data[0][0] = 1
|
|
|
|
|
|
|
|
return worldMap
|
|
|
|
}
|