Table des matières
1. Construction et structure
2. Variables et interface
3. Soleil et nuages
Maison interface Web Questions et réponses frontales Un exemple d'utilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

Un exemple d'utilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

Jan 21, 2022 pm 05:01 PM
css

Cet article vous présente les opérations liées à l'utilisation de vite+scss pour réaliser une animation créative des changements d'humeur d'un chat orange. J'espère qu'il sera utile à tout le monde.

Un exemple d'utilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

Dans ce numéro, nous utilisons vite+scss pour réaliser une animation créative des changements d'humeur du chat orange. Nous n'utiliserons aucun code js pour la logique ici, et nous compterons uniquement sur CSS pour la compléter. l'animation dans ce numéro, vous pouvez apprendre quelques techniques d'animation et de dessin CSS.

Un exemple dutilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

C'est plutôt mignon. Lorsque la souris (le poisson) entre et sort, l'orange devient terne et apathique. Mais lorsque la souris (le poisson) s'installe, l'orange devient immédiatement heureuse lorsqu'elle voit son poisson préféré, et même le temps s'améliore. Oui, cette orange est si gourmande, et il y a une raison pour laquelle elle s'est transformée en une grosse orange.

D'accord, nous sommes sur le point d'entrer dans le texte principal. Nous comprendrons le processus de création de cette animation à partir de la construction de base, du dessin et de l'animation du soleil, des nuages ​​et des chats.

1. Construction et structure

yarn add vite sass sass-loader
Copier après la connexion

Nous utilisons vite et sass pour terminer la construction du projet et l'écriture du style, nous les installons donc en premier.

<div id="app">
    <div class="warrper">
        <div class="sun"></div>
        <div class="cloud"></div>
        <div class="cat">
            <div class="eye left"><div class="eye-hide"></div></div>
            <div class="eye right"><div class="eye-hide"></div></div>
            <div class="nose"></div>
            <div class="mouth"></div>
        </div>
    </div>
</div>
Copier après la connexion

En html, on écrit d'abord la structure. div#app sert d'interface principale pour remplir l'écran, et div.warrper sert de zone d'affichage pour le contenu principal, qui est le cercle. Ensuite, dans le cercle, on met le soleil div.sun, les nuages ​​div.cloud et le chat div.cat. Bien sûr, le chat a aussi des yeux, un nez et une bouche. Quant aux oreilles du chat, nous en utilisons deux. pseudo-classes pour faire des triangles.

2. Variables et interface

$cat:rgb(252, 180, 125);
:root{
    --bgColor:rgb(81, 136, 168);
    --eyeHideTop:0px;
    --cloudLeft:45%;
    --mouthRadius:10px 10px 0 0;
}
#app{
    width: 100%;
    height: 100vh;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    background-image: repeating-linear-gradient(0deg, hsla(340,87%,75%,0.2) 0px, hsla(340,87%,75%,0.2) 30px,transparent 30px, transparent 60px),repeating-linear-gradient(90deg, hsla(340,87%,75%,0.2) 0px, hsla(340,87%,75%,0.2) 30px,transparent 30px, transparent 60px),linear-gradient(90deg, rgb(255,255,255),rgb(255,255,255));
}
.warrper{
    width: 320px;
    height: 320px;
    border-radius: 50%;
    border: 10px solid white;
    position: relative;
    overflow: hidden;
    background-color: var(--bgColor);
    transition: background-color 1s linear;
    cursor:url("./assets/fish.png"),default;
    &:hover{
        --bgColor:rgb(178, 222, 247);
        --eyeHideTop:-20px;
        --cloudLeft:100%;
        --mouthRadius:0 0 10px 10px;
    }
}
Copier après la connexion

Nous définissons d'abord la couleur principale du chat, ainsi que certaines couleurs et distances qui doivent être modifiées, car nous modifierons ces attributs via CSS3 pour réaliser certaines animations.

Ce à quoi nous nous attendons, c'est que lorsque la souris se déplace dans le cercle, le ciel devient clair, les nuages ​​se dispersent et le chat est heureux et plein d'énergie. Par conséquent, bgColor : couleur du ciel, distance de l'axe y des paupières du chat eyeHideTop, cloudLeft. Distance de décalage de l'axe X du nuage, MouthRadius cat La valeur du congé de la bouche. Actuellement, ces valeurs changeront lorsque la souris se déplacera dans div.warrper. De plus, j'ai personnalisé l'icône de la souris pour qu'elle se déplace dans le cercle et la transforme en poisson (c'est-à-dire curseur : url (adresse de l'image)). Les valeurs après survol ici sont calculées par mes soins à l'avance. Si vous développez à nouveau d'autres animations, vous pourrez les calculer au fur et à mesure.

Un exemple dutilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

3. Soleil et nuages

.sun{
    width: 50px;
    height: 50px;
    position: absolute;
    background-color: rgb(255, 229, 142);
    border:7px solid rgb(253, 215, 91);
    border-radius: 50%;
    left: 55%;
    top: 14%;
    box-shadow: 0 0 6px rgb(255, 241, 48);
}
Copier après la connexion

Pour le soleil, nous dessinons un cercle pour déterminer sa position, puis utilisons la projection d'ombre en boîte pour obtenir un petit effet lumineux.

Un exemple dutilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

Ensuite, commençons à dessiner des nuages~

.cloud{
    width: 100px;
    height: 36px;
    background-color: white;
    position: absolute;
    transition: left .6s linear;
    left: var(--cloudLeft);
    top: 23%;
    border-radius: 36px;
    animation: bouncy 2s ease-in-out infinite;
    &::before{
        content: &#39;&#39;;
        width: 50px;
        height: 50px;
        background-color: white;
        border-radius: 50%;
        position: absolute;
        top: -23px;
        left: 18px;
    }
    &::after{
        content: &#39;&#39;;
        width: 26px;
        height: 26px;
        background-color: white;
        border-radius: 50%;
        position: absolute;
        top: -16px;
        left: 56px;
    }
}
@keyframes bouncy {
    0% {
      transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
    100% {
        transform: scale(1);
    }
}
Copier après la connexion

Les nuages ​​sont très simples. Nous dessinons simplement un rectangle arrondi, puis utilisons deux pseudo-classes pour dessiner un grand cercle et un petit cercle lorsqu'ils sont empilés ensemble. ils ressemblent à des nuages. De plus, nous ajoutons une animation pour le faire grandir et rétrécir, lui donnant une sensation de mouvement.

Un exemple dutilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

4. Chat orange et animation

.cat{
    width: 180px;
    height: 160px;
    background-color: $cat;
    position: absolute;
    bottom: -20px;
    left: 50%;
    margin-left: -90px;
    animation: wait 2s ease-in-out infinite;
    &::after,
    &::before{
        content: &#39;&#39;;
        display: block;
        border-style: solid;
        border-width: 20px 30px;
        position: absolute;
        top: -30px;    
    }
    &::after{
        right: 0;
        border-color: transparent $cat $cat transparent;
    }
    &::before{
        left: 0;
        border-color: transparent transparent $cat $cat;
    }
    .eye{
        width: 42px;
        height: 42px;
        border-radius: 50%;
        position: absolute;
        top: 30px;
        background:white;
        overflow: hidden;
        display: flex;
        justify-content: center;
        align-items: center;
        .eye-hide{
            height: 20px;
            position: absolute;
            top: var(--eyeHideTop);
            left: -2px;
            right:-2px;
            background-color: $cat;
            transition: top .5s ease-in-out;
            z-index: 2;
        }
        &::before{
            content: "";
            height: 36px;
            width: 36px;
            background-color:black;
            border-radius: 50%;
        }
        &::after{
            content: "";
            width: 24px;
            height: 24px;
            background-color: white;
            border-radius: 50%;
            position: absolute;
            right: 0px;
            top: 0px; 
        }
        &.left{
            left: 24px;
        }
        &.right{
            right: 24px;
        }
    }
    .nose{
        width: 0;
        height: 0;
        border-top: 7px solid rgb(248, 226, 226);
        border-left: 7px solid transparent;
        border-right: 7px solid transparent;
        position: absolute;
        left: 50%;
        margin-left: -7px;
        top: 70px;
    }
    .mouth{
        width: 26px;
        height: 20px;
        background-color: rgb(255, 217, 217);
        position: absolute;
        top: 85px;
        left: 50%;
        margin-left: -13px;
        border-radius: var(--mouthRadius);
        transition: border-radius .2s linear;
        overflow: hidden;
        &::after,
        &::before{
            content: "";
            position: absolute;
            display: block;
            top: 0;
            border-top: 7px solid white;
            border-left: 2px solid transparent;
            border-right: 2px solid transparent;
        }
        &::after{
            right: 5px;
        }
        &::before{
            left: 5px;
        }
    }
}
@keyframes wait{
    0% {
        bottom: -20px;
    }
    50% {
        bottom: -25px;
    }
    100% {
        bottom: -20px;
    }
}
Copier après la connexion

On peut le décomposer en, oreilles (pseudo-classe) + une paire d'yeux + nez + bouche (dont deux crocs) = chat.

D'après le code ci-dessus, il n'est pas difficile de voir que cela se fait principalement en utilisant un positionnement absolu pour placer les organes du visage. La plupart d'entre eux sont implémentés à l'aide de code CSS de base. La seule chose à laquelle vous pouvez prêter attention est le triangle de l'oreille. Nous l'implémentons via des pseudo-classes. Nous ne définissons pas la largeur et la hauteur, et utilisons principalement la technique border-width+boder-color pour le dessiner. est une petite astuce CSS, le nez à l'arrière et les crocs dans la bouche sont tous réalisés avec cette petite astuce.

De plus, je veux parler des yeux. On remplit d'abord le fond blanc puis on utilise des pseudo-classes pour réaliser le cercle de fond noir et le petit cercle blanc à l'intérieur. Certains élèves ont dû se demander pourquoi on n'utilise pas. bordure pour réaliser le cadre rond blanc. Il n'est pas nécessaire de gaspiller une pseudo-classe pour compléter le cercle de fond noir ? Parce que nous avons utilisé overflow: Hidden, son contenu caché redondant est constitué des éléments situés sous la bordure, et la bordure de la bordure peut être sans perte, donc sa pseudo-classe ne peut pas couvrir sa bordure. De cette façon, le cercle où les paupières tombent est toujours très grand. et contre nature. Nous avons donc créé une autre pseudo-classe pour implémenter son fond noir, afin que le cercle extérieur n'utilise pas de bordures.

Il ne reste plus qu'à faire une animation d'attente pour que le chat monte et descende pour obtenir l'effet de respiration continue.

Un exemple dutilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

De cette façon, le chat orange apathique est fini. Parce que dans la première partie, nous avons déjà calculé les variables qui seront modifiées après l'emménagement. Maintenant, déplacez la souris et l'effet apparaîtra~

Un exemple dutilisation du CSS pour réaliser la joie de Fat Orange (exemple de partage)

Conclusion

À ce stade, nous avons terminé l'animation, nous avons à Il a dit qu'il était tellement excité quand il a vu la nourriture qu'il méritait d'être appelé Fat Orange !

(Partage de vidéos d'apprentissage : Tutoriel vidéo CSS)

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Comment écrire des lignes fendues sur bootstrap Comment écrire des lignes fendues sur bootstrap Apr 07, 2025 pm 03:12 PM

Il existe deux façons de créer une ligne divisée bootstrap: en utilisant la balise, qui crée une ligne divisée horizontale. Utilisez la propriété CSS Border pour créer des lignes de fractionnement de style personnalisées.

Comment redimensionner le bootstrap Comment redimensionner le bootstrap Apr 07, 2025 pm 03:18 PM

Pour ajuster la taille des éléments dans Bootstrap, vous pouvez utiliser la classe de dimension, qui comprend: ajuster la largeur: .col-, .w-, .mw-ajustement Hauteur: .h-, .min-h-, .max-h-

Comment configurer le cadre de bootstrap Comment configurer le cadre de bootstrap Apr 07, 2025 pm 03:27 PM

Pour configurer le framework Bootstrap, vous devez suivre ces étapes: 1. Référez le fichier bootstrap via CDN; 2. Téléchargez et hébergez le fichier sur votre propre serveur; 3. Incluez le fichier bootstrap dans HTML; 4. Compiler les sass / moins au besoin; 5. Importer un fichier personnalisé (facultatif). Une fois la configuration terminée, vous pouvez utiliser les systèmes, composants et styles de grille de Bootstrap pour créer des sites Web et des applications réactifs.

Comment insérer des photos sur bootstrap Comment insérer des photos sur bootstrap Apr 07, 2025 pm 03:30 PM

Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

Comment utiliser le bouton bootstrap Comment utiliser le bouton bootstrap Apr 07, 2025 pm 03:09 PM

Comment utiliser le bouton bootstrap? Introduisez Bootstrap CSS pour créer des éléments de bouton et ajoutez la classe de bouton bootstrap pour ajouter du texte du bouton

Comment afficher la date de bootstrap Comment afficher la date de bootstrap Apr 07, 2025 pm 03:03 PM

Réponse: Vous pouvez utiliser le composant de sélecteur de date de bootstrap pour afficher les dates dans la page. Étapes: Présentez le framework bootstrap. Créez une boîte d'entrée de sélecteur de date dans HTML. Bootstrap ajoutera automatiquement des styles au sélecteur. Utilisez JavaScript pour obtenir la date sélectionnée.

See all articles