SVG generator, start with PDF generator
This commit is contained in:
parent
9255872f57
commit
a1a65165ca
6 changed files with 107 additions and 21 deletions
|
@ -2,12 +2,49 @@ package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"f00860/kartograph-map-editor/pkg/generator"
|
"f00860/kartograph-map-editor/pkg/generator"
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
format string
|
||||||
|
|
||||||
|
size int
|
||||||
|
|
||||||
|
wastelands int
|
||||||
|
mountains int
|
||||||
|
ruins int
|
||||||
|
|
||||||
|
filename string
|
||||||
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
world := generator.New(11, 7, 5, 6)
|
world := generator.New(size, wastelands, mountains, ruins)
|
||||||
//world := generator.New(13, 50, 5, 6)
|
|
||||||
fmt.Print(world.Plot())
|
switch format {
|
||||||
world.SVG("/tmp/test.svg")
|
case "svg":
|
||||||
|
fmt.Print(world.SVG())
|
||||||
|
case "ascii":
|
||||||
|
fmt.Print(world.Plot())
|
||||||
|
case "json":
|
||||||
|
fmt.Print(world.JSON())
|
||||||
|
case "pdf":
|
||||||
|
world.PDF(filename)
|
||||||
|
case "web":
|
||||||
|
panic("Not implemented yet")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
flag.StringVar(&format, "format", "svg", "Output format (ascii, json, svg, pdf, web)")
|
||||||
|
|
||||||
|
flag.IntVar(&size, "size", 11, "The size of the map")
|
||||||
|
|
||||||
|
flag.IntVar(&wastelands, "wastelands", 7, "Number of wastelands")
|
||||||
|
flag.IntVar(&mountains, "mountains", 5, "Number of mountains")
|
||||||
|
flag.IntVar(&ruins, "ruins", 6, "Number of ruins")
|
||||||
|
|
||||||
|
flag.StringVar(&filename, "filename", "map.pdf", "The PDF filename")
|
||||||
|
|
||||||
|
flag.Parse()
|
||||||
}
|
}
|
||||||
|
|
5
go.mod
5
go.mod
|
@ -2,4 +2,7 @@ module f00860/kartograph-map-editor
|
||||||
|
|
||||||
go 1.15
|
go 1.15
|
||||||
|
|
||||||
require github.com/ajstarks/svgo v0.0.0-20200725142600-7a3c8b57fecb
|
require (
|
||||||
|
github.com/ajstarks/svgo v0.0.0-20200725142600-7a3c8b57fecb
|
||||||
|
github.com/jung-kurt/gofpdf v1.16.2
|
||||||
|
)
|
||||||
|
|
12
go.sum
12
go.sum
|
@ -1,2 +1,14 @@
|
||||||
github.com/ajstarks/svgo v0.0.0-20200725142600-7a3c8b57fecb h1:EVl3FJLQCzSbgBezKo/1A4ADnJ4mtJZ0RvnNzDJ44nY=
|
github.com/ajstarks/svgo v0.0.0-20200725142600-7a3c8b57fecb h1:EVl3FJLQCzSbgBezKo/1A4ADnJ4mtJZ0RvnNzDJ44nY=
|
||||||
github.com/ajstarks/svgo v0.0.0-20200725142600-7a3c8b57fecb/go.mod h1:K08gAheRH3/J6wwsYMMT4xOr94bZjxIelGM0+d/wbFw=
|
github.com/ajstarks/svgo v0.0.0-20200725142600-7a3c8b57fecb/go.mod h1:K08gAheRH3/J6wwsYMMT4xOr94bZjxIelGM0+d/wbFw=
|
||||||
|
github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8=
|
||||||
|
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
|
github.com/jung-kurt/gofpdf v1.0.0/go.mod h1:7Id9E/uU8ce6rXgefFLlgrJj/GYY22cpxn+r32jIOes=
|
||||||
|
github.com/jung-kurt/gofpdf v1.16.2 h1:jgbatWHfRlPYiK85qgevsZTHviWXKwB1TTiKdz5PtRc=
|
||||||
|
github.com/jung-kurt/gofpdf v1.16.2/go.mod h1:1hl7y57EsiPAkLbOwzpzqgx1A30nQCk/YmFV8S2vmK0=
|
||||||
|
github.com/phpdave11/gofpdi v1.0.7/go.mod h1:vBmVV0Do6hSBHC8uKUQ71JGW+ZGQq74llk/7bXwjDoI=
|
||||||
|
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
|
github.com/ruudk/golang-pdf417 v0.0.0-20181029194003-1af4ab5afa58/go.mod h1:6lfFZQK844Gfx8o5WFuvpxWRwnSoipWe/p622j1v06w=
|
||||||
|
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
||||||
|
golang.org/x/image v0.0.0-20190910094157-69e4b8554b2a/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
|
||||||
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
|
|
12
pkg/generator/pdf.go
Normal file
12
pkg/generator/pdf.go
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
package generator
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/jung-kurt/gofpdf"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (w World) PDF(filename string) {
|
||||||
|
pdf := gofpdf.New("P", "mm", "A4", "")
|
||||||
|
pdf.AddPage()
|
||||||
|
|
||||||
|
pdf.OutputFileAndClose(filename)
|
||||||
|
}
|
|
@ -1,13 +1,13 @@
|
||||||
package generator
|
package generator
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"math"
|
"math"
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/ajstarks/svgo"
|
"github.com/ajstarks/svgo"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (w World) SVG(filename string) {
|
func (w World) SVG() string {
|
||||||
// DIN-A5
|
// DIN-A5
|
||||||
width := 148 * 3
|
width := 148 * 3
|
||||||
height := 210 * 3
|
height := 210 * 3
|
||||||
|
@ -18,13 +18,8 @@ func (w World) SVG(filename string) {
|
||||||
gridsize := int(math.Floor(float64(width-2*hPadding) / float64(w.Size)))
|
gridsize := int(math.Floor(float64(width-2*hPadding) / float64(w.Size)))
|
||||||
boardsize := gridsize * w.Size
|
boardsize := gridsize * w.Size
|
||||||
|
|
||||||
file, err := os.OpenFile(filename, os.O_WRONLY|os.O_CREATE, 0600)
|
buf := bytes.NewBufferString("")
|
||||||
if err != nil {
|
canvas := svg.New(buf)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
defer file.Close()
|
|
||||||
|
|
||||||
canvas := svg.New(file)
|
|
||||||
|
|
||||||
canvas.Start(width, height)
|
canvas.Start(width, height)
|
||||||
|
|
||||||
|
@ -97,4 +92,6 @@ func (w World) SVG(filename string) {
|
||||||
canvas.Text(hPadding+364, vPadding+boardsize+74, "A", "stroke:black;fill:black;font-size:14px")
|
canvas.Text(hPadding+364, vPadding+boardsize+74, "A", "stroke:black;fill:black;font-size:14px")
|
||||||
|
|
||||||
canvas.End()
|
canvas.End()
|
||||||
|
|
||||||
|
return buf.String()
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package generator
|
package generator
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
|
@ -25,7 +26,23 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type Tile struct {
|
type Tile struct {
|
||||||
Territory TerritoryType
|
Territory TerritoryType `json:"territory"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t Tile) MarshalJSON() ([]byte, error) {
|
||||||
|
var s string
|
||||||
|
switch t.Territory {
|
||||||
|
case EmptyTerritory:
|
||||||
|
s = "empty"
|
||||||
|
case WastelandTerritory:
|
||||||
|
s = "wasteland"
|
||||||
|
case MountainTerritory:
|
||||||
|
s = "mountain"
|
||||||
|
case RuinsTerritory:
|
||||||
|
s = "ruin"
|
||||||
|
}
|
||||||
|
|
||||||
|
return []byte("\"" + s + "\""), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t Tile) Plot() string {
|
func (t Tile) Plot() string {
|
||||||
|
@ -44,12 +61,12 @@ func (t Tile) Plot() string {
|
||||||
}
|
}
|
||||||
|
|
||||||
type World struct {
|
type World struct {
|
||||||
Size int
|
Size int `json:"size"`
|
||||||
Wastelands int
|
Wastelands int `json:"wastelands"`
|
||||||
Ruins int
|
Ruins int `json:"ruins"`
|
||||||
Mountains int
|
Mountains int `json:"mountains"`
|
||||||
|
|
||||||
World []Tile
|
World []Tile `json:"tiles"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w World) Plot() string {
|
func (w World) Plot() string {
|
||||||
|
@ -65,6 +82,11 @@ func (w World) Plot() string {
|
||||||
return board
|
return board
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (w World) JSON() string {
|
||||||
|
output, _ := json.MarshalIndent(w, "", " ")
|
||||||
|
return string(output)
|
||||||
|
}
|
||||||
|
|
||||||
func (w World) ExportToPDF(filename string) error {
|
func (w World) ExportToPDF(filename string) error {
|
||||||
// TODO: Draw the PDF
|
// TODO: Draw the PDF
|
||||||
return nil
|
return nil
|
||||||
|
@ -74,7 +96,10 @@ func New(size int, numWastelands int, numMountains int, numRuins int) World {
|
||||||
rand.Seed(time.Now().UnixNano())
|
rand.Seed(time.Now().UnixNano())
|
||||||
|
|
||||||
w := World{
|
w := World{
|
||||||
Size: size,
|
Size: size,
|
||||||
|
Wastelands: numWastelands,
|
||||||
|
Mountains: numMountains,
|
||||||
|
Ruins: numRuins,
|
||||||
}
|
}
|
||||||
|
|
||||||
// All empty for start
|
// All empty for start
|
||||||
|
|
Loading…
Reference in a new issue