如何从视频元素中获取频率数据,并实时输入音频API

How to get frequency data from video element and feed into audio API on the fly

本文关键字:数据 实时输入 API 音频 频率 获取 视频 元素      更新时间:2023-09-26

我正在尝试使用以下方法创建视频可视化(查看可能性的最小代码):

HTML:

<canvas id=canvas width=427 height=240></canvas>

JS:

var context = new webkitAudioContext()
  , analyser = context.createAnalyser()
  , video = document.createElement('video')
  , source = context.createMediaElementSource(video)
  , canvas = document.getElementById('canvas')
  , ctx = canvas.getContext('2d')
  ;
var loadVideos = function() {
    video.src = 'my video.ogg';
    source.connect(analyser);
    analyser.connect(context.destination);
    video.play();
    videoVisualization();
}
loadVideos();
function videoVisualization() {
    window.webkitRequestAnimationFrame(videoVisualization);
    ctx.drawImage(this.video, 0, 0, canvas.width, canvas.height);
    var freqByteData = new Uint8Array(analyser.frequencyBinCount);
    analyser.getByteFrequencyData(freqByteData);
    for (i = 0; i < freqByteData.length; ++i) {
        console.log(freqByteData[5]);
    }
}

如果我在中添加这个,这可以很容易地完成

<video id=video controls width=427 height=240>
    <source src="my video.ogg" type="audio/ogg" />
</video>

尤其是当我用scriptProcessor节点获取音频数据时,但我想随时更改视频源,而视频标签不支持它。

提前感谢,

Chromecast不完全支持Web音频。频率数据是不受支持的数据之一。查看此处的错误