Question

je veux utiliser ce code, mais je veux que l'animation soit verticale.

header {
    width: 100%;
    height: 150px;
    background-image: url(http://www.scottishheritageusa.org/imgs/header_separator.png); //replace with your image
    background-position: 0px;
    background-repeat: repeat-x;
    -webkit-animation: myanim 5s infinite linear;
       -moz-animation: myanim 5s infinite linear;
         -o-animation: myanim 5s infinite linear;
            animation: myanim 5s infinite linear;
}

@-webkit-keyframes myanim {
    0%   { background-position: 0px; }
    100% { background-position: 100px; } /* set this to the width of the image */
}
@-moz-keyframes myanim {
    0%   { background-position: 0px; }
    100% { background-position: 100px; } /* set this to the width of the image */
}
@-o-keyframes myanim {
    0%   { background-position: 0px; }
    100% { background-position: 100px; } /* set this to the width of the image */
}
@keyframes myanim {
    0%   { background-position: 0px; }
    100% { background-position: 100px; } /* set this to the width of the image */
}

j'ai trouvé ce code ici : http://jsfiddle.net/e3WLD/3/

Merci pour l'aide

Était-ce utile?

La solution

La position d'arrière-plan accepte 2 paramètres:

  • le premier pour le positionnement horizontal
  • et le second pour le positionnement vertical

Plus d'infos sur la position d'arrière-plan sur W3Schools

Donc, en ajoutant un deuxième paramètre à la propriété de position de fond que vous pouvez Animez vos antécédents verticalement.

J'ai édité votre jsfiddle

à ceci:

header {
width: 100%;
height: 131px;
background-image: url(http://www.scottishheritageusa.org/imgs/header_separator.png);
background-position: 0px 0px;
background-repeat: repeat-y;
-webkit-animation: myanim 5s infinite linear;
   -moz-animation: myanim 5s infinite linear;
     -o-animation: myanim 5s infinite linear;
        animation: myanim 5s infinite linear;
}

@-webkit-keyframes myanim {
  0%   { background-position: 0px; }
  100% { background-position: 0px 1000px; } /* set this to the width of the image */
}
@-moz-keyframes myanim {
  0%   { background-position: 0px; }
  100% { background-position: 0px 1000px; } /* set this to the width of the image */
}
@-o-keyframes myanim {
  0%   { background-position: 0px; }
  100% { background-position: 1000px; } /* set this to the width of the image */
}
@keyframes myanim {
  0%   { background-position: 0px; }
  100% { background-position: 0px 1000px; } /* set this to the width of the image */
}

Autres conseils

Je suis capable de faire de la verticale en transformant l'élément de 90 degrés.

transform: rotate(90deg);
-webkit-transform: rotate(90deg);

Fiddle de travail

Vous ne pouvez définir et animer l'une des valeurs de position d'arrière-plan afin qu'elle suppose que cela se réfère à la première (Position X) et à l'autre par défaut à Auto (je pense).

Essayez ceci

** jsfiddle Demo **

**

CSS

header {
    width: 100%;
    height: 131px;
    background-image: url(http://www.scottishheritageusa.org/imgs/header_separator.png);
    background-position: 0px 0px; /* note */
    background-repeat: repeat-x;
    -webkit-animation: myanim 5s infinite linear;
       -moz-animation: myanim 5s infinite linear;
         -o-animation: myanim 5s infinite linear;
            animation: myanim 5s infinite linear;
}

@-webkit-keyframes myanim {
  0%   { background-position: 0px 0px; }
  100% { background-position: 0px 1000px; } 
}
@-moz-keyframes myanim 
{  0%   { background-position: 0px 0px; }
  100% { background-position: 0px 100px; } 
}
@-o-keyframes myanim {
  0%   { background-position: 0px 0px; }
  100% { background-position: 0px 100px; } 
}
@keyframes myanim {
  0%   { background-position: 0px 0px; }
  100% { background-position: 0px 100px; } 
}

Si vous souhaitez le configurer pour qu'il pivote verticalement comme ceci : http://jsfiddle.net/jme11/AYKC2/

Ensuite, vous devez définir la répétition sur repeat-y et modifiez la position de l'arrière-plan pour qu'elle corresponde à la hauteur de l'élément :

@keyframes myanim {
  0%   { background-position: 0px 0px; }
  100% { background-position: 0px 131px; } /* set this to the height of the image */
}
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top