master
Bel LaPointe 2025-10-15 00:12:19 -06:00
parent a9004c38af
commit 001fef8bbc
4 changed files with 16 additions and 9 deletions

View File

@ -5,12 +5,12 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width" /> <meta name="viewport" content="width=device-width" />
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/water.css@2/out/water.css"> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/water.css@2/out/water.css">
<script> <script>
window.addEventListener("load", function(evt) { window.addEventListener("load", function(evt) {
var output = document.getElementById("output"); var output = document.getElementById("output");
var input = document.getElementById("input"); var input = document.getElementById("input");
var ws; var ws;
var print = function(message) { var print = function(message) {
var before = output.innerHTML.split("<br>"); var before = output.innerHTML.split("<br>");
before.unshift(`<span>${new Date().toLocaleTimeString()} | ${message}</span>`); before.unshift(`<span>${new Date().toLocaleTimeString()} | ${message}</span>`);
@ -56,8 +56,8 @@
ele.appendChild(document.createElement("br")); ele.appendChild(document.createElement("br"));
} }
} }
ws = new WebSocket("ws://"+window.location.host+"/ws"); ws = new WebSocket("ws://"+window.location.host+"/ws"+window.location.search);
ws.onopen = function(evt) { ws.onopen = function(evt) {
print("READY"); print("READY");
} }
@ -88,7 +88,7 @@
ws.onerror = function(evt) { ws.onerror = function(evt) {
print("ERROR: " + evt.data); print("ERROR: " + evt.data);
} }
document.getElementById("send").onclick = function(evt) { document.getElementById("send").onclick = function(evt) {
if (!ws || !input.value) { if (!ws || !input.value) {
return false; return false;
@ -99,7 +99,7 @@
for (var i = 0; i < voiceEles.length; i++) for (var i = 0; i < voiceEles.length; i++)
if (voiceEles[i].checked) if (voiceEles[i].checked)
voiceIdx = voiceEles[i].value; voiceIdx = voiceEles[i].value;
const data = JSON.stringify({ const data = JSON.stringify({
"Text": input.value, "Text": input.value,
"Pitch": Number.parseInt(document.getElementById("pitch").value, 10), "Pitch": Number.parseInt(document.getElementById("pitch").value, 10),
@ -124,8 +124,8 @@
#output > span:nth-child(1) { #output > span:nth-child(1) {
opacity: 1; opacity: 1;
} }
#output > span:nth-child(2) #output > span:nth-child(2)
, #output > span:nth-child(3) , #output > span:nth-child(3)
{ {
opacity: 0.66; opacity: 0.66;
} }

View File

@ -5,4 +5,5 @@ type message struct {
Pitch int Pitch int
Rate float64 Rate float64
VoiceIdx int VoiceIdx int
room string
} }

View File

@ -31,9 +31,12 @@ func (s *Server) WS(w http.ResponseWriter, r *http.Request) error {
} }
defer sess.Close() defer sess.Close()
log.Println("someone has joined", sess.room)
defer log.Println("someone has left", sess.room)
sess.cb = func(m message) error { sess.cb = func(m message) error {
for i := range s.sessions { for i := range s.sessions {
if s.sessions[i].id != sess.id { if s.sessions[i].id != sess.id && s.sessions[i].room == sess.room {
select { select {
case s.sessions[i].scatterc <- m: case s.sessions[i].scatterc <- m:
case <-s.sessions[i].ctx.Done(): case <-s.sessions[i].ctx.Done():

View File

@ -20,6 +20,7 @@ type session struct {
cb func(message) error cb func(message) error
id string id string
scatterc chan (message) scatterc chan (message)
room string
} }
var upgrader = websocket.Upgrader{} var upgrader = websocket.Upgrader{}
@ -34,6 +35,7 @@ func newSession(w http.ResponseWriter, r *http.Request, cb func(message) error)
cb: cb, cb: cb,
id: uuid.New().String(), id: uuid.New().String(),
scatterc: make(chan message, 20), scatterc: make(chan message, 20),
room: r.URL.Query().Get("room"),
}, err }, err
} }
@ -70,6 +72,7 @@ func (s *session) gather() {
if err := json.Unmarshal(msg, &m); err != nil { if err := json.Unmarshal(msg, &m); err != nil {
return err return err
} }
m.room = s.room
return s.cb(m) return s.cb(m)
}) })