r_place/go/server.go

74 lines
1.5 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"
"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
2022-05-28 13:28:14 +00:00
func write(ticker time.Ticker, c websocket.Conn) {
for range ticker.C {
diff := tmpImage.GetDiff(&img)
for i := 0; i < int(diff.Width*diff.Height); i++ {
pix := diff.Pixels[i]
if pix.UserID != 0 {
x := i / int(diff.Width)
y := i % int(diff.Height)
msg := Message{X: uint16(x), Y: uint16(y), Timestamp: pix.Timestamp, UserID: pix.UserID, Color: pix.Color}
marshalMsg, err := json.Marshal(msg)
if err != nil {
log.Println("error while writing image", err)
break
}
err = c.WriteMessage(1, marshalMsg)
}
}
copy(img.pixels, tmpImage.pixels)
}
}
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)
2022-05-28 13:28:14 +00:00
go write(*ticker, *c)
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)
2022-05-28 13:28:14 +00:00
log.Println("starting server on", *addr)
http.HandleFunc("/", serve)
2022-05-28 13:28:14 +00:00
2022-05-26 12:14:36 +00:00
log.Fatal(http.ListenAndServe(*addr, nil))
}