Usa le transizioni CSS3 con sfondi sfumati


215

Sto cercando di passare al passaggio del mouse con CSS su un'anteprima in modo che al passaggio del mouse il gradiente di sfondo sfuma. La transizione non funziona, ma se la cambio semplicemente in un rgba()valore, funziona bene. I gradienti non sono supportati? Ho provato a usare anche un'immagine, non trasferirà neanche l'immagine.

So che è possibile, come in un altro post qualcuno l'ha fatto, ma non riesco a capire come esattamente. Qualsiasi aiuto> Ecco alcuni CSS con cui lavorare:

#container div a {
  -webkit-transition: background 0.2s linear;
  -moz-transition: background 0.2s linear;
  -o-transition: background 0.2s linear;
  transition: background 0.2s linear;
  position: absolute;
  width: 200px;
  height: 150px;
  border: 1px #000 solid;
  margin: 30px;
  z-index: 2
}

#container div a:hover {
  background: -webkit-gradient(radial, 100 75, 100, 100 75, 0, from(rgba(0, 0, 0, .7)), to(rgba(0, 0, 0, .4)))
}

5
Ora IE10 supporta le transizioni gradiente: è stata una felice sorpresa!
sirmdawg,

@mkprogramming, woha, lo fa davvero e sembra fantastico! Ecco una demo (funziona con IE10 +). Spero che altri browser ottengano supporto anche per queste fantastiche cose.
Qtax,

Questo sito ha la soluzione migliore, ha funzionato per me: nimbupani.com/some-css-transition-hacks.html
Tom Hagen,

Risposte:


173

Le sfumature non supportano ancora le transizioni (sebbene le specifiche attuali affermino che dovrebbero supportare transizioni gradiente come gradiente tramite interpolazione).

Se si desidera un effetto di dissolvenza con una sfumatura di sfondo, è necessario impostare un'opacità su un elemento contenitore e 'transizione` l'opacità.

(Ci sono state alcune versioni del browser che supportavano le transizioni sui gradienti (ad esempio IE10. Ho testato le transizioni del gradiente nel 2016 in IE e sembravano funzionare in quel momento, ma il mio codice di test non funziona più.)

Aggiornamento: ottobre 2018 Le transizioni del gradiente con una nuova sintassi senza prefisso [ad es. Gradiente radiale (...)] ora hanno confermato di funzionare (di nuovo?) Su Microsoft Edge 17.17134. Non so quando è stato aggiunto. Non funziona ancora sugli ultimi Firefox e Chrome / Windows 10.


1
Inoltre, le specifiche del gradiente non sono ancora finite e l'attuale sviluppo delle specifiche del gradiente è già molto lontano dall'attuale implementazione del gradiente web.
c-smile,

1
Ma i browser per webkit per bordi ora supportano le nuove specifiche del gradiente di eredità mozilla e la vecchia sintassi del webkit. Confusamente, sono entrambi -webkit con prefisso
Michael Mullany,

3
Ciò che IE10 supporta pienamente le transizioni gradiente.
Niet the Dark Absol,


2
Puoi aggiungere una dimostrazione sull'uso delle transizioni con gradienti ora? Non riesco a capirlo in base alla tua risposta (e non riesco a trovare altre notizie al riguardo). L'ultima volta che ho sentito, non è possibile passare tra due immagini di sfondo, che sono le sfumature.
Mackenzie McClane,

98

Una soluzione è quella di spostare la posizione di sfondo per dare l'effetto del cambiamento del gradiente: http://sapphion.com/2011/10/css3-gradient-transition-with-background-position/

Transizione gradiente CSS3 con posizione di sfondo

Sebbene non sia possibile animare direttamente i gradienti utilizzando la proprietà di transizione CSS, è possibile animare la proprietà posizione di sfondo per ottenere una semplice animazione del gradiente:

Il codice per questo è semplicissimo:

#DemoGradient{  
    background: -webkit-linear-gradient(#C7D3DC,#5B798E);  
    background: -moz-linear-gradient(#C7D3DC,#5B798E);  
    background: -o-linear-gradient(#C7D3DC,#5B798E);  
    background: linear-gradient(#C7D3DC,#5B798E);  
  
    -webkit-transition: background 1s ease-out;  
    -moz-transition: background 1s ease-out;  
    -o-transition: background 1s ease-out;  
    transition: background 1s ease-out;  
  
    background-size:1px 200px;  
    border-radius: 10px;  
    border: 1px solid #839DB0;  
    cursor:pointer;  
    width: 150px;  
    height: 100px;  
}  
#DemoGradient:Hover{  
    background-position:100px;  
}  
<div id="DemoGradient"></div>  


31

Una soluzione consiste nell'utilizzare la posizione di sfondo per imitare la transizione del gradiente. Questa soluzione è stata utilizzata in Twitter Bootstrap alcuni mesi fa.

Aggiornare

http://codersblock.blogspot.fr/2013/12/gradient-animation-trick.html?showComment=1390287622614

Ecco un breve esempio:

Stato di collegamento

 .btn {
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-size: 12px;
  font-weight: 300;
  position: relative;
  display: inline-block;
  text-decoration: none;
  color: #fff;
  padding: 20px 40px;
  background-image: -moz-linear-gradient(top, #50abdf, #1f78aa);
  background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#50abdf), to(#1f78aa));
  background-image: -webkit-linear-gradient(top, #50abdf, #1f78aa);
  background-image: -o-linear-gradient(top, #50abdf, #1f78aa);
  background-image: linear-gradient(to bottom, #50abdf, #1f78aa);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff50abdf', endColorstr='#ff1f78aa', GradientType=0);
  background-repeat: repeat-y;
  background-size: 100% 90px;
  background-position: 0 -30px;
  -webkit-transition: all 0.2s linear;
     -moz-transition: all 0.2s linear;
       -o-transition: all 0.2s linear;
          transition: all 0.2s linear;
}

Hover state

.btn:hover {
   background-position: 0 0;
}

1
La tua risposta era appropriata prima di modificarla. Ora non è affatto una risposta, ma semplicemente un link al tuo sito web. Sto ripristinando la tua risposta all'originale.
Andrew Barber,

Ok nessun problema. Devo solo apportare piccole modifiche.
Vinzcelavi,

2
Ed ecco un violino per questo: jsfiddle.net/Volker_E/RksTV La chiave è la proprietà background-size, che non è possibile utilizzare in IE8. caniuse.com/#search=background-size A parte questo, è una bella soluzione.
Volker E.

11

Per quello che vale, ecco un mixin Sass:

Uso:

@include gradientAnimation(red, blue, .6s);

mixin:

@mixin gradientAnimation( $start, $end, $transTime ){
    background-size: 100%;
    background-image: linear-gradient($start, $end);
    position: relative;
    z-index: 100;
    &:before {
        background-image: linear-gradient($end, $start);
        content: "";
        display: block;
        height: 100%;
        position: absolute;
        top: 0; left: 0;
        opacity: 0;
        width: 100%;
        z-index: -100;
        transition: opacity $transTime;
    }
    &:hover {
        &:before {
            opacity: 1;
        }
    }
}

Tratto da questo fantastico post su Medium di Dave Lunny: https://medium.com/@dave_lunny/animating-css-gradients-using-only-css-d2fd7671e759


1
Il post su Medium è molto utile, grazie per averlo aggiunto
Gendrith,

9

So che è una vecchia domanda, ma a qualcuno piace il mio modo di soluzione in puro CSS. Sfumatura sfumata da sinistra a destra.

.contener{
  background-image:url('http://www.imgbase.info/images/safe-wallpapers/digital_art/3d_landscape/9655_3d_landscape.jpg');   width:300px;
  height:200px;
  background-size:cover;
  border:solid 2px black;
}
.ed {
    width: 0px;
    height: 200px;
    background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.75));
    position: relative;
    opacity:0;
    transition:width 20s, opacity 0.6s;
}

.contener:hover .ed{
    width: 300px;
    background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.75));
    position: relative;
    opacity:1;
    transition:width 0.4s, opacity 1.1s;
    transition-delay: width 2s;
    
    animation-name: gradient-fade;
    animation-duration: 1.1s;   
    -webkit-animation-name: gradient-fade; /* Chrome, Safari, Opera */
    -webkit-animation-duration: 1.1s; /* Chrome, Safari, Opera */
}




/* ANIMATION */
@-webkit-keyframes gradient-fade {
    0%   {background:linear-gradient(to right, rgba(0,0,255,0), rgba(255,0,0,0));}
    2%  {background:linear-gradient(to right, rgba(0,0,255,0.01875), rgba(255,0,0,0));}
    4%  {background:linear-gradient(to right, rgba(0,0,255,0.0375), rgba(255,0,0,0.0));}
    6%  {background:linear-gradient(to right, rgba(0,0,255,0.05625), rgba(255,0,0,0.0));}
    8% {background:linear-gradient(to right, rgba(0,0,255,0.075), rgba(255,0,0,0));}
    10%  {background:linear-gradient(to right, rgba(0,0,255,0.09375), rgba(255,0,0,0));}
    12%   {background:linear-gradient(to right, rgba(0,0,255,0.1125), rgba(255,0,0,0));}
    14%  {background:linear-gradient(to right, rgba(0,0,255,0.13125), rgba(255,0,0,0));}
    16%  {background:linear-gradient(to right, rgba(0,0,255,0.15), rgba(255,0,0,0));}
    18%  {background:linear-gradient(to right, rgba(0,0,255,0.16875), rgba(255,0,0,0));}
    20% {background:linear-gradient(to right, rgba(0,0,255,0.1875), rgba(255,0,0,0));}
    22%  {background:linear-gradient(to right, rgba(0,0,255,0.20625), rgba(255,0,0,0.01875));}
    24%   {background:linear-gradient(to right, rgba(0,0,255,0.225), rgba(255,0,0,0.0375));}
    26%  {background:linear-gradient(to right, rgba(0,0,255,0.24375), rgba(255,0,0,0.05625));}
    28%  {background:linear-gradient(to right, rgba(0,0,255,0.2625), rgba(255,0,0,0.075));}
    30%  {background:linear-gradient(to right, rgba(0,0,255,0.28125), rgba(255,0,0,0.09375));}
    32% {background:linear-gradient(to right, rgba(0,0,255,0.3), rgba(255,0,0,0.1125));}
    34%  {background:linear-gradient(to right, rgba(0,0,255,0.31875), rgba(255,0,0,0.13125));}
    36%   {background:linear-gradient(to right, rgba(0,0,255,0.3375), rgba(255,0,0,0.15));}
    38%  {background:linear-gradient(to right, rgba(0,0,255,0.35625), rgba(255,0,0,0.16875));}
    40%  {background:linear-gradient(to right, rgba(0,0,255,0.375), rgba(255,0,0,0.1875));}
    42%  {background:linear-gradient(to right, rgba(0,0,255,0.39375), rgba(255,0,0,0.20625));}
    44% {background:linear-gradient(to right, rgba(0,0,255,0.4125), rgba(255,0,0,0.225));}
    46%  {background:linear-gradient(to right, rgba(0,0,255,0.43125),rgba(255,0,0,0.24375));}
    48%   {background:linear-gradient(to right, rgba(0,0,255,0.45), rgba(255,0,0,0.2625));}
    50%  {background:linear-gradient(to right, rgba(0,0,255,0.46875), rgba(255,0,0,0.28125));}
    52%  {background:linear-gradient(to right, rgba(0,0,255,0.4875), rgba(255,0,0,0.3));}
    54%   {background:linear-gradient(to right, rgba(0,0,255,0.50625), rgba(255,0,0,0.31875));}
    56%  {background:linear-gradient(to right, rgba(0,0,255,0.525), rgba(255,0,0,0.3375));}
    58%  {background:linear-gradient(to right, rgba(0,0,255,0.54375), rgba(255,0,0,0.35625));}
    60%  {background:linear-gradient(to right, rgba(0,0,255,0.5625), rgba(255,0,0,0.375));}
    62% {background:linear-gradient(to right, rgba(0,0,255,0.58125), rgba(255,0,0,0.39375));}
    64%  {background:linear-gradient(to right,rgba(0,0,255,0.6), rgba(255,0,0,0.4125));}
    66%   {background:linear-gradient(to right, rgba(0,0,255,0.61875), rgba(255,0,0,0.43125));}
    68%  {background:linear-gradient(to right, rgba(0,0,255,0.6375), rgba(255,0,0,0.45));}
    70%  {background:linear-gradient(to right, rgba(0,0,255,0.65625), rgba(255,0,0,0.46875));}
    72%  {background:linear-gradient(to right, rgba(0,0,255,0.675), rgba(255,0,0,0.4875));}
    74% {background:linear-gradient(to right, rgba(0,0,255,0.69375), rgba(255,0,0,0.50625));}
    76%  {background:linear-gradient(to right, rgba(0,0,255,0.7125), rgba(255,0,0,0.525));}
    78%   {background:linear-gradient(to right, rgba(0,0,255,0.73125),,rgba(255,0,0,0.54375));}
    80%  {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.5625));}
    82%  {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.58125));}
    84%  {background:linear-gradient(to right, rgba(0,0,255,0.75),rgba(255,0,0,0.6));}
    86% {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.61875));}
    88%  {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.6375));}
    90%   {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.65625));}
    92%  {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.675));}
    94%  {background:linear-gradient(to right, rgba(0,0,255,0.75),rgba(255,0,0,0.69375));}
    96%  {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.7125));}
    98% {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.73125),);}
    100%  {background:linear-gradient(to right, rgba(0,0,255,0.75), rgba(255,0,0,0.75));}
}
<div class="contener" style="">
  <div class="ed"></div>
</div>


3

Di seguito, un tag anchor ha un figlio e un nipote. Il nipote ha il gradiente di sfondo lontano. Il bambino sullo sfondo vicino è trasparente, ma ha il gradiente a cui passare. Al passaggio del mouse, l'opacità del bambino viene spostata da 0 a 1, per un periodo di 1 secondo.

Ecco il CSS:

.bkgrndfar {
  position:absolute;
  top:0;
  left:0;
  z-index:-2;
  height:100%;
  width:100%;
  background:linear-gradient(#eee, #aaa);
}

.bkgrndnear {
  position:absolute;
  top:0;
  left:0;
  height:100%;
  width:100%;
  background:radial-gradient(at 50% 50%, blue 1%, aqua 100%);
  opacity:0;
  transition: opacity 1s;
}

a.menulnk {
  position:relative;
  text-decoration:none;
  color:#333;
  padding: 0 20px;
  text-align:center;
  line-height:27px;
  float:left;
}

a.menulnk:hover {
  color:#eee;
  text-decoration:underline;
}

/* This transitions child opacity on parent hover */
a.menulnk:hover .bkgrndnear {
  opacity:1;
}

E questo è l'HTML:

<a href="#" class="menulnk">Transgradient
<div class="bkgrndfar">
  <div class="bkgrndnear">
  </div>
</div>
</a>

Quanto sopra è testato solo nell'ultima versione di Chrome. Queste sono le immagini prima del passaggio del mouse, a metà strada sul passaggio del mouse e completamente trasferite al passaggio del mouse:

Prima a metà strada Dopo


3

Una soluzione parziale per la transizione gradiente consiste nell'utilizzare l'ombra del riquadro di inserimento: è possibile eseguire il passaggio dell'ombra del riquadro stesso o del colore di sfondo, ad esempio se si crea un'ombra del riquadro di inserimento dello stesso colore dello sfondo e se si utilizza la transizione sul colore di sfondo, si crea illusione quel semplice sfondo sta cambiando in gradiente radiale

.button SPAN {
    padding: 10px 30px; 
    border: 1px solid ##009CC5;

    -moz-box-shadow: inset 0 0 20px 1px #00a7d1;
    -webkit-box-shadow: inset 0 0 20px 1px#00a7d1;
    box-shadow: inset 0 0 20px 1px #00a7d1; 

    background-color: #00a7d1;
    -webkit-transition: background-color 0.5s linear;
    -moz-transition: background-color 0.5s linear;
    -o-transition: background-color 0.5s linear;
    transition: background-color 0.5s linear;
}

.button SPAN:hover {
    background-color: #00c5f7; 
}

1
soluzione intelligente, l'ombra dell'inserzione può creare perfettamente l'illusione del gradiente
Aziz


2

Ho trovato un bel trucco su codepen che modifica la opacityproprietà ma raggiunge quella sfumatura da un gradiente all'altro sfruttando gli pseudo-elementi. Quello che fa è impostare un :aftermodo che quando cambi l'opacità dell'elemento reale, il:after elemento si presenta in modo che sembri una dissolvenza. Ho pensato che sarebbe stato utile condividere.

Codice originale: http://codepen.io/sashtown/pen/DfdHh

.button {
  display: inline-block;
  margin-top: 10%;
  padding: 1em 2em;
  font-size: 2em;
  color: #fff;
  font-family: arial, sans-serif;
  text-decoration: none;
  border-radius: 0.3em;
  position: relative;
  background-color: #ccc;
  background-image: linear-gradient(to top, #6d8aa0, #8ba2b4);
  -webkit-backface-visibility: hidden;
  z-index: 1;
}
.button:after {
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.3em;
  background-image: linear-gradient(to top, #ca5f5e, #d68584);
  transition: opacity 0.5s ease-out;
  z-index: 2;
  opacity: 0;
}
.button:hover:after {
  opacity: 1;
}
.button span {
  position: relative;
  z-index: 3;
}
body {
  text-align: center;
  background: #ddd;
}
<a class="button" href="#"><span>BUTTON</span></a>


2

Sulla base del codice CSS nella tua domanda, ho provato il codice come segue e funziona per me (esegui lo snippet di codice) e prova da solo:

#container div a {
  display: inline-block;
  margin-top: 10%;
  padding: 1em 2em;
  font-size: 2em;
  color: #fff;
  font-family: arial, sans-serif;
  text-decoration: none;
  border-radius: 0.3em;
  position: relative;
  background-color: #ccc;
  background-image: linear-gradient(to top, #C0357E, #EE5840);
  -webkit-backface-visibility: hidden;
  z-index: 1;
}
     
#container div a:after {
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.3em;
  background-image: linear-gradient(to top, #6d8aa0, #343436);
  transition: opacity 0.5s ease-out;
  z-index: 2;
  opacity: 0;
}
    
#container div a:hover:after {
  opacity: 1;
}
#container div a span {
  position: relative;
  z-index: 3;
}
<div id="container"><div><a href="#"><span>Press Me</span></a></div></div>

Sulla base del codice CSS nella tua domanda, ho provato il codice come segue e funziona per me, e prova da solo:

    #container div a {
  display: inline-block;
  margin-top: 10%;
  padding: 1em 2em;
  font-size: 2em;
  color: #fff;
  font-family: arial, sans-serif;
  text-decoration: none;
  border-radius: 0.3em;
  position: relative;
  background-color: #ccc;
  background-image: linear-gradient(to top, #C0357E, #EE5840);
  -webkit-backface-visibility: hidden;
  z-index: 1;
}

#container div a:after {
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.3em;
  background-image: linear-gradient(to top, #6d8aa0, #343436);
  transition: opacity 0.5s ease-out;
  z-index: 2;
  opacity: 0;
}

#container div a:hover:after {
  opacity: 1;
}
#container div a span {
  position: relative;
  z-index: 3;
}

Funziona per te? Cambia il colore in base alle tue necessità :)


1

Prova a usare: before e: after (ie9 +)

#wrapper{
    width:400px;
    height:400px;
    margin:0 auto;
    border: 1px #000 solid;
    position:relative;}
#wrapper:after,
#wrapper:before{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    content:'';
    background: #1e5799;
    background: -moz-linear-gradient(top, #1e5799 0%, #2989d8 50%, #207cca 51%, #7db9e8 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#1e5799), color-stop(50%,#2989d8), color-stop(51%,#207cca), color-stop(100%,#7db9e8));
    background: -webkit-linear-gradient(top, #1e5799 0%,#2989d8 50%,#207cca 51%,#7db9e8 100%);
    background: -o-linear-gradient(top, #1e5799 0%,#2989d8 50%,#207cca 51%,#7db9e8 100%);
    background: -ms-linear-gradient(top, #1e5799 0%,#2989d8 50%,#207cca 51%,#7db9e8 100%);
    background: linear-gradient(to bottom, #1e5799 0%,#2989d8 50%,#207cca 51%,#7db9e8 100%);
    opacity:1;
    z-index:-1;
    -webkit-transition: all 2s ease-out;
    -moz-transition: all 2s ease-out;
    -ms-transition: all 2s ease-out;
    -o-transition: all 2s ease-out;
    transition: all 2s ease-out;
}
#wrapper:after{
    opacity:0;
    background: #87e0fd;
    background: -moz-linear-gradient(top, #87e0fd 0%, #53cbf1 40%, #05abe0 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#87e0fd), color-stop(40%,#53cbf1), color-stop(100%,#05abe0));
    background: -webkit-linear-gradient(top, #87e0fd 0%,#53cbf1 40%,#05abe0 100%);
    background: -o-linear-gradient(top, #87e0fd 0%,#53cbf1 40%,#05abe0 100%);
    background: -ms-linear-gradient(top, #87e0fd 0%,#53cbf1 40%,#05abe0 100%);
    background: linear-gradient(to bottom, #87e0fd 0%,#53cbf1 40%,#05abe0 100%);
}
#wrapper:hover:before{opacity:0;}
#wrapper:hover:after{opacity:1;}

1

Come indicato. Le sfumature non sono attualmente supportate con le transizioni CSS. Ma potresti aggirare il problema in alcuni casi impostando uno dei colori su trasparente, in modo che il colore di sfondo di qualche altro elemento di avvolgimento brilli attraverso e la transizione invece.


1

Lo uso al lavoro :) IE6 + https://gist.github.com/GrzegorzPerko/7183390

Non dimenticare <element class="ahover"><span>Text</span></a>se si utilizza un elemento di testo.

.ahover {
    display: block;
    /** text-indent: -999em; ** if u use only only img **/
    position: relative;
}
.ahover:after {
    content: "";
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: all 0.5s ease 0s;
    width: 100%;
    z-index: 1;
}
.ahover:hover:after {
    opacity: 1;
}
.ahover span {
    display: block;
    position: relative;
    z-index: 2;
}

0

Non posso far male a pubblicare un altro punto di vista poiché non esiste ancora un modo ufficiale per farlo. Ha scritto un plug-in jQuery leggero con il quale è possibile definire un gradiente radiale di sfondo e una velocità di transizione. Questo utilizzo di base lo lascerà quindi sfumare, ottimizzato con requestAnimationFrame (molto fluido):

$('#element').gradientFade({

    duration: 2000,
    from: '(20,20,20,1)',
    to: '(120,120,120,0)'
});

http://codepen.io/Shikkediel/pen/xbRaZz?editors=001

Mantiene inalterato lo sfondo originale e tutte le proprietà. Ha anche il rilevamento delle luci come impostazione:

http://codepen.io/Shikkediel/pen/VYRZZY?editors=001


0

Volevo che un div apparisse come una sfera 3D e passasse attraverso i colori. Ho scoperto che i colori di sfondo sfumato non passano (ancora). Ho posizionato uno sfondo sfumato radiale davanti all'elemento (usando l'indice z) con uno sfondo solido in transizione.

/* overlay */
z-index : 1;
background : radial-gradient( ellipse at 25% 25%, rgba( 255, 255, 255, 0 ) 0%, rgba( 0, 0, 0, 1 ) 100% );

poi il div.ballsotto:

transition : all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);

quindi cambiato il colore di sfondo di div.balle voilà!

https://codepen.io/keldon/pen/dzPxZP

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.