如何一个接一个地播放<audio>块,没有弹出和点击?

时间:2016-01-26 00:59:34

标签: html5 audio ffmpeg html5-audio media-source

我有两个这样的标签:

<audio id="1" src="lub0.mp4" />
<audio id="2" src="lub1.mp4" />

我想逐个播放它们,即.play()第一个,当它启动一个事件时,我会播放()第二个。不幸的是,这给了我一个流行音乐。有没有正确的crossbrowser方式来做到这一点没有点击?

文件本身很好,如果我在ffmpeg中将它们粘在一起,声音是完美的。

感谢名单。

3 个答案:

答案 0 :(得分:3)

尝试以下方法。

var fileOne = document.getElementById('1');
fileOne.onended = function() {
    document.getElementById('2').play();
}

fileOne.play();

我确实对音频标签进行了不同的格式化,我按照你的方式尝试了它并且失败了。这就是我的方式

<audio id="1">
<source src="movie.mp4" type="video/mp4">
</audio >

<audio id="2">
  <source src="movie.mp4" type="video/mp4">
</audio >

答案 1 :(得分:2)

这是你可以检查的小提琴。您不需要单击它们,它们位于播放列表中,并且js eventlistener会在结束时检查它是否为另一个播放列表。当一个结束时,另一个将开始。注意我没有创建那个小提琴,但在我的项目中也用它作为我自己的一个例子。

http://jsfiddle.net/WsXX3/33/

HTML:

    <audio id="audio" preload="auto" tabindex="0" controls="" type="audio/mpeg">
    <source type="audio/mp3" src="http://www.archive.org/download/bolero_69/Bolero.mp3">
    Sorry, your browser does not support HTML5 audio.
</audio>
<ul id="playlist">
    <li class="active"><a href="http://www.archive.org/download/bolero_69/Bolero.mp3">Ravel Bolero</a></li>
    <li><a href="http://www.archive.org/download/MoonlightSonata_755/Beethoven-MoonlightSonata.mp3">Moonlight Sonata - Beethoven</a></li>
    <li><a href="http://www.archive.org/download/CanonInD_261/CanoninD.mp3">Canon in D Pachabel</a></li>
    <li><a href="http://www.archive.org/download/PatrikbkarlChamberSymph/PatrikbkarlChamberSymph_vbr_mp3.zip">patrikbkarl chamber symph</a></li>

</ul>

CSS:

#playlist,audio{background:#666;width:400px;padding:20px;}
.active a{color:#5DB0E6;text-decoration:none;}
li a{color:#eeeedd;background:#333;padding:5px;display:block;}
li a:hover{text-decoration:none;}

JS:

var audio;
var playlist;
var tracks;
var current;

init();
function init(){
    current = 0;
    audio = $('audio');
    playlist = $('#playlist');
    tracks = playlist.find('li a');
    len = tracks.length - 1;
    audio[0].volume = .10;
    audio[0].play();
    playlist.find('a').click(function(e){
        e.preventDefault();
        link = $(this);
        current = link.parent().index();
        run(link, audio[0]);
    });
    audio[0].addEventListener('ended',function(e){
        current++;
        if(current == len){
            current = 0;
            link = playlist.find('a')[0];
        }else{
            link = playlist.find('a')[current];    
        }
        run($(link),audio[0]);
    });
}
function run(link, player){
        player.src = link.attr('href');
        par = link.parent();
        par.addClass('active').siblings().removeClass('active');
        audio[0].load();
        audio[0].play();
}

答案 2 :(得分:0)

如果我理解正确的话......

我现在唯一可以推荐的是添加preload="auto"(以减少缓冲时间)。
Example

  • HTML:

    <audio id="file1" src="http://www.freesound.org/data/previews/335/335253_3162775-lq.mp3" controls preload="auto"></audio>
    <br>
    <audio id="file2" src="http://www.freesound.org/data/previews/331/331122_4490625-lq.mp3" controls preload="auto"></audio>
    
  • JS:

    var file1 = document.querySelector('#file1');
    var file2 = document.querySelector('#file2');
    
    file1.onended = function() {file2.play();}
    file2.onended = function() {file1.play();}
    
    file1.play();
    

然而,虽然这似乎在MP3是两首不相关的歌曲等时起作用,但是用ffmpeg将一个声音切换成两个单独的文件并以这种方式播放它们将在第二个文件的开头显示出一个小故障。从来没有,在我的情况下将它们连接回单个文件并不能修复故障(即在我的情况下,故障是声音文件本身的属性,因为它们通过不准确地将单个文件切割成两个部分而出现 - 不是浏览器行为的结果 - 您能提供您的文件吗?)。