【问题标题】:Play audio files continuously using a for loop使用 for 循环连续播放音频文件
【发布时间】:2019-07-06 06:25:06
【问题描述】:

我有这个 HTML 代码:

<div id="1">Paragraph 1</div>
<div id="2">Paragraph 2</div>
<div id="3">Paragraph 3</div>
<div id="4">Paragraph 4</div>
<div id="5">Paragraph 5</div>

<span id="play">play</span>

我想要做的是,当我点击“播放”时,播放第 1 段的音频,在播放时,突出显示这个 div,并在后台加载下一段音频,这样音频就不会停止完全加载,这是到下一个的无缝过渡。现在当第一段的音频播放完毕后,取消突出显示该 div,然后播放下一段的音频并突出显示它并重复该过程直到循环完成。

我认为这很容易通过获取音频文件的持续时间并在 for 循环中播放所有音频来实现。但这不起作用:

$('#play').on("click",function(){

    var total_paragraphs = 7;

    function playAudio() {

        for (var i = 1; i <= total_paragraphs; i++) {

            var audio = new Audio("paragraphs/"+i+".mp3");

            var sec, ms;

            audio.addEventListener("loadedmetadata", function(_event) {
                seconds = audio.duration.toFixed(2),
                milliseconds = audio.duration.toFixed(2)*1000;
            });

            $("#"+i).css("background-color", "red");

            audio.play();

            audio.onended = function() {
                $("#"+i).css("background-color", "white");
            };

        }

    }

    playAudio();

});

当我点击播放时,所有的音频都会同时播放。似乎所有循环都是同时执行的。我想获得音频文件的持续时间来延迟循环,但这也不起作用。

我确信有很多更简单的方法可以做我想做的事。任何帮助,将不胜感激。

【问题讨论】:

  • audio.onended 回调中的i 将始终为8。同样,loadedmetadata 回调中的 audio 将始终为 new Audio("paragraphs/7.mp3")
  • @PatrickRoberts 请问有什么解决方案吗?

标签: javascript jquery html


【解决方案1】:

怎么样:

html

<div class="paragraph">Paragraph 1</div>
<div class="paragraph">Paragraph 2</div>
<div class="paragraph">Paragraph 3</div>
<div class="paragraph">Paragraph 4</div>
<div class="paragraph">Paragraph 5</div>

<span id="play">play</span>

jquery

_play = (totalParagraphs, currentParagraph) =>
{
    const paragraph = $(`.paragraph:nth-child(${currentParagraph})`)

    if (currentParagraph <= totalParagraphs)
    {
        paragraph.css('background', 'coral');
        const audio = new Audio(`paragraphs/${currentParagraph}.mp3`)
        audio.play()
        audio.onended = () => {
            paragraph.css('background', 'white')
            _play(totalParagraphs, currentParagraph + 1)
        }
    }
}

$('#play').on('click', () => {

    let totalParagraphs  = $('.paragraph').length,
        currentParagraph = 1

    _play(totalParagraphs, currentParagraph)

})

【讨论】:

  • 这实际上几乎可以完美运行,只是就像我说的那样,过渡不是无缝的,因为它必须在前一个音频完成后才加载新音频。我想要的是过渡应该是无缝的,也就是说,它们不应该看起来像是不同的音频。我认为如果在后台加载下一个音频,这可以实现。有什么想法吗?
  • 其实,我现在很满意。但是,您也可以帮我使用暂停功能吗?因为它只是一个播放功能。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-11-26
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多