r_place/go/server.go

65 lines
1.2 KiB
Go
Raw Normal View History

2022-05-26 12:14:36 +00:00
package main
import (
2022-05-27 16:00:19 +00:00
"encoding/json"
2022-05-26 12:14:36 +00:00
"flag"
"fmt"
2022-05-26 12:14:36 +00:00
"log"
"net/http"
2022-05-27 16:00:19 +00:00
"time"
2022-05-26 12:14:36 +00:00
"github.com/gorilla/websocket"
)
var upgrader = websocket.Upgrader{
ReadBufferSize: 2048,
WriteBufferSize: 2048,
}
var img = GetImage(10, 10)
var tmpImage = GetImage(img.width, img.height)
2022-05-26 12:14:36 +00:00
func serve(w http.ResponseWriter, r *http.Request) {
2022-05-26 12:14:36 +00:00
c, err := upgrader.Upgrade(w, r, nil)
if err != nil {
log.Print("error while upgrading", err)
return
}
defer c.Close()
2022-05-27 16:00:19 +00:00
ticker := time.NewTicker(1 * time.Second)
go func() {
for range ticker.C {
diff := tmpImage.GetDiff(&img)
msg, err := json.Marshal(diff)
fmt.Println(diff)
// TODO only write chenaged pixels to channel instead of entire image
2022-05-27 16:00:19 +00:00
err = c.WriteMessage(1, msg)
if err != nil {
2022-05-27 16:13:36 +00:00
log.Println("error while writing image", err)
break
2022-05-27 16:00:19 +00:00
}
copy(img.pixels, tmpImage.pixels)
2022-05-27 16:00:19 +00:00
}
}()
for {
_, msg, err := c.ReadMessage()
if err != nil {
log.Println("read:", err)
break
}
message := Message{}
message.JsonToStruct(msg)
img.SetPixel(message)
2022-05-27 16:00:19 +00:00
}
2022-05-27 16:00:19 +00:00
}
2022-05-26 12:14:36 +00:00
func main() {
2022-05-27 14:12:27 +00:00
var addr = flag.String("addr", "localhost:8080", "http service address")
2022-05-26 12:14:36 +00:00
flag.Parse()
log.SetFlags(0)
http.HandleFunc("/", serve)
2022-05-26 12:14:36 +00:00
log.Fatal(http.ListenAndServe(*addr, nil))
}