Я пытаюсь создать визуализацию видео, используя приведенный ниже метод (минимальный код, чтобы увидеть возможность):
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, но я хочу менять источники видео на лету, а тег видео не поддерживает это.
Заранее спасибо,