?room s
parent
a9004c38af
commit
001fef8bbc
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,4 +5,5 @@ type message struct {
|
||||||
Pitch int
|
Pitch int
|
||||||
Rate float64
|
Rate float64
|
||||||
VoiceIdx int
|
VoiceIdx int
|
||||||
|
room string
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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():
|
||||||
|
|
|
||||||
|
|
@ -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)
|
||||||
})
|
})
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue