2017-02-13 03:27:02 -05:00
|
|
|
package main
|
|
|
|
|
2019-09-10 00:02:48 -04:00
|
|
|
//go:generate go run main.go
|
|
|
|
|
2017-02-13 03:27:02 -05:00
|
|
|
import (
|
2019-09-10 00:02:48 -04:00
|
|
|
"os"
|
2017-02-13 03:27:02 -05:00
|
|
|
|
2024-10-27 22:52:38 -04:00
|
|
|
"git.smarteching.com/zeni/go-chart/v2"
|
2017-02-13 03:27:02 -05:00
|
|
|
)
|
|
|
|
|
2019-09-10 00:02:48 -04:00
|
|
|
func main() {
|
2017-02-13 03:27:02 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
In this example we add a `Renderable` or a custom component to the `Elements` array.
|
|
|
|
In this specific case it is a pre-built renderable (`CreateLegend`) that draws a legend for the chart's series.
|
|
|
|
If you like, you can use `CreateLegend` as a template for writing your own renderable, or even your own legend.
|
|
|
|
*/
|
|
|
|
|
|
|
|
graph := chart.Chart{
|
|
|
|
Background: chart.Style{
|
|
|
|
Padding: chart.Box{
|
|
|
|
Top: 20,
|
|
|
|
Left: 260,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Series: []chart.Series{
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "A test series",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "Another test series",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "Yet Another test series",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "Even More series",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "Foo Bar",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "Bar Baz",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
2017-02-13 03:27:33 -05:00
|
|
|
Name: "Moo Bar",
|
2017-02-13 03:27:02 -05:00
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
2017-02-13 03:27:33 -05:00
|
|
|
Name: "Zoo Bar Baz",
|
2017-02-13 03:27:02 -05:00
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "Fast and the Furious",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{5.0, 4.0, 3.0, 2.0, 1.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "2 Fast 2 Furious",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{5.0, 4.0, 3.0, 2.0, 1.0},
|
|
|
|
},
|
|
|
|
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Name: "They only get more fast and more furious",
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{5.0, 4.0, 3.0, 2.0, 1.0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
//note we have to do this as a separate step because we need a reference to graph
|
|
|
|
graph.Elements = []chart.Renderable{
|
|
|
|
chart.LegendLeft(&graph),
|
|
|
|
}
|
|
|
|
|
2019-09-10 00:02:48 -04:00
|
|
|
f, _ := os.Create("output.png")
|
|
|
|
defer f.Close()
|
|
|
|
graph.Render(chart.PNG, f)
|
2017-02-13 03:27:02 -05:00
|
|
|
}
|