Faire de l'affiche vidéo HTML5 la même taille que la vidéo elle-même

93

Est-ce que quelqu'un sait comment redimensionner l'affiche vidéo HTML5 pour qu'elle corresponde aux dimensions exactes de la vidéo elle-même?

voici un jsfiddle qui montre le problème: http://jsfiddle.net/zPacg/7/

voici ce code:

HTML:

<video controls width="100%" height="100%"  poster="http://www.wpclipart.com/blanks/buttons/glossy_buttons/glossy_button_blank_orange_rectangle.png">
  <source src="http://demo.inwebson.com/html5-video/iceage4.mp4" type="video/mp4" />
  <source src="http://demo.inwebson.com/html5-video/iceage4.ogg" type="video/ogg" />
  <source src="http://demo.inwebson.com/html5-video/iceage4.webm" type="video/webm" />
</video>

CSS:

video{
border:1px solid red;
}​

Notez que le rectangle orange ne s'adapte pas à la bordure rouge de la vidéo.

De plus, ajouter simplement le CSS ci-dessous ne fonctionne pas non plus car il redimensionne la vidéo avec l'affiche:

video[poster]{
height:100%;
width:100%;
}
Tim Peterson
la source
1
je ne pense pas que vous puissiez utiliser "%" dans les attributs; cependant, le changer à 100 ne résout pas le problème. Je parie que c'est un style de média -webkit. n'hésitez pas à les parcourir trac.webkit.org/browser/trunk/Source/WebCore/css/…
albert
@albert, merci, je ne vois aucune référence posterdans le lien que vous avez envoyé. Pouvez-vous me montrer à quoi ressemble le CSS pour ce dont vous parlez, c'est-à-dire " -webkit media style"? merci
tim peterson
bien c'est ce que je voulais dire par "cueillette"; ce sont des styles de médias spécifiques au chrome; je ne les connais que vaguement, sans parler des pseudo sélecteurs qu'ils déclarent; sans point de départ: je passerais par la recherche de déclarations avec remplissage, etc.
albert

Réponses:

49

Vous pouvez utiliser une image d'affiche transparente en combinaison avec une image d'arrière-plan CSS pour y parvenir ( exemple ); cependant, pour avoir un arrière-plan étiré à la hauteur et à la largeur d'une vidéo, vous devrez utiliser une <img>balise positionnée de manière absolue ( exemple ).

Il est également possible de mettre background-sizeà100% 100% dans les navigateurs qui supportentbackground-size ( par exemple ).


Mettre à jour

Une meilleure façon de le faire serait d'utiliser la object-fitpropriété CSS comme le suggère @Lars Ericsson.

Utilisation

object-fit: cover;

si vous ne souhaitez pas afficher les parties de l'image qui ne correspondent pas au rapport hauteur / largeur de la vidéo, et

object-fit: fill;

pour étirer l'image pour l'adapter aux proportions de votre vidéo

Exemple

user2428118
la source
- @ user1419007, votre exemple répète l'image d'arrière-plan. Puisque vous suggérez que ce n'est pas la meilleure façon, cela vous dérangerait-il de fournir un jsfiddle montrant comment mettre en œuvre votre deuxième stratégie?
tim peterson
J'ai no-repeatédité l'image d'arrière-plan. Quant à l'autre solution, donnez-moi un moment pour y arriver.
user2428118
Edit: exemple ajouté pour la deuxième solution proposée.
user2428118
merci pour cela, nous avons besoin de javascript pour changer l' z-indeximage de sorte que la vidéo soit visible lorsque vous commencez à la lire.
tim peterson
2
.. le deuxième exemple n'a pas fonctionné dans Chrome? vous devez donner à la div externe une position comme jsfiddle.net/xh8er ; alors ça marche.
commonpike
87

En fonction des navigateurs que vous ciblez, vous pouvez utiliser la propriété object-fit pour résoudre ce problème:

object-fit: cover;

ou c'est peut fill- être ce que vous recherchez. Toujours à l'étude pour IE .

Lars Ericsson
la source
3
C'est certainement la réponse.
cilphex
1
+1 pour le lien vers la propriété object-fit , en utilisant object-fit: initialdid it for me.
FireBrand
"object-fit: fill" a fait l'affaire! comme l'a fait "object-fit: initial" (curieusement, parce que je ne vois pas de valeur "initiale" dans la spécification sur developer.mozilla.org/en-US/docs/Web/CSS/object-fit ). Les deux "cover" et "contain" ont déformé l'affiche lors de la lecture dans le navigateur natif de Samsung sous Android 5.1.1. Et cela n'affecte pas IE!
plugincontainer
1
Quel sélecteur CSS avez-vous ciblé pour la règle d'ajustement d'objet? Puisqu'il n'y a aucun moyen de cibler l'image de l'affiche, je suppose que vous avez utilisé video{object-fit: cover;}?
zıəs uɐɟəʇs
@ zıəs uɐɟəʇs Dans mon css c'est ... vidéo [poster] {object-fit: fill}
plugincontainer
27

Ou vous pouvez utiliser simplement l' preload="none"attribut pour rendre l'arrière-plan VIDEO visible. Et vous pouvez utiliser background-size: cover;ici.

 video {
   background: transparent url('video-image.jpg') 50% 50% / cover no-repeat ;
 }

 <video preload="none" controls>
   <source src="movie.mp4" type="video/mp4">
   <source src="movie.ogg" type="video/ogg">
 </video>
Veiko Jääger
la source
2
meilleure réponse. ne casse rien, et ne pas précharger une vidéo ne nuit pas vraiment à votre page à moins qu'il ne s'agisse d'un site centré sur la vidéo. +1.
totalementNotLizards
1
J'avais redimensionné en arrière-plan sur les mobiles. À partir d'autres questions / réponses ici (par exemple stackoverflow.com/questions/18229974/… ), il semble que le problème soit la duplication des images (l'arrière-plan du lecteur css et l'affiche de l'élément vidéo). Ce correctif a fonctionné.
plugincontainer
1
Hmm ... a travaillé dans Chrome mais a créé un nouveau problème dans le navigateur Android natif. Voir: stackoverflow.com/questions/39546792/…
plugincontainer
Corrigé enfin - voir la réponse de Lars Ericsson ci
plugincontainer
27

Je jouais avec cela et j'ai essayé toutes les solutions, finalement la solution que j'ai choisie était une suggestion de l'inspecteur de Google Chrome. Si vous ajoutez ceci à votre CSS, cela a fonctionné pour moi:

video{
   object-fit: inherit;
}
patrick
la source
Je vous remercie! C'était la solution exacte que je cherchais pour SUPPRIMER l'espace vidéo en haut et en bas
cpcdev
11

Ma solution combine les réponses de user2428118 et Veiko Jääger, permettant un préchargement mais sans nécessiter une image transparente séparée. Nous utilisons à la place une image transparente 1px encodée en base64.

<style type="text/css" >
    video{
        background: transparent url("poster.jpg") 50% 50% / cover no-repeat ;
    }
</style>
<video controls poster="" >
    <source src="movie.mp4" type="video/mp4">
    <source src="movie.ogg" type="video/ogg">
</video>
Jamie G
la source
Doit-il uniquement s'agir du nom de l'image ou du chemin complet?
Dans le navigateur natif d'Android (le navigateur s'appelle "Internet") sur mon Samsung, l'affiche a été redimensionnée ... catastrophiquement en cours de lecture. Cette solution - un gif transparent comme affiche et "l'affiche" comme arrière-plan - a résolu cela, MAIS, .. maintenant l'affiche ne s'affiche pas dans IE-9, 10 ou 11.
plugincontainer
1
La solution était d'abandonner le gif transparent et l'affiche comme arrière-plan et d'utiliser (voir la réponse de Lars Ericsson ci-dessus) la vidéo [poster] {object-fit: fill}. Problème résolu sur le navigateur natif Samsung sous Android 5.1.1. et IE affiche l'affiche sans problèmes
plugincontainer
Cette approche est meilleure en particulier pour les mobiles. object-fitn'empêche pas les distorsions de taille sauvage posterqui se produisent sur Android pendant le chargement du contenu.
TheLinguist
5

J'ai eu cette idée et cela fonctionne parfaitement. D'accord, nous voulons donc supprimer la première image de la vidéo de l'écran, puis redimensionner l'affiche à la taille réelle de la vidéo. Si nous définissons ensuite les dimensions, nous avons terminé l'une de ces tâches. Alors il n'en reste qu'un seul. Alors maintenant, le seul moyen que je connaisse pour me débarrasser de la première image est de définir une affiche. Cependant, nous allons donner à la vidéo une fausse vidéo, qui n'existe pas. Cela entraînera un affichage vide avec l'arrière-plan transparent. Ie arrière-plan de notre div parent sera visible.

Simple à utiliser, mais il peut ne pas fonctionner avec tous les navigateurs Web si vous souhaitez redimensionner la dimension de l'arrière-plan du div à la dimension de la vidéo car mon code utilise "background-size".

HTML / HTML5:

<div class="video_poster">
    <video poster="dasdsadsakaslmklda.jpg" controls>
        <source src="videos/myvideo.mp4" type="video/mp4">
        Your browser does not support the video tag.
    </video>
<div>

CSS:

video{
    width:694px;
    height:390px;
}
.video_poster{
    width:694px;
    height:390px;
    background-size:694px 390px;
    background-image:url(images/myvideo_poster.jpg);
}
Jonathan J
la source
c'est malin, je l'ai essayé. Ce n'est pas parfait mais y arriver ... jsfiddle.net/trpeters1/NJtc9
Tim Peterson
Oui tu as raison. En regardant votre jsfiddle, je réalise maintenant que la dimension de la vidéo doit également être correcte et pas seulement l'élément vidéo. Je suppose que j'ai eu de la chance quand je l'ai essayé sur ma page.
Jonathan J
5
<video src="videofile.webm" poster="posterimage.jpg" controls preload="metadata">
    Sorry, your browser doesn't support embedded videos.
</video>

Couverture

video{
   object-fit: cover; /*to cover all the box*/
}

Remplir

video{
   object-fit: fill; /*to add black content at top and bottom*/
   object-position: 0 -14px; /* to center our image*/
}

Notez que les contrôles vidéo sont sur notre image , donc notre image n'est pas complètement affichée. Si vous utilisez une couverture adaptée aux objets, modifiez votre image sur une application visuelle en tant que Photoshop et ajoutez un contenu de marge inférieure.

Daniel Eduardo Delgado Diaz
la source
1

J'ai eu un problème similaire et je viens de le résoudre en créant une image avec le même rapport hauteur / largeur que ma vidéo (16: 9). Ma largeur est définie à 100% sur la balise vidéo et maintenant l'image (320 x 180) s'adapte parfaitement. J'espère que cela pourra aider!

deebs
la source
1

Vous pouvez redimensionner la taille de l'image après avoir généré le pouce

exec("ffmpeg -i $video_image_dir/out.png -vf scale=320:240 {$video_image_dir}/resize.png",$out2, $return2);
Motilal Soni
la source
1

Vous pouvez utiliser l'affiche pour afficher l'image au lieu de la vidéo sur un appareil mobile (ou des appareils qui ne prennent pas en charge la fonctionnalité de lecture automatique vidéo). Parce que les appareils mobiles ne prennent pas en charge la fonctionnalité de lecture automatique vidéo.

<div id="wrap_video">
<video preload="preload" id="Video" autoplay="autoplay" loop="loop" poster="default.jpg">
<source src="Videos.mp4" type="video/mp4">
Your browser does not support the <code>video</code> tag.
</video>
</div>

Maintenant, vous pouvez simplement styliser l'attribut poster qui se trouve à l'intérieur de la balise vidéo pour l'appareil mobile via une requête multimédia.

#wrap_video
{
width:480px;
height:360px;
position: relative;
} 
@media (min-width:360px) and (max-width:780px)
{
video[poster]
{
top:0 !important;
left:0 !important;
width:480px !important;
height:360px !important;
position: absolute !important;
}
}
gopal sharma
la source
En fait, iOS 10+ prend en charge la fonctionnalité de lecture automatique de la vidéo avec l'attribut playinline.
Lukas Petr
Comment spécifiez-vous cet attribut?
Khom Nazid
0
height:500px;
min-width:100%;
-webkit-background-size: 100% 100%;
-moz-background-size: 100% 100%;
-o-background-size: 100% 100%;
background-size:100% 100%;
object-fit:cover;

-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size:cover;
Irinachen
la source
0

Cela a fonctionné

<video class="video-box" poster="/" controls>
    <source src="some source" type="video/mp4">
</video>

Et le CSS

.video-box{
 background-image: 'some image';
 background-size: cover;
}
user2903934
la source
0
  <div class="container">
        <video poster="~/Content/WebSite/img/SiteSetting/Load.gif" autoplay muted loop class="myVideo">
            <source src="~/Content/WebSite/images/VideoTube.mp4" type="video/mp4" />
        </video>

    </div>



 <style>
    .myVideo {
position: absolute;
right: 0;
left: 0;
bottom: 0;
min-width: 100%;
min-height: 100%;
object-fit: inherit;
 }
@media only screen and (max-width:768px) {
.myVideo {
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
    max-width: -webkit-fill-available;
    min-height: 100%;
    object-fit: cover;
    }
   }

     @media only screen and (max-width:320px) {
.myVideo {
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
    max-width: -webkit-fill-available;
    min-height: 100%;
    object-fit: cover;
  }
}
</style>
Aladein
la source