我有以下几段代码
function modifyGain(stream){
var AudioContext = window.AudioContext || window.webkitAudioContext;
var ctx = new AudioContext();
var src = ctx.createMediaStreamSource(stream);
var dst = ctx.createMediaStreamDestination();
var gainNode = ctx.createGain();
gainNode.gain.value = 3.5;
src.connect(gainNode);
gainNode.connect(dst);
return dst.stream;
}我在原始流上尝试了addTrack()和removeTrack(),但没有成功。
这就是如何使用上面的函数。
webcamStream = await navigator.mediaDevices.getUserMedia(mediaConstraints);
webcamStream = modifyGain(webcamStream);
document.getElementById("local_video").srcObject = webcamStream;
webcamStream.getTracks().forEach(
function (track){
myPeerConnection.addTrack(track, webcamStream);
});这就是我如何停止音轨的呼叫挂断
webcamStream.getTracks().forEach(track => {
track.stop();
});
webcamStream = null;
localVideo.srcObject = null;在我应用该增益相关代码之前,所有工作都很好。但一旦我补充说,浏览器不释放麦克风,我必须刷新页面,以便与其他端进行任何音频交换。
请帮帮忙。
发布于 2020-12-16 08:55:10
有两个流。您只需停止第二个流中的曲目,即由ctx.createMediaStreamDestination()创建的流。
如果要放弃麦克风,则需要停止从navigator.mediaDevices.getUserMedia获取的原始流中的曲目。
https://stackoverflow.com/questions/65176439
复制相似问题