转换此JavaScript以使用多首歌曲?

时间:2013-03-04 05:14:53

标签: javascript html5 html5-audio

我创建了这个小型音频播放器,播放随机介绍,一首歌的中段,然后是一个随机的outro。 现在它被硬编码为一首歌。每首歌有3个前奏,一个中段和3个outros。我希望能够有一个随机选择的歌曲列表(比如从数组中随机选取),因此脚本会选择一首歌并相应地更改脚本(前奏和outros以及中段)。 我想到了不同的方法,但是我不希望脚本中的每首歌都有大量的数组。我该如何设计这样的系统?在www.saradio.tk/dev.html进行演示(音频时序仅在Chrome-ACTIVE-TAB AFAIK中正常运行)

代码:

<body onload="checkdif(), loadintro(), loadoutro()">
<audio id="intro" src="" controls preload autoplay></audio>
<audio id="mid" src="radio/Barracuda-mid.ogg" controls preload></audio>
<audio id="outro" src="" controls preload></audio>
<br>
<br>
<button onclick="resetradio()">RESET</button>   <span id="timeleft"> n/a </span>

<script>
    var intros = [
        "radio/Barracuda-intro1.ogg",
        "radio/Barracuda-intro2.ogg",
        "radio/Barracuda-intro3.ogg"];

    var outros = [
        "radio/Barracuda-outro1.ogg",
        "radio/Barracuda-outro2.ogg",
        "radio/Barracuda-outro3.ogg"];

    function loadintro() {
        document.getElementById("intro").src = intros[Math.floor(Math.random() * intros.length)];
        document.getElementById("intro").load();
        document.getElementById("intro").play();
    }

    function loadoutro() {
        document.getElementById("outro").src = outros[Math.floor(Math.random() * outros.length)];
        document.getElementById("outro").load();
    }

    x = document.getElementById('intro');
    y = document.getElementById('mid');
    done = false;
    done2 = false;

    function checkdif() {
        if (done) return;
        setTimeout('checkdif()', 5);
        document.getElementById('timeleft').innerHTML = x.duration - x.currentTime;
        if (x.duration - x.currentTime <= 0.09) {
            document.getElementById('mid').play();
            done = true;
            checkdif2();
        }
    }

    function checkdif2() {
        if (done2) return;
        setTimeout('checkdif2()', 5);
        document.getElementById('timeleft').innerHTML = y.duration - y.currentTime;
        if (y.duration - y.currentTime <= 0.09) {
            document.getElementById('outro').play();
            done2 = true;
        }
    }

    function resetradio() {
        done = false;
        done2 = false;
        document.getElementById('mid').pause();
        document.getElementById('mid').currentTime = 0;
        loadintro();
        loadoutro();
        checkdif();
    }

    document.getElementById("outro").addEventListener('ended', resetradio, false)
</script>
</body>

PS:我还想设计系统,以便删除刚刚从列表中播放的歌曲,因此它不会播放同一首歌,直到它循环播放所有其他可能的歌曲。所以它会从一系列歌曲中挑选出来,当它选择时,可以说&#34;歌曲x&#34;,它将删除&#34;歌曲x&#34;从数组中进行下一次随机选择。只是一个想法...

更新:这是我对该系统的最终实现:http://saradio.tk/new.html

如果您查看源并观看控制台,您会看到它从阵列中拉出一首随机歌曲,然后从阵列中删除该歌曲。这样,在播放完所有歌曲之前,它不会重复播放歌曲。一旦循环到达最后一首歌曲,阵列将恢复到原始状态。

1 个答案:

答案 0 :(得分:3)

即使你说你不想拥有大量的数组,只要每首歌都有一个介绍列表和一个outros列表,你必须以某种方式“了解”它们。你基本上有两个选择:

  1. 制作一个命名约定系统,其中所有的outros和intros都有类似的文件名和一些后缀
  2. 明确指出所有内省outros
  3. 对于1.,您的数据结构可能如下所示:

    var intro_suffix = '-intro';
    var outro_suffix = '-outro';
    var extension = '.ogg';
    var songs = [
        {
               base_name: "radio/Barracuda"
            ,  num_intro: 3
            , num_outros: 3
        },
        {
               base_name: "radio/SomeOtherSong"
            ,  num_intro: 3
            , num_outros: 3
        },
    ];
    

    从中选择一首歌后,您可以获得前奏,主歌和outro的文件名。例如:

    var song = songs[0];
    var intro_url = song.name
        + intro_suffix
        + (1 + Math.floor(Math.random() * song.num_intros))
        + extension;
    var song_url = song.name + extension;
    var outro_url = song.name
        + outro_suffix
        + (1 + Math.floor(Math.random() * song.num_outros))
        + extension;
    

    对于2,您的数据结构必须是明确的:

    var songs = [
        {
                 url: "radio/Barracuda.ogg"
            , intros: ["radio/Barracuda-intro1.ogg", "radio/Barracuda-intro2.ogg", "radio/Barracuda-intro3.ogg"]
            , outros: ["radio/Barracuda-outtro1.ogg", "radio/Barracuda-outro2.ogg", "radio/Barracuda-outro3.ogg"]
        },
        {
                 url: "radio/SomeOtherSong.ogg"
            , intros: ["radio/foo.ogg", "radio/bar.ogg", "radio/baz.ogg"]
            , outros: ["radio/meh.ogg", "radio/fuuuuu.ogg", "radio/yo.ogg"]
        },
    ];
    

    然后你将变量推导为:

    var song = songs[0];
    var intro_url = song.intros[Math.floor(Math.random() * song.intros.length)];
    var song_url = song.url;
    var outro_url = song.outros[Math.floor(Math.random() * song.outros.length)];
    

    2.的一个“优点”是你可以随心所欲地存档你的文件