2016-01-26 9 views
12

私はこのような二つのタグがあります。<audio>ブロックをポップとクリックしないで1つずつ再生する方法は?

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

私はすなわち.play(、それらを一つ一つを再生したい)最初のものを、それがイベントをonend起動したときに、私は)(1秒を.playます。残念ながら、これは私の間にポップ音を与えます。クリックなしでこれを行うには正しいcrossbrowserの方法はありますか?

私はffmpegでお互いを接着すると、ファイル自体は問題ありません。サウンドは完璧です。

Thanx。

+1

ウェブオーディオAPIを使用して、オーディオバッファにロードし、それらを再生すると、これを改善するかもしれない - しかし、コードは多くの関与 – William

+0

@Williamで、IEの仕事をaudiobufferでしょうか? –

+0

ウェブのオーディオAPIがIE上で動作しない – William

答えて

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 > 
+0

再生の間に何も聞かずにこれを聞くことができました – aemorales1

+0

しかしmp3ファイルではなくmp3を使用していました。 – aemorales1

+0

ちょうどMP4で試してみましたが、再生の間に – aemorales1

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(); 
} 
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ファイルは、2つの無関係な曲やなど、1を切断されたときに動作するようですが、 ffmpegで2つの別々のファイルにして、このように再生すると、 n 2番目のファイルの先頭。私の場合は、私の場合、それらを1つのファイルに連結しても、グリッチは修復されません(つまり、私の場合は、1つのファイルを2つの部分に不正確に切断することによってブラウザの動作 - ファイルを提供できますか?)

+0

これは私の[連結の結果](http://www.filedropper.com/concat)([元のファイル](http://www.freesound.org/data/previews/331/331122_4490625-lq.mp3)です。 )は00:00:05.000に分割され、次に連結されました)。 Amarokで完璧に演奏するのは面白いですが、ブラウザで再生すると、00:00:05.000のグリッチが表示されます。つまり、連結されたファイルはさまざまなプレーヤーで異なる発音をします。 – Sasha

関連する問題