2017-01-10 22:50:17 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2018-12-06 16:46:27 +01:00
|
|
|
"git.gutmet.org/go-chart.git"
|
2017-01-10 22:50:17 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func drawChart(res http.ResponseWriter, req *http.Request) {
|
|
|
|
|
|
|
|
/*
|
|
|
|
The below will draw the same chart as the `basic` example, except with both the x and y axes turned on.
|
2017-01-10 22:54:57 +01:00
|
|
|
In this case, both the x and y axis ticks are generated automatically, the x and y ranges are established automatically,
|
|
|
|
the canvas "box" is adjusted to fit the space the axes occupy so as not to clip.
|
|
|
|
Additionally, it shows how you can use the "Descending" property of continuous ranges to change the ordering of
|
|
|
|
how values (including ticks) are drawn.
|
2017-01-10 22:50:17 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
graph := chart.Chart{
|
|
|
|
Height: 500,
|
|
|
|
Width: 500,
|
|
|
|
XAxis: chart.XAxis{
|
2018-10-12 02:20:44 +02:00
|
|
|
Style: chart.StyleShow(),
|
2017-01-10 22:50:17 +01:00
|
|
|
/*Range: &chart.ContinuousRange{
|
|
|
|
Descending: true,
|
|
|
|
},*/
|
|
|
|
},
|
|
|
|
YAxis: chart.YAxis{
|
2018-10-12 02:20:44 +02:00
|
|
|
Style: chart.StyleShow(),
|
2017-01-10 22:50:17 +01:00
|
|
|
Range: &chart.ContinuousRange{
|
|
|
|
Descending: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Series: []chart.Series{
|
|
|
|
chart.ContinuousSeries{
|
|
|
|
Style: chart.Style{
|
|
|
|
Show: true,
|
|
|
|
StrokeColor: chart.GetDefaultColor(0).WithAlpha(64),
|
|
|
|
FillColor: chart.GetDefaultColor(0).WithAlpha(64),
|
|
|
|
},
|
|
|
|
XValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
YValues: []float64{1.0, 2.0, 3.0, 4.0, 5.0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
res.Header().Set("Content-Type", "image/png")
|
|
|
|
graph.Render(chart.PNG, res)
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
http.HandleFunc("/", drawChart)
|
|
|
|
http.ListenAndServe(":8080", nil)
|
|
|
|
}
|