我有以下几段代码
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;
在我应用该增益相关代码之前,所有工作都很好。但一旦我补充说,浏览器不释放麦克风,我必须刷新页面,以便与其他端进行任何音频交换。
请帮帮忙。
转载请注明出处:http://www.lechuangzk.com/article/20230526/2526996.html