gpt4 book ai didi

javascript - 从 Canvas 和视频元素创建 MediaStream

转载 作者:行者123 更新时间:2023-11-30 09:40:43 27 4
gpt4 key购买 nike

我正在创建一个 MediaStream 对象,并使用 captureStream() 函数从 Canvas 向其添加视频轨道。这很好用。

但是我正在尝试将音频添加为与视频元素分开的轨道。我似乎找不到从 html 视频元素获取 AudioTrack 对象的方法。

目前 HTMLMediaElement.audioTracks 在 Chrome 中不受支持。根据 mozilla 开发人员网站,我应该能够使用 HTMLMediaElement.captureStream() 返回一个 MediaStream 对象,我应该能够从中检索单独的轨道,但我只是收到“captureStream 不是函数”错误。

也许我遗漏了一些非常明显的东西,但我将非常感谢这方面的任何帮助。

下面是我当前的代码:

var stream = new MediaStream();

//Works fine for adding video source
var videotracks = myCanvas.captureStream().getTracks();
var videostream = videotracks[0];
stream.addTrack(videostream);

//Currently not supported in Chrome
var audiotracks = myVid.audioTracks;
var audiostream = audiotracks[0];
stream.addTrack(audiostream);

最佳答案

以跨浏览器的方式从视频元素获取音频流:

AudioContext API createMediaStreamDestination + createMediaElementSource .

// if all you need is the audio, then you should even probably load your video in an Audio element
var vid = document.createElement('video');
vid.onloadedmetadata = generateAudioStream;
vid.crossOrigin = 'anonymous';
vid.src = 'https://dl.dropboxusercontent.com/s/bch2j17v6ny4ako/movie720p.mp4';

function generateAudioStream() {
var audioCtx = new AudioContext();
// create a stream from our AudioContext
var dest = audioCtx.createMediaStreamDestination();
// connect our video element's output to the stream
var sourceNode = audioCtx.createMediaElementSource(this);
sourceNode.connect(dest)
// start the video
this.play();
// your audio stream
doSomethingWith(dest.stream)
}

function doSomethingWith(audioStream) {
// the audio element that will be shown in the doc
var output = new Audio();
output.srcObject = audioStream;
output.controls = true;
output.play();
document.body.appendChild(output);
}

将音频添加到 Canvas 流:

MediaStream Capture Canvas and Audio Simultaneously

关于javascript - 从 Canvas 和视频元素创建 MediaStream,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41261716/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com