YouTube: Jak zaprezentować osadzone wideo z wyciszonym dźwiękiem


81

Próbuję osadzić wideo z wyciszonym dźwiękiem, ale nie wiem, jak to działa.

Obecnie używam tego, ale nie działa:

<iframe src="https://www.youtube.com/embed/uNRGWVJ10gQ?rel=0&amp;autoplay=1" width="560" height="315" frameborder="0" allowfullscreen></iframe>

Czy ktoś z was wie, jak mogę to zrobić?

Odpowiedzi:


92

Zaktualizowano

Dodaj &mute=1na końcu swojego adresu URL.

Twój nowy kod wyglądałby tak:

<iframe src="https://www.youtube.com/embed/uNRGWVJ10gQ?rel=0&amp;autoplay=1&mute=1" width="560" height="315" frameborder="0" allowfullscreen></iframe>


6
już nie działa. użyj interfejsu API YouTube ( stackoverflow.com/a/41045251/353752 )
mwm,

@FrankConijn, łatwiejsze rozwiązanie? odpowiedzi są takie same, ale ten ma przykład, nie ma znaczenia, kto jest pierwszy, z przykładami rzeczy ułatwiają.
ICG DEVS

@ICGDEVS - Twój komentarz nie ma sensu. Spójrz na daty zmian i mój komentarz - pod inną odpowiedzią i nie mówiąc nic o „łatwiejszym”.
Frank Conijn,

Mój zły, przepraszam. w każdym razie twój komentarz, zanim mój zniknie, więc jego więcej nie ma już sensu.
ICG DEVS


29

Przyjęta odpowiedź nie działała dla mnie, zamiast tego skorzystałem z tego samouczka z sukcesem.

Gruntownie:

<div id="muteYouTubeVideoPlayer"></div>
<script async src="https://www.youtube.com/iframe_api"></script>
<script>
 function onYouTubeIframeAPIReady() {
  var player;
  player = new YT.Player('muteYouTubeVideoPlayer', {
    videoId: 'YOUR_VIDEO_ID', // YouTube Video ID
    width: 560,               // Player width (in px)
    height: 316,              // Player height (in px)
    playerVars: {
      autoplay: 1,        // Auto-play the video on load
      controls: 1,        // Show pause/play buttons in player
      showinfo: 0,        // Hide the video title
      modestbranding: 1,  // Hide the Youtube Logo
      loop: 1,            // Run the video in a loop
      fs: 0,              // Hide the full screen button
      cc_load_policy: 0, // Hide closed captions
      iv_load_policy: 3,  // Hide the Video Annotations
      autohide: 0         // Hide video controls when playing
    },
    events: {
      onReady: function(e) {
        e.target.mute();
      }
    }
  });
 }

 // Written by @labnol 
</script>

3
Możesz również dodać mute: 1jako dodatkowe, playerVara wtedy onReadywydarzenie nie będzie potrzebne. Pamiętaj, aby dodać przecinek po autohide: 0i pamiętaj, że nie możesz użyć, mute: 0ponieważ zostałby uznany za „spamerski”. Pamiętaj też, że po jawnym wyciszeniu wideo podczas odświeżania strony nadal będzie ono wyciszone.
Simon_Weaver,

11

To jest łatwe. Po prostu dodaj mute = 1 do parametru src elementu iframe.

Przykład:

<iframe src="https://www.youtube.com/embed/uNRGWVJ10gQ?controls=0&mute=1&showinfo=0&rel=0&autoplay=1&loop=1&playlist=uNRGWVJ10gQ" frameborder="0" allowfullscreen></iframe>


2
<iframe width="560" height="315" src="https://www.youtube-nocookie.com/embed/ObHKvS2qSp8?list=PLF8tTShmRC6uppiZ_v-Xj-E1EtR3QCTox&autoplay=1&controls=1&loop=1&mute=1" frameborder="0" allowfullscreen></iframe>



<iframe width="560" height="315" src="https://www.youtube.com/embed/ObHKvS2qSp8?list=PLF8tTShmRC6uppiZ_v-Xj-E1EtR3QCTox&autoplay=1&controls=1&loop=1&mute=1" frameborder="0" allowfullscreen></iframe>

Od 2017 r. Działa to poprawnie i powinno zostać zaakceptowane.
Manuel Di Iorio

2

Chciałbym podziękować znajomemu, który zamieścił poniższe kody w tym obszarze. W końcu rozwiązałem problem, z którym miałem do czynienia przez cały dzień.

<div id="muteYouTubeVideoPlayer"></div>
                            <script async src="https://www.youtube.com/iframe_api"></script>
                            <script>
                                function onYouTubeIframeAPIReady() {
                                    var player;
                                    player = new YT.Player('muteYouTubeVideoPlayer', {
                                        videoId: 'xCIBR8kpM6Q', // YouTube Video ID
                                        width: 1350, // Player width (in px)
                                        height: 500, // Player height (in px)
                                        playerVars: {
                                            autoplay: 1, // Auto-play the video on load
                                            controls: 0, // Show pause/play buttons in player
                                            showinfo: 0, // Hide the video title
                                            modestbranding: 0, // Hide the Youtube Logo
                                            loop: 1, // Run the video in a loop
                                            fs: 0, // Hide the full screen button
                                            cc_load_policy: 0, // Hide closed captions
                                            iv_load_policy: 3, // Hide the Video Annotations
                                            autohide: 0, // Hide video controls when playing
                                            rel: 0 
                                        },
                                        events: {
                                            onReady: function(e) {
                                                e.target.setVolume(5);
                                            }
                                        }
                                    });
                                }

                                // Written by @labnol

                            </script>


1

Źródło: https://developers.google.com/youtube/iframe_api_reference

   <div id="player"></div>
    <script>

          var tag = document.createElement('script');
          tag.src = "https://www.youtube.com/iframe_api";
          var firstScriptTag = document.getElementsByTagName('script')[0];
          firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);

          var player;
          function onYouTubeIframeAPIReady() {
            player = new YT.Player('player', {
              height: '720',
              width: '1280',
              videoId: 'M7lc1UVf-VE',
              playerVars :{'autoplay':1,'loop':1,'playlist':'M7lc1UVf-VE','vq':'hd720'},
              events: {
                'onReady': onPlayerReady,
                'onStateChange': onPlayerStateChange
              }
            });
          }

          function onPlayerReady(event) {
               event.target.setVolume(0);
           event.target.playVideo();
          }

          var done = false;
          function onPlayerStateChange(event) {
            if (event.data == YT.PlayerState.PLAYING && !done) {
        //      setTimeout(stopVideo, 6000);
                      done = true;
            }
               event.target.setVolume(0);
          }
    </script>

0

Po prostu podaj mute=1.

Na przykład:

<iframe id="myVideo" src="https://www.youtube.com/embed/k0DN-BZrM4o?rel=0&amp;autoplay=1;mute=1" width="100%" height="600" frameborder="0" allowfullscreen></iframe>


-3
<iframe width="560" height="315" src="https://www.youtube.com/embed/ULzr7JsFp0k?list=PLF8tTShmRC6vp9YTjkVdm1qKuTimC6K3e&rel=0&amp;autoplay=1&controls=1&loop=1" rel=0&amp frameborder="0" allowfullscreen></iframe>

2
Opisz, jak to działa i dlaczego. Samo opublikowanie fragmentu kodu nie jest pomocne dla nowicjuszy.
herrbischoff

To po prostu nie daje odpowiedzi na pytanie!
jankal,

-5

Spróbuj tego

<iframe width="420" height="315" src="http://www.youtube.com/embed/
HeQ39bLsoTI?autoplay=1&cc_load_policy=1" volume="0" frameborder="0"
allowfullscreen></iframe>

nie zapomnij napisać volume = "0"

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.