go-chart/_examples/bar_chart/main.go

58 lines
1.1 KiB
Go
Raw Normal View History

2016-08-05 19:55:55 -04:00
package main
import (
"fmt"
"log"
"net/http"
"os"
"github.com/wcharczuk/go-chart"
)
func drawChart(res http.ResponseWriter, req *http.Request) {
sbc := chart.BarChart{
Title: "Test Bar Chart",
TitleStyle: chart.StyleShow(),
Background: chart.Style{
Padding: chart.Box{
Top: 40,
},
},
2016-08-05 19:55:55 -04:00
Height: 512,
BarWidth: 60,
XAxis: chart.StyleShow(),
2016-08-05 19:55:55 -04:00
YAxis: chart.YAxis{
Style: chart.StyleShow(),
2016-08-05 19:55:55 -04:00
},
Bars: []chart.Value{
2016-08-05 23:08:24 -04:00
{Value: 5.25, Label: "Blue"},
{Value: 4.88, Label: "Green"},
{Value: 4.74, Label: "Gray"},
{Value: 3.22, Label: "Orange"},
2016-08-05 19:55:55 -04:00
{Value: 3, Label: "Test"},
2016-08-05 23:08:24 -04:00
{Value: 2.27, Label: "??"},
2016-08-05 19:55:55 -04:00
{Value: 1, Label: "!!"},
},
}
res.Header().Set("Content-Type", "image/png")
err := sbc.Render(chart.PNG, res)
if err != nil {
fmt.Printf("Error rendering chart: %v\n", err)
}
}
func port() string {
if len(os.Getenv("PORT")) > 0 {
return os.Getenv("PORT")
}
return "8080"
}
func main() {
listenPort := fmt.Sprintf(":%s", port())
fmt.Printf("Listening on %s\n", listenPort)
http.HandleFunc("/", drawChart)
log.Fatal(http.ListenAndServe(listenPort, nil))
}