当页面不可见时暂时不重连,防止重连后又心跳超时

This commit is contained in:
John Smith 2024-01-26 02:24:32 +08:00
parent ee3b11e001
commit 9663a77338
3 changed files with 48 additions and 11 deletions

View File

@ -24,24 +24,32 @@ export default class ChatClientDirectOpenLive extends ChatClientOfficialBase {
} }
stop() { stop() {
super.stop()
if (this.gameHeartbeatTimerId) {
window.clearTimeout(this.gameHeartbeatTimerId)
this.gameHeartbeatTimerId = null
}
this.endGame() this.endGame()
super.stop()
} }
async initRoom() { async initRoom() {
if (!await this.startGame()) { return this.startGame()
return false }
async wsConnect() {
await super.wsConnect()
if (this.isDestroying) {
return
} }
if (this.gameId && this.gameHeartbeatTimerId === null) { if (this.gameId && this.gameHeartbeatTimerId === null) {
this.gameHeartbeatTimerId = window.setTimeout(this.onSendGameHeartbeat.bind(this), GAME_HEARTBEAT_INTERVAL) this.gameHeartbeatTimerId = window.setTimeout(this.onSendGameHeartbeat.bind(this), GAME_HEARTBEAT_INTERVAL)
} }
return true }
onWsClose() {
if (this.gameHeartbeatTimerId) {
window.clearTimeout(this.gameHeartbeatTimerId)
this.gameHeartbeatTimerId = null
}
super.onWsClose()
} }
async startGame() { async startGame() {
@ -139,10 +147,11 @@ export default class ChatClientDirectOpenLive extends ChatClientOfficialBase {
} }
async onBeforeWsConnect() { async onBeforeWsConnect() {
// 重连次数太多则重新init_room保险 // 重连次数太多则重新initRoom保险
let reinitPeriod = Math.max(3, (this.hostServerUrlList || []).length) let reinitPeriod = Math.max(3, (this.hostServerUrlList || []).length)
if (this.retryCount > 0 && this.retryCount % reinitPeriod === 0) { if (this.retryCount > 0 && this.retryCount % reinitPeriod === 0) {
this.needInitRoom = true this.needInitRoom = true
await this.endGame()
} }
return super.onBeforeWsConnect() return super.onBeforeWsConnect()
} }
@ -155,6 +164,16 @@ export default class ChatClientDirectOpenLive extends ChatClientOfficialBase {
this.websocket.send(this.makePacket(this.authBody, base.OP_AUTH)) this.websocket.send(this.makePacket(this.authBody, base.OP_AUTH))
} }
delayReconnect() {
if (document.visibilityState !== 'visible') {
// 不知道什么时候才能重连先endGame吧
this.needInitRoom = true
this.endGame()
}
super.delayReconnect()
}
async dmCallback(command) { async dmCallback(command) {
let data = command.data let data = command.data

View File

@ -200,7 +200,24 @@ export default class ChatClientOfficialBase {
return return
} }
window.setTimeout(this.wsConnect.bind(this), this.getReconnectInterval()) this.delayReconnect()
}
delayReconnect() {
if (document.visibilityState === 'visible') {
window.setTimeout(this.wsConnect.bind(this), this.getReconnectInterval())
return
}
// 页面不可见就先不重连了,即使重连也会心跳超时
let listener = () => {
if (document.visibilityState !== 'visible') {
return
}
document.removeEventListener('visibilitychange', listener)
this.wsConnect()
}
document.addEventListener('visibilitychange', listener)
} }
getReconnectInterval() { getReconnectInterval() {

View File

@ -107,6 +107,7 @@ export default class ChatClientRelay {
return return
} }
// 这边不用判断页面是否可见,因为发心跳包不是由定时器触发的,即使是不活动页面也不会心跳超时
window.setTimeout(this.wsConnect.bind(this), this.getReconnectInterval()) window.setTimeout(this.wsConnect.bind(this), this.getReconnectInterval())
} }