Проигрывайте последовательные звуки, чтобы создать звуковое предложение с HTML5 и JavaScript

Я пытаюсь собрать звуковую карту для приложения с пробелом в телефоне. Я хочу построить простые предложения для создания направлений.

Чтобы сузить круг, у меня есть массив аудиоэлементов, которые я хочу воспроизвести последовательно для выполнения аудио навигации. Например:

// playList[0].play --> "You are coming from the"
// playList[1].play --> "Reptile House"
// playList[2].play --> "(half-second pause as sentence period...)"
// playlist[3].play --> "Please select a destination from the list on the left."

В нижней части этого поста приведен упрощенный код, с которым я играл, но не добился большого успеха. Я продолжаю получать ошибки. Прежде чем предложить использовать jplayer или другую систему, мне кажется, что они больше ориентированы на воспроизведение песен с возможностью их остановки. Мне не нужен полноценный интерфейс в стиле jplayer или другого стиля. Мне просто нужно, чтобы люди нажимали кнопки, чтобы они могли ориентироваться в системе звуковой карты. Я продолжаю получать эту ошибку в консоли:

Uncaught TypeError: Object #selectionFrom has no method 'play' audio-map.js:142
(anonymous function) audio-map.js:142
jQuery.event.dispatch jquery-1.9.1.js:3074
jQuery.event.add.elemData.handle jquery-1.9.1.js:2750

Я пробовал массив как идентификаторы элементов и просто переменные.

var playList= ["#selectionFrom","#playReptileHouse","#play500msPause","#selectDestination"];
var playList= ["selectionFrom","playReptileHouse","play500msPause","selectDestination"];

Я был бы благодарен за любую помощь. Вот упрощенный скрипт:

$(document).ready(function() {

    var playZooEntrance = document.createElement('audio');
    playZooEntrance.setAttribute('src', 'assets/audio/playZooEntrance.mp3');
    playZooEntrance.setAttribute('id', 'playZooEntrance');
    document.body.appendChild(playZooEntrance);

    var playReptileHouse = document.createElement('audio');
    playReptileHouse.setAttribute('src', 'assets/audio/playReptileHouse.mp3');
    playReptileHouse.setAttribute('id', 'playReptileHouse');
    document.body.appendChild(playReptileHouse);

    var selectionFrom = document.createElement('audio');
    selectionFrom.setAttribute('src', 'assets/audio/selectionFrom.mp3');
    selectionFrom.setAttribute('id', 'selectionFrom');
    document.body.appendChild(selectionFrom);

    var selectDestination = document.createElement('audio');
    selectDestination.setAttribute('src', 'assets/audio/selectDestination.mp3');
    selectDestination.setAttribute('id', 'selectDestination');
    document.body.appendChild(selectDestination);

    var play500msPause = document.createElement('audio');
    play500msPause.setAttribute('src', 'assets/audio/play500msPause.mp3');
    play500msPause.setAttribute('id', 'play500msPause');
    document.body.appendChild(play500msPause);

    $('#selected_from').click(function() {  // On the press of a button...
        var playList= ["selectionFrom","playReptileHouse","play500msPause","selectDestination"];
        var i;
        for (i = 0; i < playList.length; ++i) {
            console.log(playList[i]);
            playList[i].play();
            playList[i].setAttribute('ended',function(){/* next i??? */});
        }
    });
    // Play this consecutively...
    // playList[0].play --> "You're coming from the"
    // playList[1].play --> "Reptile House"
    // playList[2].play --> "(half-second pause)"
    // playlist[3].play --> "Please select a destination from the list on the left."
});

1 ответ

Решение

Кажется, вы допустили ошибку типа: вы запрашиваете строку ("SelectionFrom") для воспроизведения, когда хотите получить элемент с таким идентификатором.
Таким образом, вы можете предварительно сохранить элементы в массиве или объекте при их создании, или найти их по id с помощью jquery ($('#'+playList[i]).

Другие вопросы по тегам