As tags <video> e <source>
Você preparou adequadamente um arquivo de vídeo para a web. Você lhe atribuiu as dimensões e a resolução corretas. Você até criou arquivos WebM e MP4 separados para navegadores diferentes.
Para que qualquer um consiga ver seu vídeo, você ainda precisa adicioná-lo a uma página da web. Fazer isso corretamente requer a adição de dois elementos HTML: o elemento <video>
e o elemento <source>
. Além das noções básicas sobre essas tags, este artigo explica os atributos que você deve adicionar a elas para criar uma boa experiência do usuário.
Especifique um único arquivo #
Embora não seja recomendado, você pode usar o elemento de vídeo sozinho. Sempre use o atributo type
conforme mostrado abaixo. O navegador usa isso para determinar se pode reproduzir o arquivo de vídeo fornecido. Se não puder, o texto incluído será exibido.
<video src="chrome.webm" tipo="video/webm">
<p>Seu navegador não pode reproduzir o arquivo de vídeo fornecido.</p>
</video>
Especifique vários formatos de arquivo #
Lembre-se das noções básicas de arquivos de mídia, de que nem todos os navegadores suportam os mesmos formatos de vídeo. O elemento <source>
permite que você especifique vários formatos como substituto, caso o navegador do usuário não ofereça suporte a algum deles.
O exemplo abaixo produz o vídeo incorporado que é usado posteriormente como exemplo neste artigo.
<video controls>
<source src="https://storage.googleapis.com/web-dev-assets/video-and-source-tags/chrome.webm" type="video/webm">
<source src="https://storage.googleapis.com/web-dev-assets/video-and-source-tags/chrome.mp4" type="video/mp4">
<p>Seu navegador não pode reproduzir o arquivo de vídeo fornecido.</p>
</video>
Você sempre deve adicionar um atributo de type
ao <source>
, embora ele seja opcional. Isso garante que o navegador baixe apenas o arquivo que é capaz de reproduzir.
Essa abordagem possui várias vantagens em relação à exibição de HTML diferente ou script do lado do servidor, especialmente em dispositivos móveis:
- Você pode listar os formatos em ordem de preferência.
- A comutação do lado do cliente reduz a latência; apenas uma solicitação é feita para obter conteúdo.
- Deixar o navegador escolher um formato é mais simples, rápido e potencialmente mais confiável do que usar um banco de dados de suporte do lado do servidor com detecção de agente de usuário.
- Especificar o tipo de cada fonte de arquivo melhora o desempenho da rede; o navegador pode selecionar uma fonte de vídeo sem ter que baixar parte do vídeo para "farejar" o formato.
Esses problemas são especialmente importantes em contextos móveis, onde a largura de banda e a latência são precárias e a paciência do usuário provavelmente é limitada. A omissão do type
pode afetar o desempenho quando há várias fontes com tipos não suportados.
Existem algumas maneiras de se aprofundar nos detalhes. Confira A Digital Media Primer for Geeks para saber mais sobre como o vídeo e o áudio funcionam na web. Você também pode usar a depuração remota em DevTools para comparar a atividade de rede com atributos de tipo e sem atributos de tipo .
Especifique os horários de início e término #
Economize largura de banda e torne seu site mais responsivo: use fragmentos de mídia para adicionar horários de início e término ao elemento de vídeo.
Para usar um fragmento de mídia, adicione #t=[start_time][,end_time]
ao URL da mídia. Por exemplo, para reproduzir o vídeo dos segundos 5 a 10, especifique:
<source src="video/chrome.webm#t=5,10" type="video/webm">
Você também pode especificar os tempos em <hours>:<minutes>:<seconds>
. Por exemplo, #t=00:01:05
inicia o vídeo em um minuto e cinco segundos. Para reproduzir apenas o primeiro minuto do vídeo, especifique #t=,00:01:00
.
Você pode usar esse recurso para fornecer várias visualizações no mesmo vídeo - como pontos de sinalização em um DVD - sem ter que codificar e servir vários arquivos.
Para que esse recurso funcione, seu servidor deve oferecer suporte a solicitações de intervalo e esse recurso deve ser ativado. A maioria dos servidores habilita solicitações de intervalo por padrão. Como alguns serviços de hospedagem os desativam, você deve confirmar se as solicitações de intervalo estão disponíveis para o uso de fragmentos em seu site.
Felizmente, você pode fazer isso nas ferramentas de desenvolvedor do seu navegador. No Chrome, por exemplo, está no painel Rede . Procure o Accept-Ranges
e verifique se ele diz bytes
. Na imagem, desenhei uma caixa vermelha ao redor deste cabeçalho. Se você não vir bytes
como o valor, entre em contato com seu provedor de hospedagem.
Incluir uma imagem de pôster #
Adicione um atributo pôster ao video
para que os espectadores tenham uma ideia do conteúdo assim que o elemento for carregado, sem a necessidade de baixar o vídeo ou iniciar a reprodução.
<video poster="poster.jpg" ...>
…
</video>
Um pôster também pode ser um substituto se o src
do vídeo estiver quebrado ou se nenhum dos formatos de vídeo fornecidos for compatível. A única desvantagem das imagens de pôster é uma solicitação de arquivo adicional, que consome parte da largura de banda e requer renderização. Para obter mais informações, consulte Codificar imagens com eficiência .
Não faça
Faça Quando os elementos de vídeo são muito grandes para a janela de visualização, eles podem estourar seu contêiner, tornando impossível para o usuário ver o conteúdo ou usar os controles. Você pode controlar as dimensões do vídeo usando CSS. Se o CSS não atender a todas as suas necessidades, bibliotecas e plug-ins JavaScript como o FitVids (fora do escopo deste artigo) podem ajudar, mesmo para vídeos do YouTube e outras fontes. Infelizmente, esses recursos podem aumentar o tamanho da carga útil da rede, com consequências negativas para suas receitas e carteiras de usuários. Para usos simples como os que estou descrevendo aqui, use consultas de mídia CSS para especificar o tamanho dos elementos dependendo das dimensões da janela de visualização; Para conteúdo de mídia em iframes (como vídeos do YouTube), tente uma abordagem responsiva (como a proposta por John Surdakowski ). Compare a amostra responsiva com a versão que não responde . Como você pode ver, a versão que não responde não é uma ótima experiência para o usuário. A orientação do dispositivo não é um problema para monitores de desktop ou laptops, mas é extremamente importante ao considerar o design da página da web para dispositivos móveis e tablets. O Safari no iPhone faz um bom trabalho ao alternar entre a orientação retrato e paisagem: A orientação do dispositivo em um iPad e Chrome no Android pode ser problemática. Por exemplo, sem qualquer personalização, um vídeo reproduzido em um iPad na orientação paisagem fica assim: Definir a O Chrome: depende de vários fatores, incluindo, sem limitação, se a visualização é no desktop e se o usuário móvel adicionou seu site ou aplicativo à tela inicial. Para obter detalhes, consulte Práticas recomendadas de reprodução automática . Firefox: bloqueia todos os vídeos e sons, mas dá aos usuários a capacidade de relaxar essas restrições para todos os sites ou sites específicos. Para obter detalhes, consulte Permitir ou bloquear a reprodução automática de mídia no Firefox Safari: historicamente exige um gesto do usuário, mas tem relaxado esse requisito nas versões recentes. Para obter detalhes, consulte Novas políticas de <vídeo> para iOS . Mesmo em plataformas onde a reprodução automática é possível, você precisa considerar se é uma boa ideia habilitá-la: O O Agora que você sabe como adicionar mídia à sua página da web, é hora de aprender sobre Acessibilidade de mídia, onde você adicionará legendas ao seu vídeo para deficientes auditivos ou quando reproduzir o áudio não for uma opção viável.Certifique-se de que os vídeos não transbordem de contêineres #
max-width: 100%
é seu amigo.CSS #
.video-container {
position: relative;
padding-bottom: 56.25%;
padding-top: 0;
height: 0;
overflow: hidden;
}
.video-container iframe,
.video-container object,
.video-container embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}HTML #
<div class="video-container">
<iframe src="//www.youtube.com/embed/l-BA9Ee2XuM"
frameborder="0" width="560" height="315">
</iframe>
</div>Orientação do dispositivo #
width: 100%
ou max-width: 100%
com CSS pode resolver muitos problemas de layout de orientação do dispositivo.Reprodução automática #
autoplay
controla se o navegador baixa e reproduz um vídeo imediatamente. A maneira precisa como funciona depende da plataforma e do navegador.Pré-carga #
preload
fornece uma dica ao navegador quanto à quantidade de informações ou conteúdo a ser pré-carregado.Valor Descrição none
O usuário pode optar por não assistir ao vídeo, portanto, não pré-carregue nada. metadata
Os metadados (duração, dimensões, trilhas de texto) devem ser pré-carregados, mas com o mínimo de vídeo. auto
Baixar o vídeo inteiro imediatamente é considerado desejável. Uma string vazia produz o mesmo resultado. preload
tem efeitos diferentes em plataformas diferentes. Por exemplo, o Chrome armazena 25 segundos de vídeo no desktop, mas nenhum no iOS ou Android. Isso significa que no celular, pode haver atrasos na inicialização da reprodução que não acontecem no desktop. Consulte Reprodução rápida com pré- carregamento de áudio e vídeo ou o blog de Steve Souders para obter mais detalhes.