Forem

Double Slash [FR]

Les animation avec CSS

Dans cet épisode, nous allons expliquer comment faire des animations avec CSS et comment optimiser les performances de vos animations Retrouvez la vidéo de l'enregistrement sur le Youtube de DoubleSlash Animation avec CSS Tout commence avec un changement d’état d’un élément. Changement de couleur et de taille pour un bouton par exemple quand je passe dessus avec la souris. Déclencher les changements d’états Pour déclencher des animations, on peut utiliser les pseudo classes (focus, hover, etc.), ajouter des classes avec JS et utiliser "IntersectionObserver" pour déclencher l'animation quand l'élément devient visible. Transition L’animation/transition apparait dès que l’on ajoute la propriété “Transition" Pour déterminer les transitions entre 2 états : Marche sur quasiment tout : width, height, background, etc.. Transform Mais dans l’idéal, il faut utiliser en priorité la propriété Transform. On reviendra sur la raison plus tard. Transform c'est 20 propriétés de transformation. Avec transform-origin, on peut créer des mouvements poussés Animation Passons maintenant aux vraies animations, celle qui peuvent tourner en boucle. Il est tout à fait possible de faire des animations avec CSS. Pour cela, il faut utiliser les propriétés animations : animation-name animation-duration animation-timing-function animation-delay animation-iteration-count animation-direction animation-fill-mode animation-play-state Évidemment, il y a une écriture raccourcie pour toutes les propriétés : Keyframes Mais avant de pouvoir utiliser les propriétés ”animation”, il faut créer une timeline avec @keyframes : ou Dans l'ensemble, c'est assez simple. On peut tout utiliser dans les @keyframes mais attention aux performances ! Motion Path 3 propriétés qui permettent à un élément de suivre un tracé. Le tracé a suivre : offset-path Position de l’élément sur le tracé : offset-distance La rotation de l’élément sur le tracé : offset-rotate Bientôt supporté par Safari !! FPS La plupart des appareils actualisent aujourd'hui leurs écrans 60 fois par seconde. S'il y a une animation ou une transition en cours d'exécution, ou si l'utilisateur fait défiler les pages, le navigateur doit faire correspondre le taux de rafraîchissement de l'appareil et mettre en place 1 nouvelle image, ou cadre, pour chacun de ces rafraîchissements d'écran. Chacune de ces cadres a un budget d'un peu plus de 16 ms (1 seconde / 60 = 16,66 ms). En réalité, cependant, le navigateur a un travail de nettoyage à faire, donc tout votre travail doit être achevé à l'intérieur de 10 ms. Lorsque vous ne respectez pas ce budget, la fréquence d'images baisse et le contenu juge à l'écran. Ceci est souvent appelé Jank, et cela a un impact négatif sur l'expérience de l'utilisateur. Bien animer ! Pour commencer, on va parler des étapes de rendu du page web (HTML, CSS). Cela fonctionne comme un tunnel qui s'appelle pixels-to-screen pipeline : 0 - JavaScript : Trier, ajouter un élément dans le DOM, etc... Dans le cas où c'est JS qui déclenche un changement visuel. 1 - style calculation (calcul du style) : lecture du CSS et détermination des règles basées sur les sélecteurs pour pouvoir les appliquer sur les éléments 2 - Layout (disposition) : Determination de la taille des éléments et placements dans le flux de la page 3 - Paint (peinture( : Les éléments deviennent des pixels. Essentiellement toutes les parties visuelles des éléments. Le dessin est généralement effectué sur plusieurs surfaces, souvent appelées couches. 4 - Composition : assemblage des layers entre eux pour composer la page Important Les propriétés ne sont pas toutes appliquées aux mêmes étapes. width et height c'est au layout. backgroud color c'est au paint. Chaque étape déclenche les suivantes. Changer la width d'un élément déclenche un layout > paint > composition. Donc plus de calcul et donc plus de temps. Dans l'idéal, il faut éviter de déclencheur du layout et du paint. Et donc, utiliser des propriétés qui déclenche que de la composition…

Episode source