IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Mise en page CSS Discussion :

Enchainement d'animations en CSS [CSS 3]


Sujet :

CSS

  1. #1
    Membre confirmé
    Homme Profil pro
    retraité
    Inscrit en
    Juin 2018
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Juin 2018
    Messages : 105
    Par défaut Enchainement d'animations en CSS
    Bonjour à tous

    dans une page de mon site je fais apparaitre des textes avec une animation CSS de la forme :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    .textappear {    
        opacity:0;
        animation-name: appear;
        animation-timing-function: ease;
        animation-delay: 6.5s;
        animation-duration: 1.5s;
        animation-iteration-count: 1;
        animation-fill-mode: forwards;
    }
     
    @keyframes appear {
        100% {
            opacity: 1;
        }
    }
    il y a six textes qui s'affichent les uns après les autres. Ils utilisent tous l'animation appear, avec des délais différents, la duration étant la même pour tous les textes.
    J'aimerai que tous ces textes disparaissent en même temps, 1 seconde après la fin de l'apparition du dernier texte.

    Y a-t-il un moyen, en CSS uniquement, de faire ça ? Est-il possible, par exemple, d'enchainer deux animations, la première qui ferait apparaitre les textes et la seconde qui les ferait disparaitre ?
    Comme ça ça serait assez facile, il suffirait que la somme de appear(delai+duration)+disappear(delai+duration) soit la même pour tous les textes. Mais je n'ai pas trouver le moyen d'enchainer deux animations successives pour une même DIV

    Par avance merci,
    Fifi

  2. #2
    Membre confirmé
    Homme Profil pro
    retraité
    Inscrit en
    Juin 2018
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Juin 2018
    Messages : 105
    Par défaut
    Si ça intéresse....

    Ma solution est de mettre le même délai et la même durée pour tous les textes et ensuite de régler les apparitions des textes avec le @keyframes.
    Pour que tous les textes disparaissent en même temps il suffit de mettre l'animation-fill-mode à none.
    Mais ça oblige à écrire une classe CSS par texte
    Chez moi ça donne ça :

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <body>
       <div class="labelo1">Texte 1</div>
       <div class="labelo2">Texte 2</div>
       <div class="labelo3">Texte 3</div>
    </body>
    Code CSS : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    .labelo1 {
        position: absolute;
        width: 300px;
        height: 100px;
        background-color: aqua;
        top: 20%;
        left: -50%;
        opacity:1;
        animation-name: gliss1;
        animation-timing-function: ease;
        animation-delay: 0s;
        animation-duration: 8s;
        animation-iteration-count: 1;
        animation-fill-mode: none;
    }
    .labelo2 {
        position: absolute;
        width: 300px;
        height: 100px;
        background-color: aqua;
        top: 40%;
        left: -50%;
        opacity:1;
        animation-name: gliss2;
        animation-timing-function: ease;
        animation-delay: 0s;
        animation-duration: 8s;
        animation-iteration-count: 1;
        animation-fill-mode: none;
    }
     
    .labelo3 {
        position: absolute;
        width: 300px;
        height: 100px;
        background-color: yellow;
        top: 60%;
        left: -50%;
        opacity:1;
        animation-name: gliss3;
        animation-timing-function: ease;
        animation-delay: 0s;
        animation-duration: 8s;
        animation-iteration-count: 1;
        animation-fill-mode: none;
    }
     
     
    @keyframes gliss1 {
        0%{
            left:-50%;
        }
        20%{
            opacity:1;
            left:50%;
        }
        100% {
            left: 50%;
            opacity:1;
        }
    }
     
    @keyframes gliss2 {
        30%{
            left:-50%;
        }
        50%{
            left:50%;
            opacity:1;
        }
        100% {
            left: 50%;
            opacity:1;
        }
    }
     
    @keyframes gliss3 {
        60%{
            left:-50%;
        }
        80%{
            left:50%;
            opacity:1;
        }
     
        100% {
            left: 50%;
            opacity:1;
        }
    }

  3. #3
    Expert confirmé
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 132
    Par défaut
    Salut

    Tu peux toujours réduire un peu le
    Code CSS : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    .Commun {
        position: absolute;
        width: 300px;
        height: 100px;
        left: -50%;
        opacity:1;
        animation-timing-function: ease;
        animation-delay: 0s;
        animation-duration: 8s;
        animation-iteration-count: 1;
        animation-fill-mode: none;
    }
    .labelo1 {
        background-color: aqua;
        top: 20%;
        animation-name: gliss1;
    }
    .labelo2 {
        background-color: aqua;
        top: 40%;
        animation-name: gliss2;
    }
    .labelo3 {
        background-color: yellow;
        top: 60%;
        animation-name: gliss3;
    }
    @keyframes gliss1 {
        0%   {left:-50%;}
        20%  {left:50%;}
        100% {left: 50%;}
    }
    @keyframes gliss2 {
        30% {left:-50%;}
        50% {left:50%;}
        100%{left: 50%;}
    }
    @keyframes gliss3 {
        60% {left:-50%;}
        80% {left:50%;}
        100% {left: 50%;}
    }
    en ajoutant la classe Commun au
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
       <div class="Commun labelo1">Texte 1</div>
       <div class="Commun labelo2">Texte 2</div>
       <div class="Commun labelo3">Texte 3</div>
    :whistle:pourquoi pas, pour remercier, un :plusser: pour celui/ceux qui vous ont dépannés.
    saut de ligne
    OOOOOOOOO👉 → → Ma page perso sur DVP ← ← 👈

  4. #4
    Membre confirmé
    Homme Profil pro
    retraité
    Inscrit en
    Juin 2018
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Juin 2018
    Messages : 105
    Par défaut
    .

    Bonjour ProgElecT

    en effet, merci.

    .

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 10
    Dernier message: 05/11/2009, 18h39
  2. [Dojo] dojo.animateProperty : Animer les Css
    Par Zineb1987_UNI dans le forum Bibliothèques & Frameworks
    Réponses: 11
    Dernier message: 29/10/2009, 18h47
  3. Enchainement d'animations avec Tweenlite
    Par ncheboi dans le forum ActionScript 3
    Réponses: 0
    Dernier message: 14/04/2009, 14h32
  4. Animation en CSS
    Par popy67 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 13/02/2008, 00h45

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo