-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmain.go
109 lines (85 loc) · 2.33 KB
/
main.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
package main
import (
"flag"
"os"
svg "github.com/ajstarks/svgo"
)
func main() {
var showText bool
flag.BoolVar(&showText, "text", true, "render 'Fabio' in the logo")
flag.Parse()
var (
// box dimensions
bW = 80 // box width
bH = bW / 2 // box height
bRad = 10 // box corner radius
bPad = 16 // box padding
// other dimensions
botY = bH + 4*bPad // top of bottom row
centerX = bW + bPad + bW/2 // canvas center
// canvas
width = 749 // try and error for logo with text
height = 145
// colors
darkBlue = "#4294d3"
lightBlue = "#21bdf0"
// styles
darkBoxStyle = "fill:" + darkBlue
lightBoxStyle = "fill:" + lightBlue
lineStyle = "stroke-width:6;stroke-linecap:round;stroke:" + lightBlue
textStyle = "text-anchor:start;font-size:160px;font-family:Sportscenter;fill:" + darkBlue
textTransform = "matrix(1 0 0 1 291 140)"
)
if !showText {
width = 3*bW + 2*bPad
}
canvas := svg.New(os.Stdout)
canvas.Start(width, height)
canvas.Title("Fabio")
// use this to determine the width
// canvas.Rect(0, 0, width, height, "fill:red")
if showText {
// fabio
tX := 3*bW + 4*bPad
tY := botY + bH
// todo(fs): add transform="<textTransform>" for reduced char spacing
canvas.Text(tX, tY, "Fabio", textStyle)
}
// boxes
// box draws a box
box := func(x, y int, style string) {
canvas.Roundrect(x, y, bW, bH, bRad, bRad, style)
}
// top row box
box(bW+bPad, 0, darkBoxStyle)
// bottom row
box(0, botY, darkBoxStyle)
box(bW+bPad, botY, darkBoxStyle)
box(2*bW+2*bPad, botY, lightBoxStyle)
// lines
// center vertical row
cW, cH := 0, 6*bPad/2
cX1, cY1 := centerX, bH+bPad/2
cX2, cY2 := cX1+cW, cY1+cH
canvas.Line(cX1, cY1, cX2, cY2, lineStyle)
// left vertical row
lvW, lvH := 0, 2*bPad/2
lvX1, lvY1 := bW/2, bH+5*bPad/2
lvX2, lvY2 := lvX1+lvW, lvY1+lvH
canvas.Line(lvX1, lvY1, lvX2, lvY2, lineStyle)
// right vertical row
rvW, rvH := 0, lvH
rvX1, rvY1 := 2*bW+2*bPad+bW/2, lvY1
rvX2, rvY2 := rvX1+rvW, rvY1+rvH
canvas.Line(rvX1, rvY1, rvX2, rvY2, lineStyle)
// top cross row
tcW, tcH := bW+2*bPad, 0
tcX1, tcY1 := bW, bH+3*bPad/2
tcX2, tcY2 := tcX1+tcW, tcY1+tcH
canvas.Line(tcX1, tcY1, tcX2, tcY2, lineStyle)
// diag left
canvas.Line(tcX1, tcY1, lvX1, lvY1, lineStyle)
// diag right
canvas.Line(tcX2, tcY2, rvX1, rvY1, lineStyle)
canvas.End()
}