Muting the speaker now results in muted clients as well
This commit is contained in:
parent
947bac0e66
commit
9afced5d98
2 changed files with 37 additions and 2 deletions
|
@ -22,6 +22,7 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
private readonly listenerRtcAudioAssignment;
|
private readonly listenerRtcAudioAssignment;
|
||||||
private readonly listenerRtcStateChanged;
|
private readonly listenerRtcStateChanged;
|
||||||
private listenerClientMoved;
|
private listenerClientMoved;
|
||||||
|
private listenerSpeakerStateChanged;
|
||||||
|
|
||||||
private connectionState: VoiceConnectionStatus;
|
private connectionState: VoiceConnectionStatus;
|
||||||
private localFailedReason: string;
|
private localFailedReason: string;
|
||||||
|
@ -30,6 +31,7 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
private currentAudioSourceNode: AudioNode;
|
private currentAudioSourceNode: AudioNode;
|
||||||
private currentAudioSource: RecorderProfile;
|
private currentAudioSource: RecorderProfile;
|
||||||
|
|
||||||
|
private speakerMuted: boolean;
|
||||||
private voiceClients: RtpVoiceClient[] = [];
|
private voiceClients: RtpVoiceClient[] = [];
|
||||||
|
|
||||||
private currentlyReplayingVoice: boolean = false;
|
private currentlyReplayingVoice: boolean = false;
|
||||||
|
@ -49,6 +51,12 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
this.rtcConnection.getEvents().on("notify_state_changed",
|
this.rtcConnection.getEvents().on("notify_state_changed",
|
||||||
this.listenerRtcStateChanged = event => this.handleRtcConnectionStateChanged(event));
|
this.listenerRtcStateChanged = event => this.handleRtcConnectionStateChanged(event));
|
||||||
|
|
||||||
|
this.listenerSpeakerStateChanged = connection.client.events().on("notify_state_updated", event => {
|
||||||
|
if(event.state === "speaker") {
|
||||||
|
this.updateSpeakerState();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
/* FIXME: Listener for audio! */
|
/* FIXME: Listener for audio! */
|
||||||
|
|
||||||
this.listenerClientMoved = this.rtcConnection.getConnection().command_handler_boss().register_explicit_handler("notifyclientmoved", event => {
|
this.listenerClientMoved = this.rtcConnection.getConnection().command_handler_boss().register_explicit_handler("notifyclientmoved", event => {
|
||||||
|
@ -61,6 +69,7 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.speakerMuted = connection.client.isSpeakerMuted() || connection.client.isSpeakerDisabled();
|
||||||
|
|
||||||
this.setConnectionState(VoiceConnectionStatus.Disconnected);
|
this.setConnectionState(VoiceConnectionStatus.Disconnected);
|
||||||
aplayer.on_ready(() => {
|
aplayer.on_ready(() => {
|
||||||
|
@ -77,6 +86,11 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
this.listenerClientMoved = undefined;
|
this.listenerClientMoved = undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(this.listenerSpeakerStateChanged) {
|
||||||
|
this.listenerSpeakerStateChanged();
|
||||||
|
this.listenerSpeakerStateChanged = undefined;
|
||||||
|
}
|
||||||
|
|
||||||
this.rtcConnection.getEvents().off("notify_audio_assignment_changed", this.listenerRtcAudioAssignment);
|
this.rtcConnection.getEvents().off("notify_audio_assignment_changed", this.listenerRtcAudioAssignment);
|
||||||
this.rtcConnection.getEvents().off("notify_state_changed", this.listenerRtcStateChanged);
|
this.rtcConnection.getEvents().off("notify_state_changed", this.listenerRtcStateChanged);
|
||||||
|
|
||||||
|
@ -195,7 +209,7 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
log.info(LogCategory.VOICE, tr("Local voice started"));
|
log.info(LogCategory.VOICE, tr("Local voice started"));
|
||||||
|
|
||||||
const ch = chandler.getClient();
|
const ch = chandler.getClient();
|
||||||
if(ch) ch.speaking = true;
|
if(ch) { ch.speaking = true; }
|
||||||
this.rtcConnection.setTrackSource("audio", this.localAudioDestination.stream.getAudioTracks()[0])
|
this.rtcConnection.setTrackSource("audio", this.localAudioDestination.stream.getAudioTracks()[0])
|
||||||
.catch(error => {
|
.catch(error => {
|
||||||
logError(LogCategory.AUDIO, tr("Failed to set current audio track: %o"), error);
|
logError(LogCategory.AUDIO, tr("Failed to set current audio track: %o"), error);
|
||||||
|
@ -370,4 +384,12 @@ export class RtpVoiceConnection extends AbstractVoiceConnection {
|
||||||
bytesSend: stats.voiceBytesSent
|
bytesSend: stats.voiceBytesSent
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private updateSpeakerState() {
|
||||||
|
const newState = this.connection.client.isSpeakerMuted() || this.connection.client.isSpeakerDisabled();
|
||||||
|
if(this.speakerMuted === newState) { return; }
|
||||||
|
|
||||||
|
this.speakerMuted = newState;
|
||||||
|
this.voiceClients.forEach(client => client.setGloballyMuted(this.speakerMuted));
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -9,6 +9,8 @@ export class RtpVoiceClient implements VoiceClient {
|
||||||
private readonly listenerTrackStateChanged;
|
private readonly listenerTrackStateChanged;
|
||||||
private readonly clientId: number;
|
private readonly clientId: number;
|
||||||
|
|
||||||
|
private globallyMuted: boolean;
|
||||||
|
|
||||||
private volume: number;
|
private volume: number;
|
||||||
private currentState: VoicePlayerState;
|
private currentState: VoicePlayerState;
|
||||||
private currentRtpTrack: RemoteRTPAudioTrack;
|
private currentRtpTrack: RemoteRTPAudioTrack;
|
||||||
|
@ -24,6 +26,13 @@ export class RtpVoiceClient implements VoiceClient {
|
||||||
this.events.destroy();
|
this.events.destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setGloballyMuted(muted: boolean) {
|
||||||
|
if(this.globallyMuted === muted) { return; }
|
||||||
|
|
||||||
|
this.globallyMuted = muted;
|
||||||
|
this.updateVolume();
|
||||||
|
}
|
||||||
|
|
||||||
getClientId(): number {
|
getClientId(): number {
|
||||||
return this.clientId;
|
return this.clientId;
|
||||||
}
|
}
|
||||||
|
@ -52,7 +61,7 @@ export class RtpVoiceClient implements VoiceClient {
|
||||||
|
|
||||||
setVolume(volume: number) {
|
setVolume(volume: number) {
|
||||||
this.volume = volume;
|
this.volume = volume;
|
||||||
this.currentRtpTrack?.setGain(volume);
|
this.updateVolume();
|
||||||
}
|
}
|
||||||
|
|
||||||
getLatencySettings(): Readonly<VoicePlayerLatencySettings> {
|
getLatencySettings(): Readonly<VoicePlayerLatencySettings> {
|
||||||
|
@ -95,4 +104,8 @@ export class RtpVoiceClient implements VoiceClient {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private updateVolume() {
|
||||||
|
this.currentRtpTrack?.setGain(this.globallyMuted ? 0 : this.volume);
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Add table
Reference in a new issue