Как сделать автозапуск аудио на Chrome

автозапуск аудио работает в Mozilla, Microsoft edge и старом Google Chrome, но не в новом Google Chrome. они заблокировали автовоспроизведение. Есть ли способ сделать это автозапуск аудио в Google Chrome?

Ответы

Ответ 1

Решение № 1

Мое решение здесь - создать iframe

<iframe src="audio/source.mp3" allow="autoplay" style="display:none" id="iframeAudio">
</iframe> 
Теги

и audio также подходят для нехромных браузеров

<audio autoplay loop  id="playAudio">
      <source src="audio/source.mp3">
    </audio>

и в моем script

  var isChrome = /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor);
    if(!isChrome){
      $('#iframeAudio').remove()
    }
  else{
     $('#playAudio').remove() //just to make sure that it will not have 2x audio in the background 
  }

Решение № 2:

Согласно @Leonard

для этого есть и другой обходной путь.Создайте iframe, который ничего не воспроизводит, просто чтобы запустить автозапуск при первой загрузке.

<iframe src="silence.mp3" allow="autoplay" id="audio" style="display:none"></iframe>

хороший источник для mp3 файла silence.mp3

Затем воспроизведите свой настоящий аудиофайл в покое.

<audio id="player" autoplay loop>
    <source src="audio/source.mp3" type="audio/mp3">
</audio>

Лично я предпочитаю решение №2, потому что это более чистый подход, позволяющий не полагаться на JavaScript.

Обновление августа 2019 года

Решение № 3

В качестве альтернативы мы можем использовать <embed>

Для Firefox  Кажется, что автозапуск аудио работает, поэтому нам не нужен элемент <embed>, потому что он создаст двойной звук при запуске.

//index.js
let audioPlaying = true,
backgroundAudio,browser;
browser = navigator.userAgent.toLowerCase();
$('<audio class="audio1" src="audio.mp3" loop></audio>').prependTo('body');
if (!browser.indexOf('firefox') > -1) {
    $('<embed id="background-audio" src="audio.mp3" autostart="1"></embed>').prependTo('body');

 backgroundAudio = setInterval(function() {
      $("#background-audio").remove();
       $('<embed id="background-audio" src="audio.mp3"></embed>').prependTo('body');
      }, 120000);
      //120000 is the duration of your audio which in this case 2 mins.
}

Также, если у вас есть событие переключения для вашего аудио, обязательно удалите созданный элемент <embed> для аудио.

Примечание: После вашего переключения он будет перезапущен с самого начала, потому что <embed> уже удален и элемент <audio> теперь будет играть как обычно.

$(".toggle-audio").on('click', function(event) {
 audioPlaying = !audioPlaying;
 $("#background-audio").remove();

 clearInterval(backgroundAudio);
 if(audioPlaying){
    $(".audio1").play();
    //play audio 
  }else{
    $(".audio1").pause();

}

А теперь убедитесь, что скрыли эти элементы <audio> и <embed>

audio, embed {
  position: absolute;
  z-index: -9999;
}

Примечание: diplay:none и visibility:hidden приведут к тому, что элемент <embed> не будет работать.

Ответ 2

Есть действительно изящная хитрость в использовании функции autoplay тега audio в Chrome.

Добавить

<iframe src="silence.mp3" allow="autoplay" id="audio"></iframe>

тогда как silence.mp3 только 0,5 секунды тишины.

Это

<audio id="player" autoplay controls><source src="0.mp3" type="audio/mp3"></audio>

работает потом.

Chrome замечает, что звук был воспроизведен, и дает разрешение на автоматическое воспроизведение в аудиотэгах.

Ответ 3

Просто добавьте этот небольшой скрипт, как показано в https://developers.google.com/web/updates/2017/09/autoplay-policy-changes#webaudio

<head>
<script>
window.onload = function() {
  var context = new AudioContext();
}
</script>
</head>

Чем это будет работать, как вы хотите:

<audio autoplay>
      <source src="hal_9000_sorry_dave.mp3">
</audio>

Ответ 4

С апреля 2018 года правила автозапуска Chrome изменились:

"Правила автозапуска Chrome просты:

  • Приглушенный автовоспроизведение всегда разрешено.

Автозапуск со звуком разрешен, если:

  • Пользователь взаимодействовал с доменом (нажмите, нажмите и т.д.).
  • На рабочем столе пользовательское пороговое значение индекса вовлеченности мультимедиа превышено, что означает, что пользователь ранее воспроизводил видео со звуком.
  • На мобильном телефоне пользователь добавил сайт на свой домашний экран.

Также

  • Верхние кадры могут делегировать разрешение на автозапуск своим фреймам, чтобы разрешить автоигру со звуком. "

Сайт для разработчиков Chrome содержит больше информации, включая примеры программирования, которые можно найти здесь: https://developers.google.com/web/updates/2017/09/autoplay-policy-changes

Ответ 5

В прошлом месяце Google изменил свои правила в отношении автоигры в Chrome. Пожалуйста, посмотрите это объявление.

Однако они разрешают автоматическое воспроизведение, если вы встраиваете видео, и оно отключено. Вы можете добавить свойство muted и оно должно позволить видео начать воспроизведение.

<video autoplay controls muted>
  <source src="movie.mp4" type="video/mp4">
  <source src="movie.ogg" type="video/ogg">
  Your browser does not support the video tag.
</video>

Ответ 6

По крайней мере, вы можете использовать это:

document.addEventListener('click', musicPlay);
function musicPlay() {
    document.getElementById('ID').play();
    document.removeEventListener('click', musicPlay);
}

Музыка начинается, когда пользователь щелкает в любом месте страницы.

Он также мгновенно удаляет EventListener, поэтому, если вы используете аудиоустановки, пользователь может отключить звук или приостановить его, и музыка не начнется снова, когда он щелкнет где-нибудь еще.

Ответ 7

Вместо этого используйте iframe:

<iframe id="stream" src="YOUTSOURCEAUDIOORVIDEOHERE" frameborder="0"></iframe>

Ответ 8

Сегодня я отмахивался от этого, и я просто хотел добавить небольшой кусочек, который я обнаружил, к обсуждению.

Во всяком случае, я ушел от этого:

<iframe src="silence.mp3" allow="autoplay" id="audio" style="display:none"></iframe>
<audio id="audio" autoplay>
  <source src="helloworld.mp3">
</audio>

этом:

<audio id="myAudio" src="helloworld.mp3"></audio>
<script type="text/javascript">
  document.getElementById("myAudio").play();
</script>

И, наконец, это "решение", которое несколько выходит за рамки, если вы просто хотите создать свою собственную вещь (что мы делаем):

<script src='https://code.responsivevoice.org/responsivevoice.js'></script>
<input onclick='responsiveVoice.speak("Hello World");' type='button' value='Play' />

Открытие, которое я сделал, а также по-настоящему забавная (странная? странная? смешная?) часть состоит в том, что в случае с первыми двумя вы можете на самом деле победить систему, дав f5 правильное удары; если вы нажмете на обновление очень быстро (примерно 5-10 раз должно сработать), звук будет воспроизводиться автоматически, а затем он будет проигрываться несколько раз после обновления только для возврата к злым путям. Fantastic!

В объявлении от Google говорится, что для того, чтобы медиа файлы воспроизводились "автоматически", должно происходить взаимодействие между пользователем и сайтом. Поэтому лучшее "решение", которое мне удалось найти, - это добавить кнопку, которая сделает воспроизведение файлов менее автоматическим, но гораздо более стабильным/надежным.

Ответ 9

Вы можете использовать <iframe src="link/to/file.mp3" allow="autoplay">, если у источника есть разрешение автозапуска. Больше информации здесь.

Ответ 10

Я использовал pixi.js и pixi-sound.js для достижения автоматической игры в хром и firefox.

<script>

            PIXI.sound.Sound.from({
            url: 'audios/tuto.mp3',
            loop:true,
            preload: true,
            loaded: function(err, sound) {
                    sound.play();

            document.querySelector("#paused").addEventListener('click', function() {
            const paused = PIXI.sound.togglePauseAll();

            this.className = this.className.replace(/\b(on|off)/g, '');
            this.className += paused ? 'on' : 'off';

            });
            }
            });

</script>

HTML:

<button class="btn1 btn-lg off" id="paused">
    <span class="glyphicon glyphicon-pause off"></span>
    <span class="glyphicon glyphicon-play on"></span>
</button>

он также работает на мобильных устройствах, но пользователь должен прикасаться где-то на экране, чтобы вызвать звук.

Ответ 11

Как я заметил, этот атрибут autoplay удален, HTML5 больше не поддерживает функцию автовоспроизведения, даже если вы проверяете официальную документацию HTML5, вы не найдете ничего, связанного с автозапуском, поскольку они удалили ее из документации.

Ссылка: W3Schools. (2018, 09 07). HTML5 Audio. Источник: www.w3schools.com: https://www.w3schools.com/html/html5_audio.asp

Существуют альтернативные решения с помощью javascript.

Ответ 12

временное исправление

$(document).on('click', "#buttonStarter", function(evt)
{
var context = new AudioContext();
document.getElementById('audioPlayer').play();
$("#buttonStarter").hide()
$("#Game").show()
});

Или используйте пользовательский плеер, чтобы запустить игру http://zohararad.github.io/audio5js/

Примечание: автоигра будет сдана в аренду 31 декабря

Ответ 13

Я добавляю атрибут управления тоже тегом audio, и просто скрываю его в CSS. И все отлично работает в Chrome.

<audio autoplay loop controls id="playAudio">
  <source src="audio/source.mp3">
</audio>

Ответ 14

Вам нужно только запустить функцию воспроизведения при инициализации:

var aud = document.getElementById("myAudio");
aud.play(); // this will do the trick :)
<audio id="myAudio">
  <source src="https://wiki.selfhtml.org/local/Europahymne.mp3" type="audio/mp3">
</audio>

Ответ 15

Решение без использования iframe или javascript:

<embed src="silence.mp3" type="audio/mp3" autostart="true" hidden="true">
        <audio id="player" autoplay controls><source src="source/audio.mp3" type="audio/mp3"></audio>

Благодаря этому решению диалоговое окно открытия/сохранения в Internet Explorer также исключается.

   <embed src="http://deinesv.cf/silence.mp3" type="audio/mp3" autostart="true" hidden="true">
        <audio id="player" autoplay controls><source src="https://freemusicarchive.org/file/music/ccCommunity/Mild_Wild/a_Alright_Okay_b_See_Through/Mild_Wild_-_Alright_Okay.mp3" type="audio/mp3"></audio>

Ответ 16

Атрибут автозапуска HTML5 audio по умолчанию не работает в Chrome, но вы можете включить автозапуск аудио с помощью JavaScript. Попробуй это:

document.getElementById('myAudio').play();

Это работает для меня.