Maison > interface Web > tutoriel CSS > Comment utiliser CSS et D3 pour réaliser une animation à effet swing cycloïde

Comment utiliser CSS et D3 pour réaliser une animation à effet swing cycloïde

不言
Libérer: 2018-08-10 09:55:50
original
2273 Les gens l'ont consulté

Le contenu de cet article explique comment utiliser CSS et D3 pour réaliser l'animation de l'effet swing cycloïde. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. .

Aperçu de l'effet

Comment utiliser CSS et D3 pour réaliser une animation à effet swing cycloïde

Interprétation du code

Définissez dom, le conteneur contient 3 éléments, représentant 3 cycloïdes :

<div>
    <span></span>
    <span></span>
    <span></span>
</div>
Copier après la connexion

Affichage centré :

body {
    margin: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(lightyellow, burlywood);
}
Copier après la connexion

Définir la taille du conteneur et dessiner une cycloïde fixe pour indiquer le mur :

.pendulums {
    width: 40em;
    height: 30em;
    font-size: 10px;
    border-top: 0.3em solid cadetblue;
}
Copier après la connexion

Dessiner une cycloïde :

.pendulums {
    position: relative;
}

.pendulums span {
    position: absolute;
    width: 0.2em;
    height: 15em;
    background-color: cadetblue;
    left: 50%;
}
Copier après la connexion

Utilisez des pseudo-éléments pour dessiner une petite boule suspendue au bas de la cycloïde :

.pendulums span::before {
    content: '';
    position: absolute;
    width: 1.5em;
    height: 1.5em;
    background: steelblue;
    border-radius: 50%;
    top: 100%;
    left: -0.75em;
}
Copier après la connexion

Utilisez des dégradés radiaux pour ajouter de la lumière et de l'ombre à la petite boule :

.pendulums span::before {
    background: radial-gradient(
        circle at 70% 35%,
        white,
        darkturquoise 30%,
        steelblue 50%
    );
}
Copier après la connexion

Utilisez des pseudo-éléments pour dessiner l'ombre de la balle :

.pendulums span::after {
    content: '';
    position: absolute;
    width: 2em;
    height: 0.3em;
    background-color: rgba(0, 0, 0, 0.2);
    top: 120%;
    left: -1em;
    filter: blur(0.4em);
}
Copier après la connexion

En utilisant le sommet de la cycloïde comme origine, faites pivoter la cycloïde vers la gauche :

.pendulums span {
    transform-origin: 50% top;
    transform: rotate(25deg);
}
Copier après la connexion

Laissez le swing cycloïde :

.pendulums span {
    animation: swing ease-in-out infinite;
    animation-duration: 1.5s;
}

@keyframes swing {
    50% {
        transform: rotate(-25deg);
    }
}
Copier après la connexion

Définissez des variables d'indice pour chaque cycloïde :

.pendulums span:nth-child(1) {
    --n: 1;
}

.pendulums span:nth-child(2) {
    --n: 2;
}

.pendulums span:nth-child(3) {
    --n: 3;
}
Copier après la connexion

Utilisez des variables pour définir la longueur de la cycloïde et la durée de l'animation, qui augmentent progressivement arithmétique séquences :

.pendulums span {
    height: calc((var(--n) - 1) * 1em + 15em);
    animation-duration: calc((var(--n) - 1) * 0.02s + 1.5s);
}
Copier après la connexion

Ensuite, utilisez d3 pour traiter par lots les éléments dom et les variables CSS :
Introduisez la bibliothèque d3 :

<script></script>
Copier après la connexion

Utilisez d3 pour créer des éléments dom cycloïdaux :

const COUNT = 3;

d3.select('.pendulums')
    .selectAll('span')
    .data(d3.range(COUNT))
    .enter()
    .append('span')
Copier après la connexion

Utilisez d3 pour définir la variable d'indice de la cycloïde :

d3.select('.pendulums')
    .selectAll('span')
    .data(d3.range(COUNT))
    .enter()
    .append('span')
    .style('--n', (d) => d + 1);
Copier après la connexion

Supprimez les définitions dom pertinentes dans le fichier html et les définitions de variables dans le fichier css.

Enfin, ajustez le nombre de cycloïdes à 15.

const COUNT = 15;
Copier après la connexion

Recommandations associées :

Comment utiliser CSS pour implémenter l'effet d'animation d'un chargeur de montagnes russes

Comment utiliser CSS pur pour implémenter un cochon vert L'effet de

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal